diff options
author | Ken VanDine <ken.vandine@canonical.com> | 2012-05-03 09:07:19 -0700 |
---|---|---|
committer | Package Import Robot <package-import@ubuntu.com> | 2012-05-03 09:07:19 -0700 |
commit | 8c3919c60a789f650a35a72a0891daa340f9e809 (patch) | |
tree | 1d7bbe5414203e473a5e78ae4b4e2176280dbe04 /src/volume-widget.c | |
parent | 3b1ebd8c79d394fa65b53ee23255617440e2fec4 (diff) | |
parent | b68112634c6721221dc7b82e04f798378e26bb9e (diff) | |
download | ayatana-indicator-sound-8c3919c60a789f650a35a72a0891daa340f9e809.tar.gz ayatana-indicator-sound-8c3919c60a789f650a35a72a0891daa340f9e809.tar.bz2 ayatana-indicator-sound-8c3919c60a789f650a35a72a0891daa340f9e809.zip |
* debian/patches/lp_992262.patch
- fix sound indicator not working after amarok close (LP: #992262)
* debian/patches/lp_902715.patch
- Partial fix which sets the accessibility property on the volume
slider menu item. Previously this was achieved by sending a signal
on the indicator object but now it seems the way to update orca is
to set/update the appropriate property on the menuitem. Orca doesn't
broadcast volume updates on slider movement but at least it updates
when the user moves to the item on the menu, previously it was entirely
silent. (LP: #902715)
Diffstat (limited to 'src/volume-widget.c')
-rw-r--r-- | src/volume-widget.c | 25 |
1 files changed, 22 insertions, 3 deletions
diff --git a/src/volume-widget.c b/src/volume-widget.c index ac603c1..1258c20 100644 --- a/src/volume-widget.c +++ b/src/volume-widget.c @@ -135,16 +135,28 @@ volume_widget_property_update( DbusmenuMenuitem* item, gchar* property, if(g_ascii_strcasecmp(DBUSMENU_VOLUME_MENUITEM_LEVEL, property) == 0){ g_return_if_fail (g_variant_is_of_type (value, G_VARIANT_TYPE_DOUBLE) ); + gdouble update = g_variant_get_double (value); + if(priv->grabbed == FALSE){ GtkWidget *slider = ido_scale_menu_item_get_scale((IdoScaleMenuItem*)priv->ido_volume_slider); GtkRange *range = (GtkRange*)slider; - gdouble update = g_variant_get_double (value); gtk_range_set_value(range, update); /* g_debug ("volume-widget::volume_widget_property_update - volume - value %f", update); -*/ - update_accessible_desc(priv->indicator); + AtkObject* atk_object; + atk_object = gtk_widget_get_accessible (priv->ido_volume_slider); + if (atk_object != NULL){ + atk_object_set_name (atk_object, desc); + + }*/ } + gchar* desc = g_strdup_printf(_("Volume (%'.0f%%)"), + update); + dbusmenu_menuitem_property_set (priv->twin_item, + DBUSMENU_MENUITEM_PROP_ACCESSIBLE_DESC, + desc); + g_free (desc); + update_accessible_desc(priv->indicator); } else if(g_ascii_strcasecmp(DBUSMENU_VOLUME_MENUITEM_MUTE, property) == 0){ g_return_if_fail (g_variant_is_of_type (value, G_VARIANT_TYPE_BOOLEAN)); @@ -196,6 +208,13 @@ volume_widget_set_twin_item(VolumeWidget* self, initial_level = 0; } gtk_range_set_value(range, initial_level); + gchar* desc = g_strdup_printf(_("Volume (%'.0f%%)"), + initial_level); + dbusmenu_menuitem_property_set (priv->twin_item, + DBUSMENU_MENUITEM_PROP_ACCESSIBLE_DESC, + desc); + g_free (desc); + } static gboolean |