|
@@ -42,11 +42,9 @@ static ID3D11DeviceContext* g_pd3dDeviceContext = NULL;
|
|
|
static IDXGIFactory* g_pFactory = NULL;
|
|
|
static ID3D11Buffer* g_pVB = NULL;
|
|
|
static ID3D11Buffer* g_pIB = NULL;
|
|
|
-static ID3D10Blob* g_pVertexShaderBlob = NULL;
|
|
|
static ID3D11VertexShader* g_pVertexShader = NULL;
|
|
|
static ID3D11InputLayout* g_pInputLayout = NULL;
|
|
|
static ID3D11Buffer* g_pVertexConstantBuffer = NULL;
|
|
|
-static ID3D10Blob* g_pPixelShaderBlob = NULL;
|
|
|
static ID3D11PixelShader* g_pPixelShader = NULL;
|
|
|
static ID3D11SamplerState* g_pFontSampler = NULL;
|
|
|
static ID3D11ShaderResourceView*g_pFontTextureView = NULL;
|
|
@@ -381,11 +379,14 @@ bool ImGui_ImplDX11_CreateDeviceObjects()
|
|
|
return output;\
|
|
|
}";
|
|
|
|
|
|
- D3DCompile(vertexShader, strlen(vertexShader), NULL, NULL, NULL, "main", "vs_4_0", 0, 0, &g_pVertexShaderBlob, NULL);
|
|
|
- if (g_pVertexShaderBlob == NULL) // NB: Pass ID3D10Blob* pErrorBlob to D3DCompile() to get error showing in (const char*)pErrorBlob->GetBufferPointer(). Make sure to Release() the blob!
|
|
|
- return false;
|
|
|
- if (g_pd3dDevice->CreateVertexShader((DWORD*)g_pVertexShaderBlob->GetBufferPointer(), g_pVertexShaderBlob->GetBufferSize(), NULL, &g_pVertexShader) != S_OK)
|
|
|
+ ID3DBlob* vertexShaderBlob;
|
|
|
+ if (FAILED(D3DCompile(vertexShader, strlen(vertexShader), NULL, NULL, NULL, "main", "vs_4_0", 0, 0, &vertexShaderBlob, NULL)))
|
|
|
+ return false; // NB: Pass ID3DBlob* pErrorBlob to D3DCompile() to get error showing in (const char*)pErrorBlob->GetBufferPointer(). Make sure to Release() the blob!
|
|
|
+ if (g_pd3dDevice->CreateVertexShader(vertexShaderBlob->GetBufferPointer(), vertexShaderBlob->GetBufferSize(), NULL, &g_pVertexShader) != S_OK)
|
|
|
+ {
|
|
|
+ vertexShaderBlob->Release();
|
|
|
return false;
|
|
|
+ }
|
|
|
|
|
|
// Create the input layout
|
|
|
D3D11_INPUT_ELEMENT_DESC local_layout[] =
|
|
@@ -394,8 +395,12 @@ bool ImGui_ImplDX11_CreateDeviceObjects()
|
|
|
{ "TEXCOORD", 0, DXGI_FORMAT_R32G32_FLOAT, 0, (size_t)(&((ImDrawVert*)0)->uv), D3D11_INPUT_PER_VERTEX_DATA, 0 },
|
|
|
{ "COLOR", 0, DXGI_FORMAT_R8G8B8A8_UNORM, 0, (size_t)(&((ImDrawVert*)0)->col), D3D11_INPUT_PER_VERTEX_DATA, 0 },
|
|
|
};
|
|
|
- if (g_pd3dDevice->CreateInputLayout(local_layout, 3, g_pVertexShaderBlob->GetBufferPointer(), g_pVertexShaderBlob->GetBufferSize(), &g_pInputLayout) != S_OK)
|
|
|
+ if (g_pd3dDevice->CreateInputLayout(local_layout, 3, vertexShaderBlob->GetBufferPointer(), vertexShaderBlob->GetBufferSize(), &g_pInputLayout) != S_OK)
|
|
|
+ {
|
|
|
+ vertexShaderBlob->Release();
|
|
|
return false;
|
|
|
+ }
|
|
|
+ vertexShaderBlob->Release();
|
|
|
|
|
|
// Create the constant buffer
|
|
|
{
|
|
@@ -427,11 +432,15 @@ bool ImGui_ImplDX11_CreateDeviceObjects()
|
|
|
return out_col; \
|
|
|
}";
|
|
|
|
|
|
- D3DCompile(pixelShader, strlen(pixelShader), NULL, NULL, NULL, "main", "ps_4_0", 0, 0, &g_pPixelShaderBlob, NULL);
|
|
|
- if (g_pPixelShaderBlob == NULL) // NB: Pass ID3D10Blob* pErrorBlob to D3DCompile() to get error showing in (const char*)pErrorBlob->GetBufferPointer(). Make sure to Release() the blob!
|
|
|
- return false;
|
|
|
- if (g_pd3dDevice->CreatePixelShader((DWORD*)g_pPixelShaderBlob->GetBufferPointer(), g_pPixelShaderBlob->GetBufferSize(), NULL, &g_pPixelShader) != S_OK)
|
|
|
+ ID3DBlob* pixelShaderBlob;
|
|
|
+ if (FAILED(D3DCompile(pixelShader, strlen(pixelShader), NULL, NULL, NULL, "main", "ps_4_0", 0, 0, &pixelShaderBlob, NULL)))
|
|
|
+ return false; // NB: Pass ID3DBlob* pErrorBlob to D3DCompile() to get error showing in (const char*)pErrorBlob->GetBufferPointer(). Make sure to Release() the blob!
|
|
|
+ if (g_pd3dDevice->CreatePixelShader(pixelShaderBlob->GetBufferPointer(), pixelShaderBlob->GetBufferSize(), NULL, &g_pPixelShader) != S_OK)
|
|
|
+ {
|
|
|
+ pixelShaderBlob->Release();
|
|
|
return false;
|
|
|
+ }
|
|
|
+ pixelShaderBlob->Release();
|
|
|
}
|
|
|
|
|
|
// Create the blending setup
|
|
@@ -494,11 +503,9 @@ void ImGui_ImplDX11_InvalidateDeviceObjects()
|
|
|
if (g_pDepthStencilState) { g_pDepthStencilState->Release(); g_pDepthStencilState = NULL; }
|
|
|
if (g_pRasterizerState) { g_pRasterizerState->Release(); g_pRasterizerState = NULL; }
|
|
|
if (g_pPixelShader) { g_pPixelShader->Release(); g_pPixelShader = NULL; }
|
|
|
- if (g_pPixelShaderBlob) { g_pPixelShaderBlob->Release(); g_pPixelShaderBlob = NULL; }
|
|
|
if (g_pVertexConstantBuffer) { g_pVertexConstantBuffer->Release(); g_pVertexConstantBuffer = NULL; }
|
|
|
if (g_pInputLayout) { g_pInputLayout->Release(); g_pInputLayout = NULL; }
|
|
|
if (g_pVertexShader) { g_pVertexShader->Release(); g_pVertexShader = NULL; }
|
|
|
- if (g_pVertexShaderBlob) { g_pVertexShaderBlob->Release(); g_pVertexShaderBlob = NULL; }
|
|
|
}
|
|
|
|
|
|
bool ImGui_ImplDX11_Init(ID3D11Device* device, ID3D11DeviceContext* device_context)
|