mirror of
https://mirror.ghproxy.com/https://github.com/dexyfex/CodeWalker
synced 2024-11-21 22:42:54 +08:00
Hardware MSAA support for deferred render
This commit is contained in:
parent
152d439f89
commit
f333e64812
@ -392,6 +392,16 @@
|
|||||||
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">Pixel</ShaderType>
|
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">Pixel</ShaderType>
|
||||||
<ShaderModel Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">4.0</ShaderModel>
|
<ShaderModel Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">4.0</ShaderModel>
|
||||||
</FxCompile>
|
</FxCompile>
|
||||||
|
<FxCompile Include="DirLightPS_MS.hlsl">
|
||||||
|
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Release|x64'">Pixel</ShaderType>
|
||||||
|
<ShaderModel Condition="'$(Configuration)|$(Platform)'=='Release|x64'">4.1</ShaderModel>
|
||||||
|
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">Pixel</ShaderType>
|
||||||
|
<ShaderModel Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">4.1</ShaderModel>
|
||||||
|
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">Pixel</ShaderType>
|
||||||
|
<ShaderModel Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">4.1</ShaderModel>
|
||||||
|
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">Pixel</ShaderType>
|
||||||
|
<ShaderModel Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">4.1</ShaderModel>
|
||||||
|
</FxCompile>
|
||||||
<FxCompile Include="DirLightVS.hlsl">
|
<FxCompile Include="DirLightVS.hlsl">
|
||||||
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Release|x64'">Vertex</ShaderType>
|
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Release|x64'">Vertex</ShaderType>
|
||||||
<ShaderModel Condition="'$(Configuration)|$(Platform)'=='Release|x64'">4.0</ShaderModel>
|
<ShaderModel Condition="'$(Configuration)|$(Platform)'=='Release|x64'">4.0</ShaderModel>
|
||||||
@ -434,6 +444,16 @@
|
|||||||
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">Vertex</ShaderType>
|
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">Vertex</ShaderType>
|
||||||
<ShaderModel Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">4.0</ShaderModel>
|
<ShaderModel Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">4.0</ShaderModel>
|
||||||
</FxCompile>
|
</FxCompile>
|
||||||
|
<FxCompile Include="LodLightsPS_MS.hlsl">
|
||||||
|
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Release|x64'">Pixel</ShaderType>
|
||||||
|
<ShaderModel Condition="'$(Configuration)|$(Platform)'=='Release|x64'">4.1</ShaderModel>
|
||||||
|
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">Pixel</ShaderType>
|
||||||
|
<ShaderModel Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">4.1</ShaderModel>
|
||||||
|
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">Pixel</ShaderType>
|
||||||
|
<ShaderModel Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">4.1</ShaderModel>
|
||||||
|
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">Pixel</ShaderType>
|
||||||
|
<ShaderModel Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">4.1</ShaderModel>
|
||||||
|
</FxCompile>
|
||||||
<FxCompile Include="LodLightsPS.hlsl">
|
<FxCompile Include="LodLightsPS.hlsl">
|
||||||
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Release|x64'">Pixel</ShaderType>
|
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Release|x64'">Pixel</ShaderType>
|
||||||
<ShaderModel Condition="'$(Configuration)|$(Platform)'=='Release|x64'">4.0</ShaderModel>
|
<ShaderModel Condition="'$(Configuration)|$(Platform)'=='Release|x64'">4.0</ShaderModel>
|
||||||
|
@ -262,6 +262,12 @@
|
|||||||
<FxCompile Include="LodLightsPS.hlsl">
|
<FxCompile Include="LodLightsPS.hlsl">
|
||||||
<Filter>Lights</Filter>
|
<Filter>Lights</Filter>
|
||||||
</FxCompile>
|
</FxCompile>
|
||||||
|
<FxCompile Include="DirLightPS_MS.hlsl">
|
||||||
|
<Filter>Lights</Filter>
|
||||||
|
</FxCompile>
|
||||||
|
<FxCompile Include="LodLightsPS_MS.hlsl">
|
||||||
|
<Filter>Lights</Filter>
|
||||||
|
</FxCompile>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<None Include="BasicPS.hlsli">
|
<None Include="BasicPS.hlsli">
|
||||||
|
66
CodeWalker.Shaders/DirLightPS_MS.hlsl
Normal file
66
CodeWalker.Shaders/DirLightPS_MS.hlsl
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
#include "LightPS.hlsli"
|
||||||
|
|
||||||
|
|
||||||
|
Texture2DMS<float> DepthTex : register(t0);
|
||||||
|
Texture2DMS<float4> DiffuseTex : register(t2);
|
||||||
|
Texture2DMS<float4> NormalTex : register(t3);
|
||||||
|
Texture2DMS<float4> SpecularTex : register(t4);
|
||||||
|
Texture2DMS<float4> IrradianceTex : register(t5);
|
||||||
|
|
||||||
|
struct VS_Output
|
||||||
|
{
|
||||||
|
float4 Pos : SV_POSITION;
|
||||||
|
float4 Screen : TEXCOORD0;
|
||||||
|
};
|
||||||
|
|
||||||
|
PS_OUTPUT main(VS_Output input)
|
||||||
|
{
|
||||||
|
|
||||||
|
//switch (RenderMode)
|
||||||
|
//{
|
||||||
|
// case 5: c += diffuse.rgb; break;
|
||||||
|
// case 6: c += normal.rgb; break;
|
||||||
|
// case 7: c += specular.rgb; break;
|
||||||
|
//}
|
||||||
|
|
||||||
|
uint2 ssloc = uint2(input.Pos.xy); //pixel location
|
||||||
|
float2 spos = float2(input.Screen.xy / input.Screen.w);
|
||||||
|
float3 c = 0;
|
||||||
|
float d = 0;
|
||||||
|
float a = 0;
|
||||||
|
int sc = min(SampleCount, 8);
|
||||||
|
|
||||||
|
[unroll]
|
||||||
|
for (int i = 0; i < sc; i++)
|
||||||
|
{
|
||||||
|
float depth = DepthTex.Load(ssloc, i);
|
||||||
|
if (depth == 0) continue; //no existing subpixel rendered here
|
||||||
|
|
||||||
|
float4 diffuse = DiffuseTex.Load(ssloc, i);
|
||||||
|
float4 normal = NormalTex.Load(ssloc, i);
|
||||||
|
float4 specular = SpecularTex.Load(ssloc, i);
|
||||||
|
float4 irradiance = IrradianceTex.Load(ssloc, i);
|
||||||
|
|
||||||
|
float4 cpos = mul(float4(spos, depth, 1), ViewProjInv);
|
||||||
|
float3 camRel = cpos.xyz * (1 / cpos.w);
|
||||||
|
float3 norm = normal.xyz * 2 - 1;
|
||||||
|
|
||||||
|
float3 colour = DeferredDirectionalLight(camRel, norm, diffuse, specular, irradiance);
|
||||||
|
|
||||||
|
c += colour;
|
||||||
|
d += depth;
|
||||||
|
a += 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
c *= SampleMult;
|
||||||
|
d *= SampleMult;
|
||||||
|
a *= SampleMult;
|
||||||
|
|
||||||
|
if (d <= 0) discard;
|
||||||
|
|
||||||
|
PS_OUTPUT output;
|
||||||
|
output.Colour = float4(c, a);
|
||||||
|
output.Depth = d;
|
||||||
|
return output;
|
||||||
|
}
|
||||||
|
|
@ -18,8 +18,8 @@ cbuffer PSLightVars : register(b0)
|
|||||||
uint RenderSamplerCoord;
|
uint RenderSamplerCoord;
|
||||||
uint LightType; //0=directional, 1=Point, 2=Spot, 4=Capsule
|
uint LightType; //0=directional, 1=Point, 2=Spot, 4=Capsule
|
||||||
uint IsLOD; //useful or not?
|
uint IsLOD; //useful or not?
|
||||||
uint Pad0;
|
uint SampleCount;//for MSAA
|
||||||
uint Pad1;
|
float SampleMult;//for MSAA
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
53
CodeWalker.Shaders/LodLightsPS_MS.hlsl
Normal file
53
CodeWalker.Shaders/LodLightsPS_MS.hlsl
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
#include "LightPS.hlsli"
|
||||||
|
|
||||||
|
|
||||||
|
Texture2DMS<float> DepthTex : register(t0);
|
||||||
|
Texture2DMS<float4> DiffuseTex : register(t2);
|
||||||
|
Texture2DMS<float4> NormalTex : register(t3);
|
||||||
|
Texture2DMS<float4> SpecularTex : register(t4);
|
||||||
|
Texture2DMS<float4> IrradianceTex : register(t5);
|
||||||
|
|
||||||
|
struct VS_Output
|
||||||
|
{
|
||||||
|
float4 Pos : SV_POSITION;
|
||||||
|
float4 Screen : TEXCOORD0;
|
||||||
|
uint IID : SV_INSTANCEID;
|
||||||
|
};
|
||||||
|
|
||||||
|
float4 main(VS_Output input) : SV_TARGET
|
||||||
|
{
|
||||||
|
uint2 ssloc = uint2(input.Pos.xy); //pixel location
|
||||||
|
float2 spos = float2(input.Screen.xy / input.Screen.w);
|
||||||
|
float4 c = 0;
|
||||||
|
float d = 0;
|
||||||
|
int sc = min(SampleCount, 8);
|
||||||
|
|
||||||
|
[unroll]
|
||||||
|
for (int i = 0; i < sc; i++)
|
||||||
|
{
|
||||||
|
float depth = DepthTex.Load(ssloc, i);
|
||||||
|
if (depth == 0) continue; //no existing subpixel rendered here
|
||||||
|
|
||||||
|
float4 diffuse = DiffuseTex.Load(ssloc, i);
|
||||||
|
float4 normal = NormalTex.Load(ssloc, i);
|
||||||
|
float4 specular = SpecularTex.Load(ssloc, i);
|
||||||
|
float4 irradiance = IrradianceTex.Load(ssloc, i);
|
||||||
|
|
||||||
|
float4 cpos = mul(float4(spos, depth, 1), ViewProjInv);
|
||||||
|
float3 camRel = cpos.xyz * (1 / cpos.w);
|
||||||
|
float3 norm = normal.xyz * 2 - 1;
|
||||||
|
|
||||||
|
float4 colour = DeferredLODLight(camRel, norm, diffuse, specular, irradiance, input.IID);
|
||||||
|
|
||||||
|
c += colour;
|
||||||
|
d += depth;
|
||||||
|
}
|
||||||
|
|
||||||
|
c *= SampleMult;
|
||||||
|
d *= SampleMult;
|
||||||
|
|
||||||
|
if (d <= 0) discard;
|
||||||
|
|
||||||
|
return c;
|
||||||
|
}
|
||||||
|
|
@ -63,7 +63,7 @@ namespace CodeWalker.Rendering
|
|||||||
Usage = Usage.RenderTargetOutput
|
Usage = Usage.RenderTargetOutput
|
||||||
};
|
};
|
||||||
|
|
||||||
FeatureLevel[] levels = new FeatureLevel[] { FeatureLevel.Level_10_0 };
|
FeatureLevel[] levels = new FeatureLevel[] { FeatureLevel.Level_11_0, FeatureLevel.Level_10_1, FeatureLevel.Level_10_0 };
|
||||||
|
|
||||||
DeviceCreationFlags flags = DeviceCreationFlags.None;
|
DeviceCreationFlags flags = DeviceCreationFlags.None;
|
||||||
//#if DEBUG
|
//#if DEBUG
|
||||||
|
@ -132,6 +132,10 @@ namespace CodeWalker.Rendering
|
|||||||
srvd.Texture3D.MipLevels = mipLevels;
|
srvd.Texture3D.MipLevels = mipLevels;
|
||||||
srvd.Texture3D.MostDetailedMip = mostDetailedMip;
|
srvd.Texture3D.MostDetailedMip = mostDetailedMip;
|
||||||
break;
|
break;
|
||||||
|
case ShaderResourceViewDimension.Texture2DMultisampled:
|
||||||
|
case ShaderResourceViewDimension.Texture2DMultisampledArray:
|
||||||
|
//nothing to do here
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
throw new Exception(); //not implemented....
|
throw new Exception(); //not implemented....
|
||||||
}
|
}
|
||||||
|
@ -37,8 +37,8 @@ namespace CodeWalker.Rendering
|
|||||||
public uint RenderSamplerCoord; //which texcoord to use in single texture mode
|
public uint RenderSamplerCoord; //which texcoord to use in single texture mode
|
||||||
public uint LightType; //0=directional, 1=Point, 2=Spot, 4=Capsule
|
public uint LightType; //0=directional, 1=Point, 2=Spot, 4=Capsule
|
||||||
public uint IsLOD; //useful or not?
|
public uint IsLOD; //useful or not?
|
||||||
public uint Pad0;
|
public uint SampleCount;//for MSAA
|
||||||
public uint Pad1;
|
public float SampleMult;//for MSAA
|
||||||
}
|
}
|
||||||
|
|
||||||
public struct DeferredSSAAPSVars
|
public struct DeferredSSAAPSVars
|
||||||
@ -66,8 +66,10 @@ namespace CodeWalker.Rendering
|
|||||||
|
|
||||||
VertexShader DirLightVS;
|
VertexShader DirLightVS;
|
||||||
PixelShader DirLightPS;
|
PixelShader DirLightPS;
|
||||||
|
PixelShader DirLightMSPS;
|
||||||
VertexShader LodLightVS;
|
VertexShader LodLightVS;
|
||||||
PixelShader LodLightPS;
|
PixelShader LodLightPS;
|
||||||
|
PixelShader LodLightMSPS;
|
||||||
UnitCone LightCone;
|
UnitCone LightCone;
|
||||||
UnitSphere LightSphere;
|
UnitSphere LightSphere;
|
||||||
UnitCapsule LightCapsule;
|
UnitCapsule LightCapsule;
|
||||||
@ -86,6 +88,11 @@ namespace CodeWalker.Rendering
|
|||||||
public int SSAASampleCount = 1;
|
public int SSAASampleCount = 1;
|
||||||
|
|
||||||
|
|
||||||
|
public int MSAASampleCount = 4;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public long VramUsage
|
public long VramUsage
|
||||||
{
|
{
|
||||||
get
|
get
|
||||||
@ -102,8 +109,10 @@ namespace CodeWalker.Rendering
|
|||||||
|
|
||||||
byte[] bDirLightVS = File.ReadAllBytes("Shaders\\DirLightVS.cso");
|
byte[] bDirLightVS = File.ReadAllBytes("Shaders\\DirLightVS.cso");
|
||||||
byte[] bDirLightPS = File.ReadAllBytes("Shaders\\DirLightPS.cso");
|
byte[] bDirLightPS = File.ReadAllBytes("Shaders\\DirLightPS.cso");
|
||||||
|
byte[] bDirLightMSPS = File.ReadAllBytes("Shaders\\DirLightPS_MS.cso");
|
||||||
byte[] bLodLightVS = File.ReadAllBytes("Shaders\\LodLightsVS.cso");
|
byte[] bLodLightVS = File.ReadAllBytes("Shaders\\LodLightsVS.cso");
|
||||||
byte[] bLodLightPS = File.ReadAllBytes("Shaders\\LodLightsPS.cso");
|
byte[] bLodLightPS = File.ReadAllBytes("Shaders\\LodLightsPS.cso");
|
||||||
|
byte[] bLodLightMSPS = File.ReadAllBytes("Shaders\\LodLightsPS_MS.cso");
|
||||||
byte[] bFinalVS = File.ReadAllBytes("Shaders\\PPFinalPassVS.cso");
|
byte[] bFinalVS = File.ReadAllBytes("Shaders\\PPFinalPassVS.cso");
|
||||||
byte[] bSSAAPS = File.ReadAllBytes("Shaders\\PPSSAAPS.cso");
|
byte[] bSSAAPS = File.ReadAllBytes("Shaders\\PPSSAAPS.cso");
|
||||||
|
|
||||||
@ -111,6 +120,19 @@ namespace CodeWalker.Rendering
|
|||||||
DirLightPS = new PixelShader(device, bDirLightPS);
|
DirLightPS = new PixelShader(device, bDirLightPS);
|
||||||
LodLightVS = new VertexShader(device, bLodLightVS);
|
LodLightVS = new VertexShader(device, bLodLightVS);
|
||||||
LodLightPS = new PixelShader(device, bLodLightPS);
|
LodLightPS = new PixelShader(device, bLodLightPS);
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
//error could happen here if the device isn't supporting feature level 10.1
|
||||||
|
DirLightMSPS = new PixelShader(device, bDirLightMSPS);
|
||||||
|
LodLightMSPS = new PixelShader(device, bLodLightMSPS);
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
MSAASampleCount = 1; //can't do MSAA without at least 10.1 support
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
LightCone = new UnitCone(device, bLodLightVS, 4, false);
|
LightCone = new UnitCone(device, bLodLightVS, 4, false);
|
||||||
LightSphere = new UnitSphere(device, bLodLightVS, 4, true);
|
LightSphere = new UnitSphere(device, bLodLightVS, 4, true);
|
||||||
LightCapsule = new UnitCapsule(device, bLodLightVS, 4, false);
|
LightCapsule = new UnitCapsule(device, bLodLightVS, 4, false);
|
||||||
@ -198,6 +220,11 @@ namespace CodeWalker.Rendering
|
|||||||
DirLightPS.Dispose();
|
DirLightPS.Dispose();
|
||||||
DirLightPS = null;
|
DirLightPS = null;
|
||||||
}
|
}
|
||||||
|
if (DirLightMSPS != null)
|
||||||
|
{
|
||||||
|
DirLightMSPS.Dispose();
|
||||||
|
DirLightMSPS = null;
|
||||||
|
}
|
||||||
if (DirLightVS != null)
|
if (DirLightVS != null)
|
||||||
{
|
{
|
||||||
DirLightVS.Dispose();
|
DirLightVS.Dispose();
|
||||||
@ -208,6 +235,11 @@ namespace CodeWalker.Rendering
|
|||||||
LodLightPS.Dispose();
|
LodLightPS.Dispose();
|
||||||
LodLightPS = null;
|
LodLightPS = null;
|
||||||
}
|
}
|
||||||
|
if (LodLightMSPS != null)
|
||||||
|
{
|
||||||
|
LodLightMSPS.Dispose();
|
||||||
|
LodLightMSPS = null;
|
||||||
|
}
|
||||||
if (LodLightVS != null)
|
if (LodLightVS != null)
|
||||||
{
|
{
|
||||||
LodLightVS.Dispose();
|
LodLightVS.Dispose();
|
||||||
@ -249,7 +281,7 @@ namespace CodeWalker.Rendering
|
|||||||
Viewport.Y = 0.0f;
|
Viewport.Y = 0.0f;
|
||||||
|
|
||||||
|
|
||||||
GBuffers = new GpuMultiTexture(device, uw, uh, 4, Format.R8G8B8A8_UNorm, true, Format.D32_Float);
|
GBuffers = new GpuMultiTexture(device, uw, uh, 4, Format.R8G8B8A8_UNorm, true, Format.D32_Float, MSAASampleCount);
|
||||||
WindowSizeVramUsage += GBuffers.VramUsage;
|
WindowSizeVramUsage += GBuffers.VramUsage;
|
||||||
|
|
||||||
SceneColour = new GpuTexture(device, uw, uh, Format.R32G32B32A32_Float, 1, 0, true, Format.D32_Float);
|
SceneColour = new GpuTexture(device, uw, uh, Format.R32G32B32A32_Float, 1, 0, true, Format.D32_Float);
|
||||||
@ -293,18 +325,18 @@ namespace CodeWalker.Rendering
|
|||||||
|
|
||||||
public void RenderLights(DeviceContext context, Camera camera, Shadowmap globalShadows, ShaderGlobalLights globalLights)
|
public void RenderLights(DeviceContext context, Camera camera, Shadowmap globalShadows, ShaderGlobalLights globalLights)
|
||||||
{
|
{
|
||||||
uint rendermode = 0;
|
|
||||||
uint rendermodeind = 1;
|
|
||||||
|
|
||||||
//first full-screen directional light pass, for sun/moon
|
//first full-screen directional light pass, for sun/moon
|
||||||
//discard pixels where scene depth is 0, since nothing was rendered there
|
//discard pixels where scene depth is 0, since nothing was rendered there
|
||||||
//blend mode: overwrite
|
//blend mode: overwrite
|
||||||
|
|
||||||
context.VertexShader.Set(DirLightVS);
|
var ps = (MSAASampleCount > 1) ? DirLightMSPS : DirLightPS;
|
||||||
context.PixelShader.Set(DirLightPS);
|
|
||||||
|
|
||||||
LightVSVars.Vars.ViewProj = Matrix.Identity; //Matrix.Transpose(camera.ViewProjMatrix);
|
context.VertexShader.Set(DirLightVS);
|
||||||
LightVSVars.Vars.CameraPos = Vector4.Zero; //new Vector4(camera.Position, 0.0f);
|
context.PixelShader.Set(ps);
|
||||||
|
|
||||||
|
LightVSVars.Vars.ViewProj = Matrix.Identity;
|
||||||
|
LightVSVars.Vars.CameraPos = Vector4.Zero;
|
||||||
LightVSVars.Vars.LightType = 0;
|
LightVSVars.Vars.LightType = 0;
|
||||||
LightVSVars.Vars.IsLOD = 0;
|
LightVSVars.Vars.IsLOD = 0;
|
||||||
LightVSVars.Vars.Pad0 = 0;
|
LightVSVars.Vars.Pad0 = 0;
|
||||||
@ -314,15 +346,15 @@ namespace CodeWalker.Rendering
|
|||||||
|
|
||||||
LightPSVars.Vars.GlobalLights = globalLights.Params;
|
LightPSVars.Vars.GlobalLights = globalLights.Params;
|
||||||
LightPSVars.Vars.ViewProjInv = Matrix.Transpose(camera.ViewProjInvMatrix);
|
LightPSVars.Vars.ViewProjInv = Matrix.Transpose(camera.ViewProjInvMatrix);
|
||||||
LightPSVars.Vars.CameraPos = Vector4.Zero; //new Vector4(camera.Position, 0.0f);
|
LightPSVars.Vars.CameraPos = Vector4.Zero;
|
||||||
LightPSVars.Vars.EnableShadows = (globalShadows != null) ? 1u : 0u;
|
LightPSVars.Vars.EnableShadows = (globalShadows != null) ? 1u : 0u;
|
||||||
LightPSVars.Vars.RenderMode = rendermode;
|
LightPSVars.Vars.RenderMode = 0;
|
||||||
LightPSVars.Vars.RenderModeIndex = rendermodeind;
|
LightPSVars.Vars.RenderModeIndex = 1;
|
||||||
LightPSVars.Vars.RenderSamplerCoord = 0;// (uint)RenderTextureSamplerCoord;
|
LightPSVars.Vars.RenderSamplerCoord = 0;
|
||||||
LightPSVars.Vars.LightType = 0;
|
LightPSVars.Vars.LightType = 0;
|
||||||
LightPSVars.Vars.IsLOD = 0;
|
LightPSVars.Vars.IsLOD = 0;
|
||||||
LightPSVars.Vars.Pad0 = 0;
|
LightPSVars.Vars.SampleCount = (uint)MSAASampleCount;
|
||||||
LightPSVars.Vars.Pad1 = 0;
|
LightPSVars.Vars.SampleMult = 1.0f / MSAASampleCount;
|
||||||
LightPSVars.Update(context);
|
LightPSVars.Update(context);
|
||||||
LightPSVars.SetPSCBuffer(context, 0);
|
LightPSVars.SetPSCBuffer(context, 0);
|
||||||
|
|
||||||
@ -350,9 +382,10 @@ namespace CodeWalker.Rendering
|
|||||||
//instanced rendering of all other lights, using appropriate shapes
|
//instanced rendering of all other lights, using appropriate shapes
|
||||||
//blend mode: additive
|
//blend mode: additive
|
||||||
|
|
||||||
|
var ps = (MSAASampleCount > 1) ? LodLightMSPS : LodLightPS;
|
||||||
|
|
||||||
context.VertexShader.Set(LodLightVS);
|
context.VertexShader.Set(LodLightVS);
|
||||||
context.PixelShader.Set(LodLightPS);
|
context.PixelShader.Set(ps);
|
||||||
|
|
||||||
LightVSVars.Vars.ViewProj = Matrix.Transpose(camera.ViewProjMatrix);
|
LightVSVars.Vars.ViewProj = Matrix.Transpose(camera.ViewProjMatrix);
|
||||||
LightVSVars.Vars.CameraPos = new Vector4(camera.Position, 0.0f);
|
LightVSVars.Vars.CameraPos = new Vector4(camera.Position, 0.0f);
|
||||||
@ -361,26 +394,20 @@ namespace CodeWalker.Rendering
|
|||||||
LightVSVars.Vars.Pad0 = 0;
|
LightVSVars.Vars.Pad0 = 0;
|
||||||
LightVSVars.Vars.Pad1 = 0;
|
LightVSVars.Vars.Pad1 = 0;
|
||||||
|
|
||||||
//LightPSVars.Vars.GlobalLights = globalLights.Params;
|
|
||||||
LightPSVars.Vars.ViewProjInv = Matrix.Transpose(camera.ViewProjInvMatrix);
|
LightPSVars.Vars.ViewProjInv = Matrix.Transpose(camera.ViewProjInvMatrix);
|
||||||
LightPSVars.Vars.CameraPos = new Vector4(camera.Position, 0.0f);
|
LightPSVars.Vars.CameraPos = new Vector4(camera.Position, 0.0f);
|
||||||
LightPSVars.Vars.EnableShadows = 0;// (globalShadows != null) ? 1u : 0u;
|
LightPSVars.Vars.EnableShadows = 0;
|
||||||
LightPSVars.Vars.RenderMode = 0;// rendermode;
|
LightPSVars.Vars.RenderMode = 0;
|
||||||
LightPSVars.Vars.RenderModeIndex = 1;// rendermodeind;
|
LightPSVars.Vars.RenderModeIndex = 1;
|
||||||
LightPSVars.Vars.RenderSamplerCoord = 0;// (uint)RenderTextureSamplerCoord;
|
LightPSVars.Vars.RenderSamplerCoord = 0;
|
||||||
LightPSVars.Vars.LightType = 0;
|
LightPSVars.Vars.LightType = 0;
|
||||||
LightPSVars.Vars.IsLOD = 0;
|
LightPSVars.Vars.IsLOD = 0;
|
||||||
LightPSVars.Vars.Pad0 = 0;
|
LightPSVars.Vars.SampleCount = (uint)MSAASampleCount;
|
||||||
LightPSVars.Vars.Pad1 = 0;
|
LightPSVars.Vars.SampleMult = 1.0f / MSAASampleCount;
|
||||||
|
|
||||||
context.PixelShader.SetShaderResources(0, GBuffers.DepthSRV);
|
context.PixelShader.SetShaderResources(0, GBuffers.DepthSRV);
|
||||||
context.PixelShader.SetShaderResources(2, GBuffers.SRVs);
|
context.PixelShader.SetShaderResources(2, GBuffers.SRVs);
|
||||||
|
|
||||||
//if (globalShadows != null)
|
|
||||||
//{
|
|
||||||
// globalShadows.SetFinalRenderResources(context);
|
|
||||||
//}
|
|
||||||
|
|
||||||
|
|
||||||
foreach (var rll in lodlights)
|
foreach (var rll in lodlights)
|
||||||
{
|
{
|
||||||
@ -427,10 +454,6 @@ namespace CodeWalker.Rendering
|
|||||||
context.PixelShader.Set(null);
|
context.PixelShader.Set(null);
|
||||||
context.PixelShader.SetShaderResources(0, null, null, null);
|
context.PixelShader.SetShaderResources(0, null, null, null);
|
||||||
context.PixelShader.SetSamplers(0, null, null);
|
context.PixelShader.SetSamplers(0, null, null);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -293,13 +293,13 @@ namespace CodeWalker.Rendering
|
|||||||
|
|
||||||
TextureMS = DXUtility.CreateTexture2D(device, w, h, 1, 1, f, sc, sq, u, b, 0, 0);
|
TextureMS = DXUtility.CreateTexture2D(device, w, h, 1, 1, f, sc, sq, u, b, 0, 0);
|
||||||
MSRTV = DXUtility.CreateRenderTargetView(device, TextureMS, f, rtvd, 0, 0, 0);
|
MSRTV = DXUtility.CreateRenderTargetView(device, TextureMS, f, rtvd, 0, 0, 0);
|
||||||
VramUsage += (wh * fs);
|
VramUsage += (wh * fs) * sc;
|
||||||
|
|
||||||
if (depth)
|
if (depth)
|
||||||
{
|
{
|
||||||
DepthMS = DXUtility.CreateTexture2D(device, w, h, 1, 1, df, sc, sq, u, db, 0, 0);
|
DepthMS = DXUtility.CreateTexture2D(device, w, h, 1, 1, df, sc, sq, u, db, 0, 0);
|
||||||
MSDSV = DXUtility.CreateDepthStencilView(device, DepthMS, df, dsvd);
|
MSDSV = DXUtility.CreateDepthStencilView(device, DepthMS, df, dsvd);
|
||||||
VramUsage += (wh * DXUtility.ElementSize(df));
|
VramUsage += (wh * DXUtility.ElementSize(df)) * sc;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -432,31 +432,42 @@ namespace CodeWalker.Rendering
|
|||||||
public int VramUsage;
|
public int VramUsage;
|
||||||
public bool UseDepth;
|
public bool UseDepth;
|
||||||
public int Count;
|
public int Count;
|
||||||
|
public bool Multisampled;
|
||||||
|
public int MultisampleCount;
|
||||||
|
|
||||||
public void Init(Device device, int w, int h, int count, Format f, bool depth, Format df)
|
public void Init(Device device, int w, int h, int count, Format f, bool depth, Format df, int multisamplecount)
|
||||||
{
|
{
|
||||||
Count = count;
|
Count = count;
|
||||||
VramUsage = 0;
|
VramUsage = 0;
|
||||||
UseDepth = depth;
|
UseDepth = depth;
|
||||||
|
MultisampleCount = multisamplecount;
|
||||||
|
Multisampled = (multisamplecount > 1);
|
||||||
ResourceUsage u = ResourceUsage.Default;
|
ResourceUsage u = ResourceUsage.Default;
|
||||||
BindFlags b = BindFlags.RenderTarget | BindFlags.ShaderResource;
|
BindFlags b = BindFlags.RenderTarget | BindFlags.ShaderResource;
|
||||||
RenderTargetViewDimension rtvd = RenderTargetViewDimension.Texture2D;
|
|
||||||
ShaderResourceViewDimension srvd = ShaderResourceViewDimension.Texture2D;// D3D11_SRV_DIMENSION_TEXTURE2D;
|
|
||||||
int fs = DXUtility.ElementSize(f);
|
int fs = DXUtility.ElementSize(f);
|
||||||
int wh = w * h;
|
int wh = w * h;
|
||||||
BindFlags db = BindFlags.DepthStencil | BindFlags.ShaderResource;// D3D11_BIND_DEPTH_STENCIL;
|
BindFlags db = BindFlags.DepthStencil | BindFlags.ShaderResource;// D3D11_BIND_DEPTH_STENCIL;
|
||||||
|
RenderTargetViewDimension rtvd = RenderTargetViewDimension.Texture2D;
|
||||||
|
ShaderResourceViewDimension srvd = ShaderResourceViewDimension.Texture2D;// D3D11_SRV_DIMENSION_TEXTURE2D;
|
||||||
DepthStencilViewDimension dsvd = DepthStencilViewDimension.Texture2D;
|
DepthStencilViewDimension dsvd = DepthStencilViewDimension.Texture2D;
|
||||||
|
|
||||||
|
if (Multisampled)
|
||||||
|
{
|
||||||
|
rtvd = RenderTargetViewDimension.Texture2DMultisampled;
|
||||||
|
srvd = ShaderResourceViewDimension.Texture2DMultisampled;
|
||||||
|
dsvd = DepthStencilViewDimension.Texture2DMultisampled;
|
||||||
|
}
|
||||||
|
|
||||||
Textures = new Texture2D[count];
|
Textures = new Texture2D[count];
|
||||||
RTVs = new RenderTargetView[count];
|
RTVs = new RenderTargetView[count];
|
||||||
SRVs = new ShaderResourceView[count];
|
SRVs = new ShaderResourceView[count];
|
||||||
|
|
||||||
for (int i = 0; i < count; i++)
|
for (int i = 0; i < count; i++)
|
||||||
{
|
{
|
||||||
Textures[i] = DXUtility.CreateTexture2D(device, w, h, 1, 1, f, 1, 0, u, b, 0, 0);
|
Textures[i] = DXUtility.CreateTexture2D(device, w, h, 1, 1, f, multisamplecount, 0, u, b, 0, 0);
|
||||||
RTVs[i] = DXUtility.CreateRenderTargetView(device, Textures[i], f, rtvd, 0, 0, 0);
|
RTVs[i] = DXUtility.CreateRenderTargetView(device, Textures[i], f, rtvd, 0, 0, 0);
|
||||||
SRVs[i] = DXUtility.CreateShaderResourceView(device, Textures[i], f, srvd, 1, 0, 0, 0);
|
SRVs[i] = DXUtility.CreateShaderResourceView(device, Textures[i], f, srvd, 1, 0, 0, 0);
|
||||||
VramUsage += (wh * fs);
|
VramUsage += (wh * fs) * multisamplecount;
|
||||||
}
|
}
|
||||||
if (depth)
|
if (depth)
|
||||||
{
|
{
|
||||||
@ -482,10 +493,10 @@ namespace CodeWalker.Rendering
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
Depth = DXUtility.CreateTexture2D(device, w, h, 1, 1, dtexf, 1, 0, u, db, 0, 0);
|
Depth = DXUtility.CreateTexture2D(device, w, h, 1, 1, dtexf, multisamplecount, 0, u, db, 0, 0);
|
||||||
DSV = DXUtility.CreateDepthStencilView(device, Depth, df, dsvd);
|
DSV = DXUtility.CreateDepthStencilView(device, Depth, df, dsvd);
|
||||||
DepthSRV = DXUtility.CreateShaderResourceView(device, Depth, dsrvf, srvd, 1, 0, 0, 0);
|
DepthSRV = DXUtility.CreateShaderResourceView(device, Depth, dsrvf, srvd, 1, 0, 0, 0);
|
||||||
VramUsage += (wh * DXUtility.ElementSize(df));
|
VramUsage += (wh * DXUtility.ElementSize(df)) * multisamplecount;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
public void Dispose()
|
public void Dispose()
|
||||||
@ -516,13 +527,13 @@ namespace CodeWalker.Rendering
|
|||||||
Depth = null;
|
Depth = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
public GpuMultiTexture(Device device, int w, int h, int count, Format f, bool depth, Format df)
|
public GpuMultiTexture(Device device, int w, int h, int count, Format f, bool depth, Format df, int msc = 1)
|
||||||
{
|
{
|
||||||
Init(device, w, h, count, f, depth, df);
|
Init(device, w, h, count, f, depth, df, msc);
|
||||||
}
|
}
|
||||||
public GpuMultiTexture(Device device, int w, int h, int count, Format f)
|
public GpuMultiTexture(Device device, int w, int h, int count, Format f, int msc = 1)
|
||||||
{
|
{
|
||||||
Init(device, w, h, count, f, false, Format.Unknown);
|
Init(device, w, h, count, f, false, Format.Unknown, msc);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Clear(DeviceContext context, Color4 colour)
|
public void Clear(DeviceContext context, Color4 colour)
|
||||||
|
Binary file not shown.
BIN
Shaders/DirLightPS_MS.cso
Normal file
BIN
Shaders/DirLightPS_MS.cso
Normal file
Binary file not shown.
Binary file not shown.
Binary file not shown.
BIN
Shaders/LodLightsPS_MS.cso
Normal file
BIN
Shaders/LodLightsPS_MS.cso
Normal file
Binary file not shown.
Loading…
Reference in New Issue
Block a user