XFBEncoder: Sample the first layer of the resolved EFB texture.
Using the multisampled EFB texture is invalid, as the XFB encoder does not have a multisampling shader.
This commit is contained in:
parent
af8ac328e5
commit
833513f384
|
@ -78,7 +78,7 @@ static const char XFB_ENCODE_PS[] =
|
||||||
"} Params;\n"
|
"} Params;\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
|
|
||||||
"Texture2D EFBTexture : register(t0);\n"
|
"Texture2DArray EFBTexture : register(t0);\n"
|
||||||
"sampler EFBSampler : register(s0);\n"
|
"sampler EFBSampler : register(s0);\n"
|
||||||
|
|
||||||
// GameCube/Wii uses the BT.601 standard algorithm for converting to YCbCr; see
|
// GameCube/Wii uses the BT.601 standard algorithm for converting to YCbCr; see
|
||||||
|
@ -92,7 +92,7 @@ static const char XFB_ENCODE_PS[] =
|
||||||
"float3 SampleEFB(float2 coord)\n"
|
"float3 SampleEFB(float2 coord)\n"
|
||||||
"{\n"
|
"{\n"
|
||||||
"float2 texCoord = lerp(float2(Params.TexLeft,Params.TexTop), float2(Params.TexRight,Params.TexBottom), coord / float2(Params.Width,Params.Height));\n"
|
"float2 texCoord = lerp(float2(Params.TexLeft,Params.TexTop), float2(Params.TexRight,Params.TexBottom), coord / float2(Params.Width,Params.Height));\n"
|
||||||
"return EFBTexture.Sample(EFBSampler, texCoord).rgb;\n"
|
"return EFBTexture.Sample(EFBSampler, float3(texCoord, 0)).rgb;\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
|
|
||||||
"void main(out float4 ocol0 : SV_Target, in float4 Pos : SV_Position, in float2 Coord : ENCODECOORD)\n"
|
"void main(out float4 ocol0 : SV_Target, in float4 Pos : SV_Position, in float2 Coord : ENCODECOORD)\n"
|
||||||
|
@ -311,7 +311,7 @@ void XFBEncoder::Encode(u8* dst, u32 width, u32 height, const EFBRectangle& srcR
|
||||||
|
|
||||||
D3D::context->OMSetRenderTargets(1, &m_outRTV, nullptr);
|
D3D::context->OMSetRenderTargets(1, &m_outRTV, nullptr);
|
||||||
|
|
||||||
ID3D11ShaderResourceView* pEFB = FramebufferManager::GetEFBColorTexture()->GetSRV();
|
ID3D11ShaderResourceView* pEFB = FramebufferManager::GetResolvedEFBColorTexture()->GetSRV();
|
||||||
|
|
||||||
D3D::stateman->SetVertexConstants(m_encodeParams);
|
D3D::stateman->SetVertexConstants(m_encodeParams);
|
||||||
D3D::stateman->SetPixelConstants(m_encodeParams);
|
D3D::stateman->SetPixelConstants(m_encodeParams);
|
||||||
|
|
Loading…
Reference in New Issue