diff options
-rw-r--r-- | src/gfx_func.h | 1 | ||||
-rw-r--r-- | src/gfxinit.cpp | 36 | ||||
-rw-r--r-- | src/toolbar_gui.cpp | 2 |
3 files changed, 31 insertions, 8 deletions
diff --git a/src/gfx_func.h b/src/gfx_func.h index 69d2e4570..38c9ea5e3 100644 --- a/src/gfx_func.h +++ b/src/gfx_func.h @@ -137,6 +137,7 @@ void SetDirtyBlocks(int left, int top, int right, int bottom); void MarkWholeScreenDirty(); void GfxInitPalettes(); +void CheckBlitter(); bool FillDrawPixelInfo(DrawPixelInfo *n, int left, int top, int width, int height); diff --git a/src/gfxinit.cpp b/src/gfxinit.cpp index 4a830d7a8..109db2e08 100644 --- a/src/gfxinit.cpp +++ b/src/gfxinit.cpp @@ -15,6 +15,7 @@ #include "3rdparty/md5/md5.h" #include "fontcache.h" #include "gfx_func.h" +#include "transparency.h" #include "blitter/factory.hpp" #include "video/video_driver.hpp" @@ -225,14 +226,15 @@ static void LoadSpriteTables() /** * Check blitter needed by NewGRF config and switch if needed. + * @return False when nothing changed, true otherwise. */ -static void SwitchNewGRFBlitter() +static bool SwitchNewGRFBlitter() { /* Never switch if the blitter was specified by the user. */ - if (!_blitter_autodetected) return; + if (!_blitter_autodetected) return false; /* Null driver => dedicated server => do nothing. */ - if (BlitterFactory::GetCurrentBlitter()->GetScreenDepth() == 0) return; + if (BlitterFactory::GetCurrentBlitter()->GetScreenDepth() == 0) return false; /* Get preferred depth. */ uint depth_wanted_by_base = BaseGraphics::GetUsedSet()->blitter == BLT_32BPP ? 32 : 8; @@ -245,23 +247,32 @@ static void SwitchNewGRFBlitter() /* Search the best blitter. */ struct { const char *name; + uint animation; ///< 0: no support, 1: do support, 2: both uint min_base_depth, max_base_depth, min_grf_depth, max_grf_depth; } replacement_blitters[] = { #ifdef WITH_SSE - { "32bpp-sse4-anim", 32, 32, 8, 32 }, + { "32bpp-sse4", 0, 32, 32, 8, 32 }, + { "32bpp-ssse3", 0, 32, 32, 8, 32 }, + { "32bpp-sse2", 0, 32, 32, 8, 32 }, + { "32bpp-sse4-anim", 1, 32, 32, 8, 32 }, #endif - { "8bpp-optimized", 8, 8, 8, 8 }, - { "32bpp-anim", 8, 32, 8, 32 }, + { "8bpp-optimized", 2, 8, 8, 8, 8 }, + { "32bpp-optimized", 0, 8, 32, 8, 32 }, + { "32bpp-anim", 1, 8, 32, 8, 32 }, }; + const bool animation_wanted = HasBit(_display_opt, DO_FULL_ANIMATION); const char *cur_blitter = BlitterFactory::GetCurrentBlitter()->GetName(); for (uint i = 0; i < lengthof(replacement_blitters); i++) { + if (animation_wanted && (replacement_blitters[i].animation == 0)) continue; + if (!animation_wanted && (replacement_blitters[i].animation == 1)) continue; + if (!IsInsideMM(depth_wanted_by_base, replacement_blitters[i].min_base_depth, replacement_blitters[i].max_base_depth + 1)) continue; if (!IsInsideMM(depth_wanted_by_grf, replacement_blitters[i].min_grf_depth, replacement_blitters[i].max_grf_depth + 1)) continue; const char *repl_blitter = replacement_blitters[i].name; - if (strcmp(repl_blitter, cur_blitter) == 0) return; + if (strcmp(repl_blitter, cur_blitter) == 0) return false; if (BlitterFactory::GetBlitterFactory(repl_blitter) == NULL) continue; DEBUG(misc, 1, "Switching blitter from '%s' to '%s'... ", cur_blitter, repl_blitter); @@ -275,6 +286,17 @@ static void SwitchNewGRFBlitter() /* Failed to switch blitter, let's hope we can return to the old one. */ if (BlitterFactory::SelectBlitter(cur_blitter) == NULL || !_video_driver->AfterBlitterChange()) usererror("Failed to reinitialize video driver. Specify a fixed blitter in the config"); } + + return true; +} + +/** Check whether we still use the right blitter, or use another (better) one. */ +void CheckBlitter() +{ + if (!SwitchNewGRFBlitter()) return; + + ClearFontCache(); + GfxClearSpriteCache(); } /** Initialise and load all the sprites. */ diff --git a/src/toolbar_gui.cpp b/src/toolbar_gui.cpp index f4cb584b1..c14045600 100644 --- a/src/toolbar_gui.cpp +++ b/src/toolbar_gui.cpp @@ -351,7 +351,7 @@ static CallBackFunction MenuClickSettings(int index) ToggleBit(_display_opt, DO_SHOW_COMPETITOR_SIGNS); InvalidateWindowClassesData(WC_SIGN_LIST, -1); break; - case OME_FULL_ANIMATION: ToggleBit(_display_opt, DO_FULL_ANIMATION); break; + case OME_FULL_ANIMATION: ToggleBit(_display_opt, DO_FULL_ANIMATION); CheckBlitter(); break; case OME_FULL_DETAILS: ToggleBit(_display_opt, DO_FULL_DETAIL); break; case OME_TRANSPARENTBUILDINGS: ToggleTransparency(TO_HOUSES); break; case OME_SHOW_STATIONSIGNS: ToggleTransparency(TO_SIGNS); break; |