aboutsummaryrefslogtreecommitdiff
path: root/src/service.vala
diff options
context:
space:
mode:
authorTed Gould <ted@gould.cx>2014-12-03 16:30:23 -0600
committerTed Gould <ted@gould.cx>2014-12-03 16:30:23 -0600
commit66cd2203d5fcee99d3264bc6f23c8d4683c299bf (patch)
tree8aa68c757e9a748531b35710084831e0d362f508 /src/service.vala
parent119ae3decb89f0066dd5abf53d0ab1bef49c15c8 (diff)
downloadayatana-indicator-sound-66cd2203d5fcee99d3264bc6f23c8d4683c299bf.tar.gz
ayatana-indicator-sound-66cd2203d5fcee99d3264bc6f23c8d4683c299bf.tar.bz2
ayatana-indicator-sound-66cd2203d5fcee99d3264bc6f23c8d4683c299bf.zip
Switch from having custom signals for volume changing to using the property change signals.
Diffstat (limited to 'src/service.vala')
-rw-r--r--src/service.vala24
1 files changed, 11 insertions, 13 deletions
diff --git a/src/service.vala b/src/service.vala
index 1f9b880..c7e29e7 100644
--- a/src/service.vala
+++ b/src/service.vala
@@ -383,16 +383,6 @@ public class IndicatorSound.Service: Object {
return mute_action;
}
- void volume_changed (double volume) {
- var volume_action = this.actions.lookup_action ("volume") as SimpleAction;
-
- /* Normalize volume, because the volume action's state is [0.0, 1.0], see create_volume_action() */
- volume_action.set_state (new Variant.double (volume / this.max_volume));
-
- this.update_root_icon ();
- this.update_sync_notification ();
- }
-
Action create_volume_action () {
/* The action's state is between be in [0.0, 1.0] instead of [0.0,
* max_volume], so that we don't need to update the slider menu item
@@ -417,7 +407,15 @@ public class IndicatorSound.Service: Object {
volume_control.volume = v.clamp (0.0, this.max_volume);
});
- this.volume_control.volume_changed.connect (volume_changed);
+ this.volume_control.notify["volume"].connect (() => {
+ var vol_action = this.actions.lookup_action ("volume") as SimpleAction;
+
+ /* Normalize volume, because the volume action's state is [0.0, 1.0], see create_volume_action() */
+ vol_action.set_state (new Variant.double (this.volume_control.volume / this.max_volume));
+
+ this.update_root_icon ();
+ this.update_sync_notification ();
+ });
this.volume_control.bind_property ("ready", volume_action, "enabled", BindingFlags.SYNC_CREATE);
@@ -431,8 +429,8 @@ public class IndicatorSound.Service: Object {
volume_control.mic_volume = val.get_double ();
});
- this.volume_control.mic_volume_changed.connect ( (volume) => {
- volume_action.set_state (new Variant.double (volume));
+ this.volume_control.notify["mic-volume"].connect ( () => {
+ volume_action.set_state (new Variant.double (this.volume_control.mic_volume));
});
this.volume_control.bind_property ("ready", volume_action, "enabled", BindingFlags.SYNC_CREATE);