|  |  |  | GTK+ 3 Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | Implemented Interfaces | Properties | Signals | ||||
#include <gtk/gtk.h> struct GtkActionGroup; GtkActionGroup * gtk_action_group_new (const gchar *name); const gchar * gtk_action_group_get_name (GtkActionGroup *action_group); gboolean gtk_action_group_get_sensitive (GtkActionGroup *action_group); void gtk_action_group_set_sensitive (GtkActionGroup *action_group,gboolean sensitive); gboolean gtk_action_group_get_visible (GtkActionGroup *action_group); void gtk_action_group_set_visible (GtkActionGroup *action_group,gboolean visible); GtkAccelGroup * gtk_action_group_get_accel_group (GtkActionGroup *action_group); void gtk_action_group_set_accel_group (GtkActionGroup *action_group,GtkAccelGroup *accel_group); GtkAction * gtk_action_group_get_action (GtkActionGroup *action_group,const gchar *action_name); GList * gtk_action_group_list_actions (GtkActionGroup *action_group); void gtk_action_group_add_action (GtkActionGroup *action_group,GtkAction *action); void gtk_action_group_add_action_with_accel (GtkActionGroup *action_group,GtkAction *action,const gchar *accelerator); void gtk_action_group_remove_action (GtkActionGroup *action_group,GtkAction *action); struct GtkActionEntry; void gtk_action_group_add_actions (GtkActionGroup *action_group,const GtkActionEntry *entries,guint n_entries,gpointer user_data); void gtk_action_group_add_actions_full (GtkActionGroup *action_group,const GtkActionEntry *entries,guint n_entries,gpointer user_data,GDestroyNotify destroy); struct GtkToggleActionEntry; void gtk_action_group_add_toggle_actions (GtkActionGroup *action_group,const GtkToggleActionEntry *entries,guint n_entries,gpointer user_data); void gtk_action_group_add_toggle_actions_full (GtkActionGroup *action_group,const GtkToggleActionEntry *entries,guint n_entries,gpointer user_data,GDestroyNotify destroy); struct GtkRadioActionEntry; void gtk_action_group_add_radio_actions (GtkActionGroup *action_group,const GtkRadioActionEntry *entries,guint n_entries,gint value,GCallback on_change,gpointer user_data); void gtk_action_group_add_radio_actions_full (GtkActionGroup *action_group,const GtkRadioActionEntry *entries,guint n_entries,gint value,GCallback on_change,gpointer user_data,GDestroyNotify destroy); gchar * (*GtkTranslateFunc) (const gchar *path,gpointer func_data); void gtk_action_group_set_translate_func (GtkActionGroup *action_group,GtkTranslateFunc func,gpointer data,GDestroyNotify notify); void gtk_action_group_set_translation_domain (GtkActionGroup *action_group,const gchar *domain); const gchar * gtk_action_group_translate_string (GtkActionGroup *action_group,const gchar *string);
"accel-group" GtkAccelGroup* : Read / Write "name" gchar* : Read / Write / Construct Only "sensitive" gboolean : Read / Write "visible" gboolean : Read / Write
Actions are organised into groups. An action group is essentially a map from names to GtkAction objects.
All actions that would make sense to use in a particular context should be in a single group. Multiple action groups may be used for a particular user interface. In fact, it is expected that most nontrivial applications will make use of multiple groups. For example, in an application that can edit multiple documents, one group holding global actions (e.g. quit, about, new), and one group per document holding actions that act on that document (eg. save, cut/copy/paste, etc). Each window's menus would be constructed from a combination of two action groups.
Accelerators are handled by the GTK+ accelerator map. All actions are
assigned an accelerator path (which normally has the form
<Actions>/group-name/action-name)
and a shortcut is associated with this accelerator path. All menuitems
and toolitems take on this accelerator path. The GTK+ accelerator map
code makes sure that the correct shortcut is displayed next to the menu
item.
The GtkActionGroup implementation of the GtkBuildable interface accepts GtkAction objects as <child> elements in UI definitions.
Note that it is probably more common to define actions and action groups in the code, since they are directly related to what the code can do.
The GtkActionGroup implementation of the GtkBuildable interface supports a custom <accelerator> element, which has attributes named key and modifiers and allows to specify accelerators. This is similar to the <accelerator> element of GtkWidget, the main difference is that it doesn't allow you to specify a signal.
Example 78. A GtkDialog UI definition fragment.
| 1 2 3 4 5 6 7 8 9 10 | <object class="GtkActionGroup" id="actiongroup"> <child> <object class="GtkAction" id="About"> <property name="name">About</property> <property name="stock_id">gtk-about</property> <signal handler="about_activate" name="activate"/> </object> <accelerator key="F1" modifiers="GDK_CONTROL_MASK | GDK_SHIFT_MASK"/> </child> </object> | 
GtkActionGroup *    gtk_action_group_new                (const gchar *name);
gtk_action_group_new is deprecated and should not be used in newly-written code. 3.10
Creates a new GtkActionGroup object. The name of the action group is used when associating keybindings with the actions.
| 
 | the name of the action group. | 
| Returns : | the new GtkActionGroup | 
Since 2.4
const gchar *       gtk_action_group_get_name           (GtkActionGroup *action_group);
gtk_action_group_get_name is deprecated and should not be used in newly-written code. 3.10
Gets the name of the action group.
| 
 | the action group | 
| Returns : | the name of the action group. | 
Since 2.4
gboolean            gtk_action_group_get_sensitive      (GtkActionGroup *action_group);
gtk_action_group_get_sensitive is deprecated and should not be used in newly-written code. 3.10
Returns TRUE if the group is sensitive.  The constituent actions
can only be logically sensitive (see gtk_action_is_sensitive()) if
they are sensitive (see gtk_action_get_sensitive()) and their group
is sensitive.
| 
 | the action group | 
| Returns : | TRUEif the group is sensitive. | 
Since 2.4
void gtk_action_group_set_sensitive (GtkActionGroup *action_group,gboolean sensitive);
gtk_action_group_set_sensitive is deprecated and should not be used in newly-written code. 3.10
Changes the sensitivity of action_group
| 
 | the action group | 
| 
 | new sensitivity | 
Since 2.4
gboolean            gtk_action_group_get_visible        (GtkActionGroup *action_group);
gtk_action_group_get_visible is deprecated and should not be used in newly-written code. 3.10
Returns TRUE if the group is visible.  The constituent actions
can only be logically visible (see gtk_action_is_visible()) if
they are visible (see gtk_action_get_visible()) and their group
is visible.
| 
 | the action group | 
| Returns : | TRUEif the group is visible. | 
Since 2.4
void gtk_action_group_set_visible (GtkActionGroup *action_group,gboolean visible);
gtk_action_group_set_visible is deprecated and should not be used in newly-written code. 3.10
Changes the visible of action_group.
| 
 | the action group | 
| 
 | new visiblity | 
Since 2.4
GtkAccelGroup *     gtk_action_group_get_accel_group    (GtkActionGroup *action_group);
gtk_action_group_get_accel_group is deprecated and should not be used in newly-written code. 3.10
Gets the accelerator group.
| 
 | a GtkActionGroup | 
| Returns : | the accelerator group associated with this action
group or NULLif there is none. [transfer none] | 
Since 3.6
void gtk_action_group_set_accel_group (GtkActionGroup *action_group,GtkAccelGroup *accel_group);
gtk_action_group_set_accel_group is deprecated and should not be used in newly-written code. 3.10
Sets the accelerator group to be used by every action in this group.
| 
 | a GtkActionGroup | 
| 
 | a GtkAccelGroup to set or NULL. [allow-none] | 
Since 3.6
GtkAction * gtk_action_group_get_action (GtkActionGroup *action_group,const gchar *action_name);
gtk_action_group_get_action is deprecated and should not be used in newly-written code. 3.10
Looks up an action in the action group by name.
| 
 | the action group | 
| 
 | the name of the action | 
| Returns : | the action, or NULLif no action by that name exists. [transfer none] | 
Since 2.4
GList *             gtk_action_group_list_actions       (GtkActionGroup *action_group);
gtk_action_group_list_actions is deprecated and should not be used in newly-written code. 3.10
Lists the actions in the action group.
| 
 | the action group | 
| Returns : | an allocated list of the action objects in the action group. [element-type GtkAction][transfer container] | 
Since 2.4
void gtk_action_group_add_action (GtkActionGroup *action_group,GtkAction *action);
gtk_action_group_add_action is deprecated and should not be used in newly-written code. 3.10
Adds an action object to the action group. Note that this function
does not set up the accel path of the action, which can lead to problems
if a user tries to modify the accelerator of a menuitem associated with
the action. Therefore you must either set the accel path yourself with
gtk_action_set_accel_path(), or use 
gtk_action_group_add_action_with_accel (..., NULL).
| 
 | the action group | 
| 
 | an action | 
Since 2.4
void gtk_action_group_add_action_with_accel (GtkActionGroup *action_group,GtkAction *action,const gchar *accelerator);
gtk_action_group_add_action_with_accel is deprecated and should not be used in newly-written code. 3.10
Adds an action object to the action group and sets up the accelerator.
If accelerator is NULL, attempts to use the accelerator associated 
with the stock_id of the action. 
Accel paths are set to
<Actions>/.
group-name/action-name
| 
 | the action group | 
| 
 | the action to add | 
| 
 | the accelerator for the action, in
the format understood by gtk_accelerator_parse(), or "" for no accelerator, orNULLto use the stock accelerator. [allow-none] | 
Since 2.4
void gtk_action_group_remove_action (GtkActionGroup *action_group,GtkAction *action);
gtk_action_group_remove_action is deprecated and should not be used in newly-written code. 3.10
Removes an action object from the action group.
| 
 | the action group | 
| 
 | an action | 
Since 2.4
struct GtkActionEntry {
  const gchar     *name;
  const gchar     *stock_id;
  const gchar     *label;
  const gchar     *accelerator;
  const gchar     *tooltip;
  GCallback  callback;
};
GtkActionEntry is deprecated and should not be used in newly-written code. 3.10
GtkActionEntry structs are used with gtk_action_group_add_actions() to
construct actions.
| const gchar * | The name of the action. | 
| const gchar * | The stock id for the action, or the name of an icon from the icon theme. | 
| const gchar * | The label for the action. This field should typically be marked
for translation, see gtk_action_group_set_translation_domain(). IflabelisNULL, the label of the stock item with idstock_idis used. | 
| const gchar * | The accelerator for the action, in the format understood by gtk_accelerator_parse(). | 
| const gchar * | The tooltip for the action. This field should typically be
marked for translation, see gtk_action_group_set_translation_domain(). | 
| GCallback  | The function to call when the action is activated. | 
void gtk_action_group_add_actions (GtkActionGroup *action_group,const GtkActionEntry *entries,guint n_entries,gpointer user_data);
gtk_action_group_add_actions is deprecated and should not be used in newly-written code. 3.10
This is a convenience function to create a number of actions and add them to the action group.
The "activate" signals of the actions are connected to the callbacks and 
their accel paths are set to 
<Actions>/.
group-name/action-name
| 
 | the action group | 
| 
 | an array of action descriptions. [array length=n_entries] | 
| 
 | the number of entries | 
| 
 | data to pass to the action callbacks | 
Since 2.4
void gtk_action_group_add_actions_full (GtkActionGroup *action_group,const GtkActionEntry *entries,guint n_entries,gpointer user_data,GDestroyNotify destroy);
gtk_action_group_add_actions_full is deprecated and should not be used in newly-written code. 3.10
This variant of gtk_action_group_add_actions() adds a GDestroyNotify
callback for user_data.
| 
 | the action group | 
| 
 | an array of action descriptions. [array length=n_entries] | 
| 
 | the number of entries | 
| 
 | data to pass to the action callbacks | 
| 
 | destroy notification callback for user_data | 
Since 2.4
struct GtkToggleActionEntry {
  const gchar     *name;
  const gchar     *stock_id;
  const gchar     *label;
  const gchar     *accelerator;
  const gchar     *tooltip;
  GCallback  callback;
  gboolean   is_active;
};
GtkToggleActionEntry is deprecated and should not be used in newly-written code. 3.10
GtkToggleActionEntry structs are used with
gtk_action_group_add_toggle_actions() to construct toggle actions.
| const gchar * | The name of the action. | 
| const gchar * | The stock id for the action, or the name of an icon from the icon theme. | 
| const gchar * | The label for the action. This field should typically be marked
for translation, see gtk_action_group_set_translation_domain(). | 
| const gchar * | The accelerator for the action, in the format understood by gtk_accelerator_parse(). | 
| const gchar * | The tooltip for the action. This field should typically be
marked for translation, see gtk_action_group_set_translation_domain(). | 
| GCallback  | The function to call when the action is activated. | 
| gboolean  | The initial state of the toggle action. | 
void gtk_action_group_add_toggle_actions (GtkActionGroup *action_group,const GtkToggleActionEntry *entries,guint n_entries,gpointer user_data);
gtk_action_group_add_toggle_actions is deprecated and should not be used in newly-written code. 3.10
This is a convenience function to create a number of toggle actions and add them to the action group.
The "activate" signals of the actions are connected to the callbacks and 
their accel paths are set to 
<Actions>/.
group-name/action-name
| 
 | the action group | 
| 
 | an array of toggle action descriptions. [array length=n_entries] | 
| 
 | the number of entries | 
| 
 | data to pass to the action callbacks | 
Since 2.4
void gtk_action_group_add_toggle_actions_full (GtkActionGroup *action_group,const GtkToggleActionEntry *entries,guint n_entries,gpointer user_data,GDestroyNotify destroy);
gtk_action_group_add_toggle_actions_full is deprecated and should not be used in newly-written code. 3.10
This variant of gtk_action_group_add_toggle_actions() adds a 
GDestroyNotify callback for user_data.
| 
 | the action group | 
| 
 | an array of toggle action descriptions. [array length=n_entries] | 
| 
 | the number of entries | 
| 
 | data to pass to the action callbacks | 
| 
 | destroy notification callback for user_data | 
Since 2.4
struct GtkRadioActionEntry {
  const gchar *name;
  const gchar *stock_id;
  const gchar *label;
  const gchar *accelerator;
  const gchar *tooltip;
  gint   value; 
};
GtkRadioActionEntry is deprecated and should not be used in newly-written code. 3.10
GtkRadioActionEntry structs are used with
gtk_action_group_add_radio_actions() to construct groups of radio actions.
| const gchar * | The name of the action. | 
| const gchar * | The stock id for the action, or the name of an icon from the icon theme. | 
| const gchar * | The label for the action. This field should typically be marked
for translation, see gtk_action_group_set_translation_domain(). | 
| const gchar * | The accelerator for the action, in the format understood by gtk_accelerator_parse(). | 
| const gchar * | The tooltip for the action. This field should typically be
marked for translation, see gtk_action_group_set_translation_domain(). | 
| gint  | The value to set on the radio action. See gtk_radio_action_get_current_value(). | 
void gtk_action_group_add_radio_actions (GtkActionGroup *action_group,const GtkRadioActionEntry *entries,guint n_entries,gint value,GCallback on_change,gpointer user_data);
gtk_action_group_add_radio_actions is deprecated and should not be used in newly-written code. 3.10
This is a convenience routine to create a group of radio actions and add them to the action group.
The "changed" signal of the first radio action is connected to the 
on_change callback and the accel paths of the actions are set to 
<Actions>/.
group-name/action-name
| 
 | the action group | 
| 
 | an array of radio action descriptions. [array length=n_entries] | 
| 
 | the number of entries | 
| 
 | the value of the action to activate initially, or -1 if no action should be activated | 
| 
 | the callback to connect to the changed signal | 
| 
 | data to pass to the action callbacks | 
Since 2.4
void gtk_action_group_add_radio_actions_full (GtkActionGroup *action_group,const GtkRadioActionEntry *entries,guint n_entries,gint value,GCallback on_change,gpointer user_data,GDestroyNotify destroy);
gtk_action_group_add_radio_actions_full is deprecated and should not be used in newly-written code. 3.10
This variant of gtk_action_group_add_radio_actions() adds a 
GDestroyNotify callback for user_data.
| 
 | the action group | 
| 
 | an array of radio action descriptions. [array length=n_entries] | 
| 
 | the number of entries | 
| 
 | the value of the action to activate initially, or -1 if no action should be activated | 
| 
 | the callback to connect to the changed signal | 
| 
 | data to pass to the action callbacks | 
| 
 | destroy notification callback for user_data | 
Since 2.4
void gtk_action_group_set_translate_func (GtkActionGroup *action_group,GtkTranslateFunc func,gpointer data,GDestroyNotify notify);
gtk_action_group_set_translate_func is deprecated and should not be used in newly-written code. 3.10
Sets a function to be used for translating the label and tooltip of 
GtkActionEntrys added by gtk_action_group_add_actions().
If you're using gettext(), it is enough to set the translation domain
with gtk_action_group_set_translation_domain().
| 
 | a GtkActionGroup | 
| 
 | a GtkTranslateFunc | 
| 
 | data to be passed to funcandnotify | 
| 
 | a GDestroyNotify function to be called when action_groupis
destroyed and when the translation function is changed again | 
Since 2.4
void gtk_action_group_set_translation_domain (GtkActionGroup *action_group,const gchar *domain);
gtk_action_group_set_translation_domain is deprecated and should not be used in newly-written code. 3.10
Sets the translation domain and uses g_dgettext() for translating the 
label and tooltip of GtkActionEntrys added by 
gtk_action_group_add_actions().
If you're not using gettext() for localization, see 
gtk_action_group_set_translate_func().
| 
 | a GtkActionGroup | 
| 
 | the translation domain to use for g_dgettext()calls, orNULLto use the domain set withtextdomain(). [allow-none] | 
Since 2.4
const gchar * gtk_action_group_translate_string (GtkActionGroup *action_group,const gchar *string);
gtk_action_group_translate_string is deprecated and should not be used in newly-written code. 3.10
Translates a string using the function set with 
gtk_action_group_set_translate_func(). This
is mainly intended for language bindings.
| 
 | a GtkActionGroup | 
| 
 | a string | 
| Returns : | the translation of string | 
Since 2.6
"accel-group" property"accel-group" GtkAccelGroup* : Read / Write
GtkActionGroup:accel-group is deprecated and should not be used in newly-written code. 3.10
The accelerator group the actions of this group should use.
"name" property"name" gchar* : Read / Write / Construct Only
GtkActionGroup:name is deprecated and should not be used in newly-written code. 3.10
A name for the action.
Default value: NULL
"sensitive" property"sensitive" gboolean : Read / Write
GtkActionGroup:sensitive is deprecated and should not be used in newly-written code. 3.10
Whether the action group is enabled.
Default value: TRUE
"visible" property"visible" gboolean : Read / Write
GtkActionGroup:visible is deprecated and should not be used in newly-written code. 3.10
Whether the action group is visible.
Default value: TRUE
"connect-proxy" signalvoid user_function (GtkActionGroup *action_group, GtkAction *action, GtkWidget *proxy, gpointer user_data)
GtkActionGroup::connect-proxy is deprecated and should not be used in newly-written code. 3.10
The ::connect-proxy signal is emitted after connecting a proxy to an action in the group. Note that the proxy may have been connected to a different action before.
This is intended for simple customizations for which a custom action class would be too clumsy, e.g. showing tooltips for menuitems in the statusbar.
GtkUIManager proxies the signal and provides global notification just before any action is connected to a proxy, which is probably more convenient to use.
| 
 | the group | 
| 
 | the action | 
| 
 | the proxy | 
| 
 | user data set when the signal handler was connected. | 
Since 2.4
"disconnect-proxy" signalvoid user_function (GtkActionGroup *action_group, GtkAction *action, GtkWidget *proxy, gpointer user_data)
GtkActionGroup::disconnect-proxy is deprecated and should not be used in newly-written code. 3.10
The ::disconnect-proxy signal is emitted after disconnecting a proxy from an action in the group.
GtkUIManager proxies the signal and provides global notification just before any action is connected to a proxy, which is probably more convenient to use.
| 
 | the group | 
| 
 | the action | 
| 
 | the proxy | 
| 
 | user data set when the signal handler was connected. | 
Since 2.4
"post-activate" signalvoid user_function (GtkActionGroup *action_group, GtkAction *action, gpointer user_data)
GtkActionGroup::post-activate is deprecated and should not be used in newly-written code. 3.10
The ::post-activate signal is emitted just after the action in the
action_group is activated
This is intended for GtkUIManager to proxy the signal and provide global notification just after any action is activated.
| 
 | the group | 
| 
 | the action | 
| 
 | user data set when the signal handler was connected. | 
Since 2.4
"pre-activate" signalvoid user_function (GtkActionGroup *action_group, GtkAction *action, gpointer user_data)
GtkActionGroup::pre-activate is deprecated and should not be used in newly-written code. 3.10
The ::pre-activate signal is emitted just before the action in the
action_group is activated
This is intended for GtkUIManager to proxy the signal and provide global notification just before any action is activated.
| 
 | the group | 
| 
 | the action | 
| 
 | user data set when the signal handler was connected. | 
Since 2.4