aboutsummaryrefslogtreecommitdiff
path: root/src/volume-widget.c
diff options
context:
space:
mode:
authorKen VanDine <ken.vandine@canonical.com>2012-05-03 09:07:19 -0700
committerPackage Import Robot <package-import@ubuntu.com>2012-05-03 09:07:19 -0700
commit8c3919c60a789f650a35a72a0891daa340f9e809 (patch)
tree1d7bbe5414203e473a5e78ae4b4e2176280dbe04 /src/volume-widget.c
parent3b1ebd8c79d394fa65b53ee23255617440e2fec4 (diff)
parentb68112634c6721221dc7b82e04f798378e26bb9e (diff)
downloadayatana-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.c25
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