imgui_impl_dx11.h 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. // dear imgui: Renderer Backend for DirectX11
  2. // This needs to be used along with a Platform Backend (e.g. Win32)
  3. // Implemented features:
  4. // [X] Renderer: User texture binding. Use 'ID3D11ShaderResourceView*' as texture identifier. Read the FAQ about ImTextureID/ImTextureRef!
  5. // [X] Renderer: Large meshes support (64k+ vertices) even with 16-bit indices (ImGuiBackendFlags_RendererHasVtxOffset).
  6. // [X] Renderer: Texture updates support for dynamic font atlas (ImGuiBackendFlags_RendererHasTextures).
  7. // [X] Renderer: Expose selected render state for draw callbacks to use. Access in '(ImGui_ImplXXXX_RenderState*)GetPlatformIO().Renderer_RenderState'.
  8. // You can use unmodified imgui_impl_* files in your project. See examples/ folder for examples of using this.
  9. // Prefer including the entire imgui/ repository into your project (either as a copy or as a submodule), and only build the backends you need.
  10. // Learn about Dear ImGui:
  11. // - FAQ https://dearimgui.com/faq
  12. // - Getting Started https://dearimgui.com/getting-started
  13. // - Documentation https://dearimgui.com/docs (same as your local docs/ folder).
  14. // - Introduction, links and more at the top of imgui.cpp
  15. #pragma once
  16. #include "imgui.h" // IMGUI_IMPL_API
  17. #ifndef IMGUI_DISABLE
  18. struct ID3D11Device;
  19. struct ID3D11DeviceContext;
  20. struct ID3D11SamplerState;
  21. struct ID3D11Buffer;
  22. // Follow "Getting Started" link and check examples/ folder to learn about using backends!
  23. IMGUI_IMPL_API bool ImGui_ImplDX11_Init(ID3D11Device* device, ID3D11DeviceContext* device_context);
  24. IMGUI_IMPL_API void ImGui_ImplDX11_Shutdown();
  25. IMGUI_IMPL_API void ImGui_ImplDX11_NewFrame();
  26. IMGUI_IMPL_API void ImGui_ImplDX11_RenderDrawData(ImDrawData* draw_data);
  27. // Use if you want to reset your rendering device without losing Dear ImGui state.
  28. IMGUI_IMPL_API bool ImGui_ImplDX11_CreateDeviceObjects();
  29. IMGUI_IMPL_API void ImGui_ImplDX11_InvalidateDeviceObjects();
  30. // (Advanced) Use e.g. if you need to precisely control the timing of texture updates (e.g. for staged rendering), by setting ImDrawData::Textures = NULL to handle this manually.
  31. IMGUI_IMPL_API void ImGui_ImplDX11_UpdateTexture(ImTextureData* tex);
  32. // [BETA] Selected render state data shared with callbacks.
  33. // This is temporarily stored in GetPlatformIO().Renderer_RenderState during the ImGui_ImplDX11_RenderDrawData() call.
  34. // (Please open an issue if you feel you need access to more data)
  35. struct ImGui_ImplDX11_RenderState
  36. {
  37. ID3D11Device* Device;
  38. ID3D11DeviceContext* DeviceContext;
  39. ID3D11SamplerState* SamplerDefault;
  40. ID3D11Buffer* VertexConstantBuffer;
  41. };
  42. #endif // #ifndef IMGUI_DISABLE