diff --git a/libs/canvas/canvas/wave_view.h b/libs/canvas/canvas/wave_view.h index c4e19ec7bb..e9df823a9c 100644 --- a/libs/canvas/canvas/wave_view.h +++ b/libs/canvas/canvas/wave_view.h @@ -126,6 +126,7 @@ class LIBCANVAS_API WaveViewCache uint64_t image_cache_threshold () const { return _image_cache_threshold; } void set_image_cache_threshold (uint64_t); + void clear_cache (); void add (boost::shared_ptr, boost::shared_ptr); void use (boost::shared_ptr, boost::shared_ptr); diff --git a/libs/canvas/wave_view.cc b/libs/canvas/wave_view.cc index e8db7d8c6a..a0b9e48fda 100644 --- a/libs/canvas/wave_view.cc +++ b/libs/canvas/wave_view.cc @@ -1351,6 +1351,9 @@ WaveView::set_global_shape (Shape s) { if (_global_shape != s) { _global_shape = s; + if (images) { + images->clear_cache (); + } VisualPropertiesChanged (); /* EMIT SIGNAL */ } } @@ -1360,6 +1363,9 @@ WaveView::set_global_logscaled (bool yn) { if (_global_logscaled != yn) { _global_logscaled = yn; + if (images) { + images->clear_cache (); + } VisualPropertiesChanged (); /* EMIT SIGNAL */ } } @@ -1827,10 +1833,20 @@ WaveViewCache::cache_flush () } } +void +WaveViewCache::clear_cache () +{ + DEBUG_TRACE (DEBUG::WaveView, "clear cache\n"); + const uint64_t image_cache_threshold = _image_cache_threshold; + _image_cache_threshold = 0; + cache_flush (); + _image_cache_threshold = image_cache_threshold; +} + void WaveViewCache::set_image_cache_threshold (uint64_t sz) { - DEBUG_TRACE (DEBUG::WaveView, string_compose ("new image cache size \n", sz)); + DEBUG_TRACE (DEBUG::WaveView, string_compose ("new image cache size %1\n", sz)); _image_cache_threshold = sz; cache_flush (); }