GTK+ 3 Reference Manual | ||||
---|---|---|---|---|
Top | Description | Object Hierarchy | Implemented Interfaces | Properties |
#include <gtk/gtk.h> struct GtkAccelLabel; GtkWidget * gtk_accel_label_new (const gchar *string
); void gtk_accel_label_set_accel_closure (GtkAccelLabel *accel_label
,GClosure *accel_closure
); GtkWidget * gtk_accel_label_get_accel_widget (GtkAccelLabel *accel_label
); void gtk_accel_label_set_accel_widget (GtkAccelLabel *accel_label
,GtkWidget *accel_widget
); guint gtk_accel_label_get_accel_width (GtkAccelLabel *accel_label
); void gtk_accel_label_set_accel (GtkAccelLabel *accel_label
,guint accelerator_key
,GdkModifierType accelerator_mods
); gboolean gtk_accel_label_refetch (GtkAccelLabel *accel_label
);
GObject +----GInitiallyUnowned +----GtkWidget +----GtkMisc +----GtkLabel +----GtkAccelLabel
The GtkAccelLabel widget is a subclass of GtkLabel that also displays an accelerator key on the right of the label text, e.g. 'Ctl+S'. It is commonly used in menus to show the keyboard short-cuts for commands.
The accelerator key to display is not set explicitly.
Instead, the GtkAccelLabel displays the accelerators which have been added to
a particular widget. This widget is set by calling
gtk_accel_label_set_accel_widget()
.
For example, a GtkMenuItem widget may have an accelerator added to emit the
"activate" signal when the 'Ctl+S' key combination is pressed.
A GtkAccelLabel is created and added to the GtkMenuItem, and
gtk_accel_label_set_accel_widget()
is called with the GtkMenuItem as the
second argument. The GtkAccelLabel will now display 'Ctl+S' after its label.
Note that creating a GtkMenuItem with gtk_menu_item_new_with_label()
(or
one of the similar functions for GtkCheckMenuItem and GtkRadioMenuItem)
automatically adds a GtkAccelLabel to the GtkMenuItem and calls
gtk_accel_label_set_accel_widget()
to set it up for you.
A GtkAccelLabel will only display accelerators which have GTK_ACCEL_VISIBLE
set (see GtkAccelFlags).
A GtkAccelLabel can display multiple accelerators and even signal names,
though it is almost always used to display just one accelerator key.
Example 49. Creating a simple menu item with an accelerator key.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 |
GtkWidget *save_item; GtkAccelGroup *accel_group; /* Create a GtkAccelGroup and add it to the window. */ accel_group = gtk_accel_group_new (); gtk_window_add_accel_group (GTK_WINDOW (window), accel_group); /* Create the menu item using the convenience function. */ save_item = gtk_menu_item_new_with_label ("Save"); gtk_widget_show (save_item); gtk_container_add (GTK_CONTAINER (menu), save_item); /* Now add the accelerator to the GtkMenuItem. Note that since we called gtk_menu_item_new_with_label() to create the GtkMenuItem the GtkAccelLabel is automatically set up to display the GtkMenuItem accelerators. We just need to make sure we use GTK_ACCEL_VISIBLE here. */ gtk_widget_add_accelerator (save_item, "activate", accel_group, GDK_KEY_s, GDK_CONTROL_MASK, GTK_ACCEL_VISIBLE); |
struct GtkAccelLabel;
The GtkAccelLabel struct contains private data only, and should be accessed using the functions below.
GtkWidget * gtk_accel_label_new (const gchar *string
);
Creates a new GtkAccelLabel.
|
the label string. Must be non-NULL . |
Returns : |
a new GtkAccelLabel. |
void gtk_accel_label_set_accel_closure (GtkAccelLabel *accel_label
,GClosure *accel_closure
);
Sets the closure to be monitored by this accelerator label. The closure
must be connected to an accelerator group; see gtk_accel_group_connect()
.
|
a GtkAccelLabel |
|
the closure to monitor for accelerator changes. |
GtkWidget * gtk_accel_label_get_accel_widget (GtkAccelLabel *accel_label
);
Fetches the widget monitored by this accelerator label. See
gtk_accel_label_set_accel_widget()
.
|
a GtkAccelLabel |
Returns : |
the object monitored by the accelerator label, or NULL . [transfer none]
|
void gtk_accel_label_set_accel_widget (GtkAccelLabel *accel_label
,GtkWidget *accel_widget
);
Sets the widget to be monitored by this accelerator label.
|
a GtkAccelLabel |
|
the widget to be monitored. |
guint gtk_accel_label_get_accel_width (GtkAccelLabel *accel_label
);
Returns the width needed to display the accelerator key(s). This is used by menus to align all of the GtkMenuItem widgets, and shouldn't be needed by applications.
|
a GtkAccelLabel. |
Returns : |
the width needed to display the accelerator key(s). |
void gtk_accel_label_set_accel (GtkAccelLabel *accel_label
,guint accelerator_key
,GdkModifierType accelerator_mods
);
Manually sets a keyval and modifier mask as the accelerator rendered
by accel_label
.
If a keyval and modifier are explicitly set then these values are used regardless of any associated accel closure or widget.
Providing an accelerator_key
of 0 removes the manual setting.
|
a GtkAccelLabel |
|
a keyval, or 0 |
|
the modifier mask for the accel |
Since 3.6
gboolean gtk_accel_label_refetch (GtkAccelLabel *accel_label
);
Recreates the string representing the accelerator keys. This should not be needed since the string is automatically updated whenever accelerators are added or removed from the associated widget.
|
a GtkAccelLabel. |
Returns : |
always returns FALSE . |
"accel-closure"
property "accel-closure" GClosure* : Read / Write
The closure to be monitored for accelerator changes.
"accel-widget"
property"accel-widget" GtkWidget* : Read / Write
The widget to be monitored for accelerator changes.