diff --git a/data/gala.metainfo.xml.in b/data/gala.metainfo.xml.in
index 0983fbf75..0b8c1876c 100644
--- a/data/gala.metainfo.xml.in
+++ b/data/gala.metainfo.xml.in
@@ -33,6 +33,7 @@
+ Scheduled switch to dark style does not dim the wallpaper after cold reboot on elementary OS 7.1
Alt + Shift unnecessarily blocked when there is only one keyboard layout
diff --git a/src/Background/Background.vala b/src/Background/Background.vala
index 5c6e5cb7d..c58d131bd 100644
--- a/src/Background/Background.vala
+++ b/src/Background/Background.vala
@@ -74,7 +74,7 @@ namespace Gala {
var cache = BackgroundCache.get_default ();
foreach (var watch in file_watches.values) {
- SignalHandler.disconnect (cache, watch);
+ cache.disconnect (watch);
}
background_source.changed.disconnect (settings_changed);
@@ -179,7 +179,7 @@ namespace Gala {
} else {
ulong handler = 0;
handler = image.loaded.connect (() => {
- SignalHandler.disconnect (image, handler);
+ image.disconnect (handler);
if (--num_pending_images == 0) {
finish_animation (files);
}
@@ -237,7 +237,7 @@ namespace Gala {
ulong handler = 0;
handler = image.loaded.connect (() => {
set_loaded ();
- SignalHandler.disconnect (image, handler);
+ image.disconnect (handler);
});
}
}
diff --git a/src/Background/BackgroundManager.vala b/src/Background/BackgroundManager.vala
index 88300f268..d2c1edb46 100644
--- a/src/Background/BackgroundManager.vala
+++ b/src/Background/BackgroundManager.vala
@@ -17,8 +17,6 @@
namespace Gala {
public class BackgroundManager : Meta.BackgroundGroup {
- private const string GALA_BACKGROUND_SCHEMA = "io.elementary.desktop.background";
- private const string DIM_WALLPAPER_KEY = "dim-wallpaper-in-dark-style";
private const double DIM_OPACITY = 0.55;
private const int FADE_ANIMATION_TIME = 1000;
@@ -32,18 +30,10 @@ namespace Gala {
private Meta.BackgroundActor background_actor;
private Meta.BackgroundActor? new_background_actor = null;
- private Clutter.PropertyTransition? last_dim_transition = null;
-
- private static Settings gala_background_settings;
-
public BackgroundManager (Meta.Display display, int monitor_index, bool control_position = true) {
Object (display: display, monitor_index: monitor_index, control_position: control_position);
}
- static construct {
- gala_background_settings = new Settings (GALA_BACKGROUND_SCHEMA);
- }
-
construct {
background_source = BackgroundCache.get_default ().get_background_source (display);
background_actor = create_background_actor ();
@@ -120,7 +110,7 @@ namespace Gala {
ulong handler = 0;
handler = background.loaded.connect (() => {
- SignalHandler.disconnect (background, handler);
+ background.disconnect (handler);
background.set_data ("background-loaded-handler", 0);
swap_background_actor (animate);
@@ -138,17 +128,18 @@ namespace Gala {
var background = background_source.get_background (monitor_index);
var background_actor = new Meta.BackgroundActor (display, monitor_index);
- ((Meta.BackgroundContent)background_actor.content).background = background.background;
- ((Meta.BackgroundContent)background_actor.content).vignette = true;
+ unowned var content = (Meta.BackgroundContent) background_actor.content;
+ content.background = background.background;
- // Don't play dim animation when launching gala or switching wallpaper
- if (should_dim ()) {
- ((Meta.BackgroundContent)background_actor.content).brightness = DIM_OPACITY;
+ if (background_source.should_dim) {
+ // It doesn't work without Idle :(
+ Idle.add (() => {
+ content.vignette = true;
+ content.brightness = DIM_OPACITY;
+ return Source.REMOVE;
+ });
}
- Granite.Settings.get_default ().notify["prefers-color-scheme"].connect (update_dim_wallpaper);
- gala_background_settings.changed[DIM_WALLPAPER_KEY].connect (update_dim_wallpaper);
-
insert_child_below (background_actor, null);
var monitor = display.get_monitor_geometry (monitor_index);
@@ -160,78 +151,25 @@ namespace Gala {
ulong changed_handler = 0;
changed_handler = background.changed.connect (() => {
- SignalHandler.disconnect (background, changed_handler);
+ background.disconnect (changed_handler);
changed_handler = 0;
update_background_actor ();
});
background_actor.destroy.connect (() => {
if (changed_handler != 0) {
- SignalHandler.disconnect (background, changed_handler);
+ background.disconnect (changed_handler);
changed_handler = 0;
}
var loaded_handler = background.get_data ("background-loaded-handler");
if (loaded_handler != 0) {
- SignalHandler.disconnect (background, loaded_handler);
+ background.disconnect (loaded_handler);
background.set_data ("background-loaded-handler", 0);
}
});
return background_actor;
}
-
- private bool should_dim () {
- return (
- Granite.Settings.get_default ().prefers_color_scheme == Granite.Settings.ColorScheme.DARK &&
- gala_background_settings.get_boolean (DIM_WALLPAPER_KEY)
- );
- }
-
- // OpacityDimActor is used for transitioning background actor's vignette brightness
- // In mutter 3.38+ vignette's properties are contained in Meta.BackgroundContent
- // which doesn't support transitions
- // so we bind OpacityDimActor.opacity to ((Meta.BackgroundContent) background_actor.content).brightness
- // and then create transition for OpacityDimActor.opacity
-
- private class OpacityDimActor : Clutter.Actor {
- public new double opacity { get; set; }
- }
-
- private void update_dim_wallpaper () {
- if (last_dim_transition != null) {
- last_dim_transition.stop ();
- }
-
- var dim_actor = new OpacityDimActor ();
- background_actor.add_child (dim_actor);
- var binding = dim_actor.bind_property (
- "opacity",
- (Meta.BackgroundContent) background_actor.content,
- "brightness",
- BindingFlags.DEFAULT
- );
-
- var transition = new Clutter.PropertyTransition ("opacity");
- transition.set_from_value (
- ((Meta.BackgroundContent) background_actor.content).brightness
- );
- transition.set_to_value (should_dim () ? DIM_OPACITY : 1.0);
- transition.duration = FADE_ANIMATION_TIME;
- transition.progress_mode = Clutter.AnimationMode.EASE_OUT_QUAD;
- transition.remove_on_complete = true;
- transition.completed.connect (() => {
- binding.unbind ();
-
- background_actor.remove_child (dim_actor);
- dim_actor.destroy ();
-
- changed ();
- });
-
- dim_actor.add_transition ("wallpaper-dim", transition);
-
- last_dim_transition = transition;
- }
}
}
diff --git a/src/Background/BackgroundSource.vala b/src/Background/BackgroundSource.vala
index 9c51ceee0..a8fa747fa 100644
--- a/src/Background/BackgroundSource.vala
+++ b/src/Background/BackgroundSource.vala
@@ -20,7 +20,6 @@ namespace Gala {
// list of keys that are actually relevant for us
private const string[] OPTIONS = {
"color-shading-type",
- "picture-opacity",
"picture-options",
"picture-uri",
"picture-uri-dark",
@@ -31,13 +30,23 @@ namespace Gala {
public signal void changed ();
public Meta.Display display { get; construct; }
- public GLib.Settings gnome_background_settings { get; construct; }
+ public GLib.Settings gnome_background_settings { get; private set; }
internal int use_count { get; set; default = 0; }
private GLib.HashTable backgrounds;
private uint[] hash_cache;
private Meta.MonitorManager? monitor_manager;
+ private GLib.Settings gala_background_settings;
+
+ public bool should_dim {
+ get {
+ return (
+ Granite.Settings.get_default ().prefers_color_scheme == DARK &&
+ gala_background_settings.get_boolean ("dim-wallpaper-in-dark-style")
+ );
+ }
+ }
public BackgroundSource (Meta.Display display) {
Object (display: display);
@@ -50,7 +59,12 @@ namespace Gala {
monitor_manager = display.get_context ().get_backend ().get_monitor_manager ();
monitor_manager.monitors_changed.connect (monitors_changed);
- gnome_background_settings = new Settings ("org.gnome.desktop.background");
+ gala_background_settings = new GLib.Settings ("io.elementary.desktop.background");
+ gala_background_settings.changed["dim-wallpaper-in-dark-style"].connect (() => changed ());
+
+ Granite.Settings.get_default ().notify["prefers-color-scheme"].connect (() => changed ());
+
+ gnome_background_settings = new GLib.Settings ("org.gnome.desktop.background");
// unfortunately the settings sometimes tend to fire random changes even though
// nothing actually happened. The code below is used to prevent us from spamming
@@ -71,9 +85,6 @@ namespace Gala {
}
}
});
-
- unowned var granite_settings = Granite.Settings.get_default ();
- granite_settings.notify["prefers-color-scheme"].connect (() => changed ());
}
private void monitors_changed () {
diff --git a/src/WindowManager.vala b/src/WindowManager.vala
index ef238956e..35a0101ea 100644
--- a/src/WindowManager.vala
+++ b/src/WindowManager.vala
@@ -1156,7 +1156,9 @@ namespace Gala {
which_change = which_change_local;
old_rect_size_change = old_frame_rect;
- latest_window_snapshot = Utils.get_window_actor_snapshot (actor, old_frame_rect);
+ if (enable_animations) {
+ latest_window_snapshot = Utils.get_window_actor_snapshot (actor, old_frame_rect);
+ }
}
// size_changed gets called after frame_rect has updated