From 662535f3576c69c4bfd8ddaf6adc517f27ecfc25 Mon Sep 17 00:00:00 2001 From: ocornut Date: Wed, 3 Mar 2021 18:34:07 +0100 Subject: [PATCH] Backends: DX9: Fix handling of colored textures (#3844, #3868) --- backends/imgui_impl_dx9.cpp | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) diff --git a/backends/imgui_impl_dx9.cpp b/backends/imgui_impl_dx9.cpp index 3fe0fe3e09a9..b8044d9afe00 100644 --- a/backends/imgui_impl_dx9.cpp +++ b/backends/imgui_impl_dx9.cpp @@ -250,11 +250,15 @@ static bool ImGui_ImplDX9_CreateFontsTexture() int width, height, bytes_per_pixel; io.Fonts->GetTexDataAsRGBA32(&pixels, &width, &height, &bytes_per_pixel); - // Convert RGBA32 to BGRA32 as the earlier is not well supported by DX9 devices + // Convert RGBA32 to BGRA32 (because RGBA32 is not well supported by DX9 devices) #ifndef IMGUI_USE_BGRA_PACKED_COLOR if (io.Fonts->TexPixelsUseColors) - for (ImU32* p = (ImU32*)pixels, *p_end = p + width * height; p < p_end; p++) - *p = IMGUI_COL_TO_DX9_ARGB(*p); + { + ImU32* dst_start = (ImU32*)ImGui::MemAlloc(width * height * bytes_per_pixel); + for (ImU32* src = (ImU32*)pixels, *dst = dst_start, *dst_end = dst_start + width * height; dst < dst_end; src++, dst++) + *dst = IMGUI_COL_TO_DX9_ARGB(*src); + pixels = (unsigned char*)dst_start; + } #endif // Upload texture to graphics system @@ -271,6 +275,11 @@ static bool ImGui_ImplDX9_CreateFontsTexture() // Store our identifier io.Fonts->SetTexID((ImTextureID)g_FontTexture); +#ifndef IMGUI_USE_BGRA_PACKED_COLOR + if (io.Fonts->TexPixelsUseColors) + ImGui::MemFree(pixels); +#endif + return true; }