ayatana-commits team mailing list archive
-
ayatana-commits team
-
Mailing list archive
-
Message #01441
[Merge] lp:~cjcurran/indicator-sound/volume_setting_code_refactor into lp:indicator-sound
Conor Curran has proposed merging lp:~cjcurran/indicator-sound/volume_setting_code_refactor into lp:indicator-sound.
Requested reviews:
Indicator Applet Developers (indicator-applet-developers)
Greatly simplified the volume setting code. Basically on setting the volume init a mono volume. This will preserve balance and removes the cruft which was there from early this afternoon.
--
https://code.launchpad.net/~cjcurran/indicator-sound/volume_setting_code_refactor/+merge/23953
Your team ayatana-commits is subscribed to branch lp:indicator-sound.
=== modified file 'src/pulse-manager.c'
--- src/pulse-manager.c 2010-04-22 16:58:50 +0000
+++ src/pulse-manager.c 2010-04-22 18:30:29 +0000
@@ -242,27 +242,16 @@
return;
}
- sink_info *s = g_hash_table_lookup(sink_hash, GINT_TO_POINTER(DEFAULT_SINK_INDEX));
- pa_volume_t cached_volume = pa_cvolume_max(&s->volume);
- pa_volume_t new_volume = (pa_volume_t) ((percent * PA_VOLUME_NORM) / 100);
- pa_volume_t difference = 0;
-
- if( cached_volume > new_volume ){
- g_debug("I'm moving down down ...");
- difference = cached_volume - new_volume;
- pa_cvolume_dec(&s->volume, difference);
- }
- else if ( cached_volume < new_volume ){
- g_debug("I'm moving up up ...");
- difference = new_volume - cached_volume;
- pa_cvolume_inc(&s->volume, difference);
- }
-
- g_debug("Calculated difference : %f", (gdouble)difference);
- g_debug("new_volume calculated from percentage input :%f", pa_sw_volume_to_linear(new_volume));
- g_debug("new volume calculated from resultant output :%f", pa_sw_volume_to_linear(pa_cvolume_max(&s->volume)));
-
- pa_operation_unref(pa_context_set_sink_volume_by_index(pulse_context, DEFAULT_SINK_INDEX, &s->volume, NULL, NULL));
+ sink_info *cached_sink = g_hash_table_lookup(sink_hash, GINT_TO_POINTER(DEFAULT_SINK_INDEX));
+
+ pa_cvolume new_volume;
+ pa_cvolume_init(&new_volume);
+ new_volume.channels = 1;
+ pa_volume_t new_volume_value = (pa_volume_t) ((percent * PA_VOLUME_NORM) / 100);
+ pa_cvolume_set(&new_volume, 1, new_volume_value);
+ pa_cvolume_set(&cached_sink->volume, cached_sink->channel_map.channels, new_volume_value);
+
+ pa_operation_unref(pa_context_set_sink_volume_by_index(pulse_context, DEFAULT_SINK_INDEX, &new_volume, NULL, NULL));
}
Follow ups