diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/indicator-sound.c | 77 | ||||
-rw-r--r-- | src/slider-menu-item.c | 15 | ||||
-rw-r--r-- | src/sound-service.c | 12 |
3 files changed, 56 insertions, 48 deletions
diff --git a/src/indicator-sound.c b/src/indicator-sound.c index c2c3159..0837811 100644 --- a/src/indicator-sound.c +++ b/src/indicator-sound.c @@ -78,10 +78,13 @@ static GtkLabel * get_label (IndicatorObject * io); static GtkImage * get_icon (IndicatorObject * io); static GtkMenu * get_menu (IndicatorObject * io); static GtkWidget *volume_slider = NULL; +static gdouble input_value_from_across_the_dbus = 0.0; +static GtkImage *speaker_image = NULL; static gboolean new_slider_item (DbusmenuMenuitem * newitem, DbusmenuMenuitem * parent, DbusmenuClient * client); static void slider_prop_change_cb (DbusmenuMenuitem * mi, gchar * prop, GValue * value); static gboolean slider_value_changed_event_cb(GtkRange *range, GtkScrollType scroll, double value, gpointer user_data); +static void change_speaker_image(gdouble volume_percent); // DBUS communication static DBusGProxy *sound_dbus_proxy = NULL; @@ -115,9 +118,7 @@ static void indicator_sound_init (IndicatorSound *self) self->service = NULL; /* Now let's fire these guys up. */ self->service = indicator_service_manager_new_version(INDICATOR_SOUND_DBUS_NAME, INDICATOR_SOUND_DBUS_VERSION); - g_signal_connect(G_OBJECT(self->service), INDICATOR_SERVICE_MANAGER_SIGNAL_CONNECTION_CHANGE, G_CALLBACK(connection_changed), self); - return; } @@ -173,7 +174,6 @@ indicator_sound_dispose (GObject *object) static void indicator_sound_finalize (GObject *object) { - G_OBJECT_CLASS (indicator_sound_parent_class)->finalize (object); return; } @@ -187,9 +187,25 @@ get_label (IndicatorObject * io) static GtkImage * get_icon (IndicatorObject * io) { - GtkImage * status_image = GTK_IMAGE(gtk_image_new_from_icon_name("audio-volume-high", GTK_ICON_SIZE_MENU)); - gtk_widget_show(GTK_WIDGET(status_image)); - return status_image; + speaker_image = GTK_IMAGE(gtk_image_new_from_icon_name("audio-volume-high", GTK_ICON_SIZE_MENU)); + gtk_widget_show(GTK_WIDGET(speaker_image)); + return speaker_image; +} + +static void change_speaker_image(gdouble volume_percent) +{ + if (volume_percent < 30.0 && volume_percent > 0){ + gtk_image_set_from_icon_name(speaker_image, "audio-volume-low", GTK_ICON_SIZE_MENU); + } + else if(volume_percent < 70.0 && volume_percent > 30.0){ + gtk_image_set_from_icon_name(speaker_image, "audio-volume-medium", GTK_ICON_SIZE_MENU); + } + else if(volume_percent > 70.0){ + gtk_image_set_from_icon_name(speaker_image, "audio-volume-high", GTK_ICON_SIZE_MENU); + } + else if(volume_percent <= 0.0){ + gtk_image_set_from_icon_name(speaker_image, "audio-volume-muted", GTK_ICON_SIZE_MENU); + } } /* Indicator based function to get the menu for the whole @@ -202,9 +218,6 @@ get_menu (IndicatorObject * io) DbusmenuGtkClient *client = dbusmenu_gtkmenu_get_client(menu); dbusmenu_client_add_type_handler(DBUSMENU_CLIENT(client), DBUSMENU_SLIDER_MENUITEM_TYPE, new_slider_item); - //gtk_menu_shell_append (GTK_MENU_SHELL (menu), get_slider(io)); - //gtk_widget_show_all(volume_slider); - return GTK_MENU(menu); } @@ -213,7 +226,7 @@ static gboolean new_slider_item(DbusmenuMenuitem * newitem, DbusmenuMenuitem * p g_return_val_if_fail(DBUSMENU_IS_MENUITEM(newitem), FALSE); g_return_val_if_fail(DBUSMENU_IS_GTKCLIENT(client), FALSE); - volume_slider = ido_scale_menu_item_new_with_range ("Volume", 2, 98, 1); + volume_slider = ido_scale_menu_item_new_with_range ("Volume", 0, 100, 0.5); GtkMenuItem *menu_volume_slider = GTK_MENU_ITEM(volume_slider); dbusmenu_gtkclient_newitem_base(DBUSMENU_GTKCLIENT(client), newitem, menu_volume_slider, parent); @@ -230,36 +243,30 @@ static gboolean new_slider_item(DbusmenuMenuitem * newitem, DbusmenuMenuitem * p static void slider_prop_change_cb (DbusmenuMenuitem * mi, gchar * prop, GValue * value) { g_debug("slider_prop_change_cb "); - if (!g_strcmp0(prop, DBUSMENU_SLIDER_MENUITEM_PROP_VOLUME)) { - /* Set the slider value */ - g_debug("about to set it"); - GtkWidget* slider = ido_scale_menu_item_get_scale((IdoScaleMenuItem*)volume_slider); - GtkRange* range = (GtkRange*)slider; - gtk_range_set_value(range, (gdouble)g_value_get_double(value)); - } + g_debug("about to set the slider to %f", g_value_get_double(value)); + GtkWidget* slider = ido_scale_menu_item_get_scale((IdoScaleMenuItem*)volume_slider); + GtkRange* range = (GtkRange*)slider; + gdouble level; + level = gtk_range_get_fill_level(range); + input_value_from_across_the_dbus = level; + g_debug("the current level is %f", level); + + gtk_range_set_value(range, g_value_get_double(value)); return; } static gboolean slider_value_changed_event_cb(GtkRange *range, GtkScrollType scroll, double slider_value, gpointer user_data) { - DbusmenuMenuitem *item = (DbusmenuMenuitem*)user_data; - GValue value = {0}; - g_value_init(&value, G_TYPE_DOUBLE); - g_value_set_double(&value, slider_value); - - dbusmenu_menuitem_handle_event (item, "slider_change", &value, 0); + if(slider_value != input_value_from_across_the_dbus) + { + DbusmenuMenuitem *item = (DbusmenuMenuitem*)user_data; + GValue value = {0}; + g_value_init(&value, G_TYPE_DOUBLE); + g_value_set_double(&value, slider_value); + dbusmenu_menuitem_handle_event (item, "slider_change", &value, 0); + change_speaker_image(slider_value); + } return FALSE; -} - -/* GtkWidget* slider = ido_scale_menu_item_get_scale((IdoScaleMenuItem*)volume_slider);*/ -/*static GtkWidget* get_slider(IndicatorObject * io)*/ -/*{*/ -/* volume_slider = ido_scale_menu_item_new_with_range ("Volume", 2, 98, 1);*/ -/* GtkWidget* slider = ido_scale_menu_item_get_scale((IdoScaleMenuItem*)volume_slider);*/ -/* GtkRange* range = (GtkRange*)slider;*/ -/* //g_signal_connect(G_OBJECT(range), "value-changed", G_CALLBACK(slider_event_detected), NULL); */ -/* g_signal_connect(G_OBJECT(range), "change-value", G_CALLBACK(slider_value_changed_event_cb), io); */ -/* return volume_slider;*/ -/*}*/ +} diff --git a/src/slider-menu-item.c b/src/slider-menu-item.c index a1e4725..b26a90f 100644 --- a/src/slider-menu-item.c +++ b/src/slider-menu-item.c @@ -26,12 +26,6 @@ with this program. If not, see <http://www.gnu.org/licenses/>. #include "pulse-manager.h" #include "common-defs.h" -/*enum {*/ -/* VOLUME_CHANGED,*/ -/* FINAL_SIGNAL*/ -/*};*/ - -/*static guint slider_signals[FINAL_SIGNAL] = { 0 };*/ typedef struct _SliderMenuItemPrivate SliderMenuItemPrivate; @@ -96,7 +90,6 @@ static void handle_event (DbusmenuMenuitem * mi, const gchar * name, const GValue * value, guint timestamp) { g_debug("in the handle event method of slider_menu_item"); - set_sink_volume((gdouble)g_value_get_double(value)); } @@ -109,14 +102,10 @@ SliderMenuItem* slider_menu_item_new(gboolean sinks_available, gdouble start_vol dbusmenu_menuitem_property_set(DBUSMENU_MENUITEM(self), DBUSMENU_MENUITEM_PROP_TYPE, DBUSMENU_SLIDER_MENUITEM_TYPE); //TODO: If no valid sinks are found grey out the item(s) dbusmenu_menuitem_property_set_bool(DBUSMENU_MENUITEM(self), DBUSMENU_MENUITEM_PROP_SENSITIVE, sinks_available); - - GValue value = {0}; - g_value_init(&value, G_TYPE_DOUBLE); - g_value_set_double(&value, start_volume); - //dbusmenu_menuitem_property_set_value(DBUSMENU_MENUITEM(self), DBUSMENU_SLIDER_MENUITEM_PROP_VOLUME, &value); + g_debug("Sending the initial value of the slider over dbus = %f", start_volume * 100); return self; } - + diff --git a/src/sound-service.c b/src/sound-service.c index ce2b101..e7341bd 100644 --- a/src/sound-service.c +++ b/src/sound-service.c @@ -79,6 +79,12 @@ static void set_global_mute() b_all_muted = !b_all_muted; toggle_global_mute(b_all_muted); dbusmenu_menuitem_property_set(mute_all_menuitem, DBUSMENU_MENUITEM_PROP_LABEL, _(b_all_muted == FALSE ? "Mute All" : "Unmute")); + +/* GValue value = {0};*/ +/* g_value_init(&value, G_TYPE_DOUBLE);*/ +/* g_value_set_double(&value, 100.0);*/ +/* // Testing*/ +/* dbusmenu_menuitem_property_set_value(DBUSMENU_MENUITEM(volume_slider_menuitem), DBUSMENU_SLIDER_MENUITEM_PROP_VOLUME, &value);*/ } @@ -106,6 +112,12 @@ void update_pa_state(gboolean pa_state, gboolean sink_available, gboolean sink_m volume_percent = percent; g_debug("update pa state with state %i, availability of %i, mute value of %i and a volume percent is %f", pa_state, sink_available, sink_muted, volume_percent); rebuild_sound_menu(root_menuitem, dbus_interface); + g_debug("About to send over the volume slider"); + GValue value = {0}; + g_value_init(&value, G_TYPE_DOUBLE); + g_value_set_double(&value, volume_percent * 100); + dbusmenu_menuitem_property_set_value(DBUSMENU_MENUITEM(volume_slider_menuitem), DBUSMENU_SLIDER_MENUITEM_PROP_VOLUME, &value); + } |