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:
NeoBrainX 2010-06-14 23:41:17 +00:00
parent 0ec6a91477
commit bd163db74f
2 changed files with 11 additions and 13 deletions

View File

@ -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
} }

View File

@ -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)
{ FBManager.Destroy();
SetupDeviceObjects(); FBManager.Create();
}
else
{
FBManager.Destroy();
FBManager.Create();
}
D3D::context->OMSetRenderTargets(1, &FBManager.GetEFBColorTexture()->GetRTV(), FBManager.GetEFBDepthTexture()->GetDSV()); D3D::context->OMSetRenderTargets(1, &FBManager.GetEFBColorTexture()->GetRTV(), FBManager.GetEFBDepthTexture()->GetDSV());
} }