From 76e3be66872949a80c2b207d9e3dca8fa4542961 Mon Sep 17 00:00:00 2001 From: wootguy Date: Thu, 25 Apr 2024 01:46:08 -0700 Subject: [PATCH] fixes - fix texture color count not copied during downscale - fix map name not updated after doing Save As --- src/bsp/Bsp.cpp | 7 ++++--- src/editor/Gui.cpp | 1 + 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/src/bsp/Bsp.cpp b/src/bsp/Bsp.cpp index 5a62b0a2..7eb6adfe 100644 --- a/src/bsp/Bsp.cpp +++ b/src/bsp/Bsp.cpp @@ -2721,7 +2721,7 @@ bool Bsp::downscale_texture(int textureId, int newWidth, int newHeight) { int lastMipSize = (oldWidth >> 3) * (oldHeight >> 3); byte* pixels = (byte*)(textures + texOffset + tex.nOffsets[0]); - byte* palette = (byte*)(textures + texOffset + tex.nOffsets[3] + lastMipSize + 2); + byte* palette = (byte*)(textures + texOffset + tex.nOffsets[3] + lastMipSize); int oldWidths[4]; int oldHeights[4]; @@ -2741,7 +2741,7 @@ bool Bsp::downscale_texture(int textureId, int newWidth, int newHeight) { newOffset[i] = sizeof(BSPMIPTEX); } } - byte* newPalette = (byte*)(textures + texOffset + newOffset[3] + newWidths[3] * newHeights[3] + 2); + byte* newPalette = (byte*)(textures + texOffset + newOffset[3] + newWidths[3] * newHeights[3]); float srcScale = (float)oldWidth / tex.nWidth; @@ -2761,7 +2761,8 @@ bool Bsp::downscale_texture(int textureId, int newWidth, int newHeight) { } } } - memcpy(newPalette, palette, 256 * sizeof(COLOR3)); + // 2 = palette color count (should always be 256) + memcpy(newPalette, palette, 256 * sizeof(COLOR3) + 2); for (int i = 0; i < 4; i++) { tex.nOffsets[i] = newOffset[i]; diff --git a/src/editor/Gui.cpp b/src/editor/Gui.cpp index b9a607cb..6630b743 100644 --- a/src/editor/Gui.cpp +++ b/src/editor/Gui.cpp @@ -702,6 +702,7 @@ void Gui::drawMenuBar() { if (fname) { map->update_ent_lump(); map->path = fname; + map->name = stripExt(basename(fname)); map->write(map->path); } }