DX11: Fix window resizing.
Still some aspect ratio problems though... git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@5703 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
parent
0ec6a91477
commit
bd163db74f
|
@ -403,6 +403,11 @@ unsigned int GetBackBufferHeight() { return yres; }
|
||||||
|
|
||||||
void Reset()
|
void Reset()
|
||||||
{
|
{
|
||||||
|
DXGI_SWAP_CHAIN_DESC desc;
|
||||||
|
D3D::swapchain->ResizeBuffers(1, 0, 0, DXGI_FORMAT_R8G8B8A8_UNORM, 0);
|
||||||
|
swapchain->GetDesc(&desc);
|
||||||
|
xres = desc.BufferDesc.Width;
|
||||||
|
yres = desc.BufferDesc.Height;
|
||||||
// TODO: Check whether we need to do anything here
|
// TODO: Check whether we need to do anything here
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -252,7 +252,7 @@ void SetupDeviceObjects()
|
||||||
D3D::SetDebugObjectName((ID3D11DeviceChild*)cleardepthstates[1], "depth state for Renderer::ClearScreen (depth buffer enabled)");
|
D3D::SetDebugObjectName((ID3D11DeviceChild*)cleardepthstates[1], "depth state for Renderer::ClearScreen (depth buffer enabled)");
|
||||||
|
|
||||||
// TODO: once multisampling gets implemented, this might need to be changed
|
// TODO: once multisampling gets implemented, this might need to be changed
|
||||||
D3D11_RASTERIZER_DESC rdesc= CD3D11_RASTERIZER_DESC(D3D11_FILL_SOLID, D3D11_CULL_NONE, false, 0, 0.f, 0.f, false, false, false, false);
|
D3D11_RASTERIZER_DESC rdesc = CD3D11_RASTERIZER_DESC(D3D11_FILL_SOLID, D3D11_CULL_NONE, false, 0, 0.f, 0.f, false, false, false, false);
|
||||||
D3D::device->CreateRasterizerState(&rdesc, &clearraststate);
|
D3D::device->CreateRasterizerState(&rdesc, &clearraststate);
|
||||||
D3D::SetDebugObjectName((ID3D11DeviceChild*)clearraststate, "rasterizer state for Renderer::ClearScreen");
|
D3D::SetDebugObjectName((ID3D11DeviceChild*)clearraststate, "rasterizer state for Renderer::ClearScreen");
|
||||||
|
|
||||||
|
@ -489,8 +489,6 @@ void CheckForResize()
|
||||||
client_height != s_backbuffer_height) &&
|
client_height != s_backbuffer_height) &&
|
||||||
client_width >= 4 && client_height >= 4)
|
client_width >= 4 && client_height >= 4)
|
||||||
{
|
{
|
||||||
TeardownDeviceObjects();
|
|
||||||
|
|
||||||
D3D::Reset();
|
D3D::Reset();
|
||||||
s_backbuffer_width = D3D::GetBackBufferWidth();
|
s_backbuffer_width = D3D::GetBackBufferWidth();
|
||||||
s_backbuffer_height = D3D::GetBackBufferHeight();
|
s_backbuffer_height = D3D::GetBackBufferHeight();
|
||||||
|
@ -936,15 +934,10 @@ void Renderer::Swap(u32 xfbAddr, FieldType field, u32 fbWidth, u32 fbHeight)
|
||||||
s_target_height = EFB_HEIGHT * yScale;
|
s_target_height = EFB_HEIGHT * yScale;
|
||||||
|
|
||||||
D3D::context->OMSetRenderTargets(1, &D3D::GetBackBuffer()->GetRTV(), NULL);
|
D3D::context->OMSetRenderTargets(1, &D3D::GetBackBuffer()->GetRTV(), NULL);
|
||||||
if (WindowResized)
|
|
||||||
{
|
|
||||||
SetupDeviceObjects();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
FBManager.Destroy();
|
FBManager.Destroy();
|
||||||
FBManager.Create();
|
FBManager.Create();
|
||||||
}
|
|
||||||
D3D::context->OMSetRenderTargets(1, &FBManager.GetEFBColorTexture()->GetRTV(), FBManager.GetEFBDepthTexture()->GetDSV());
|
D3D::context->OMSetRenderTargets(1, &FBManager.GetEFBColorTexture()->GetRTV(), FBManager.GetEFBDepthTexture()->GetDSV());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue