Gnome User Interface Library Reference Manual | |||
---|---|---|---|
<<< Previous Page | Home | Up | Next Page >>> |
#include <gnome.h> struct GnomeMDIChild; GtkWidget* (*GnomeMDIChildViewCreator) (GnomeMDIChild*, gpointer); GList* (*GnomeMDIChildMenuCreator) (GnomeMDIChild*, GtkWidget*, gpointer); gchar* (*GnomeMDIChildConfigFunc) (GnomeMDIChild*, gpointer); GtkWidget* (*GnomeMDIChildLabelFunc) (GnomeMDIChild*, GtkWidget*, gpointer); GtkWidget* gnome_mdi_child_add_view (GnomeMDIChild *mdi_child); void gnome_mdi_child_remove_view (GnomeMDIChild *mdi_child, GtkWidget *view); void gnome_mdi_child_set_name (GnomeMDIChild *mdi_child, gchar *name); void gnome_mdi_child_set_menu_template (GnomeMDIChild *mdi_child, GnomeUIInfo *menu_tmpl); |
GnomeMDIChild is an abstract class for GnomeMDI children. In order to use it, you have to either derive a new class from it and define the proper virtual functions in its parent GnomeMDIChildClass structure or use the GnomeMDIGenericChild class that allows to specify the relevant functions on a per-instance rather than on per-class basis.
Each instance of GnomeMDIChild class defines a name for the child and possibly a menu template for document-specific menus that will be merged with the global MDI menus. The menu template is set using the gnome_mdi_child_set_menu_template() function.
The GnomeMDIChild class has four virtual functions that are used by the MDI:
create_view must be defined for each subclass and must return a pointer to a GtkWidget representing a new view of the document.
create_menus must return a GList of menu items and can be used instead of the child's menu template. If both template and this function are defined, only the template (which can be defined on a per-instance basis) is used.
get_config_string must return a string that represents the state of the child and will be used to save and restore state of the MDI children bewtween sessions.
set_label must return a pointer to a GtkWidget that will be used as notebook and menu item label for this child.
GList* (*GnomeMDIChildMenuCreator) (GnomeMDIChild*, GtkWidget*, gpointer); |
GtkWidget* (*GnomeMDIChildLabelFunc) (GnomeMDIChild*, GtkWidget*, gpointer); |
GtkWidget* gnome_mdi_child_add_view (GnomeMDIChild *mdi_child); |
Creates a new view of a child (a GtkWidget) adds it to the list of the views and returns a pointer to it. Virtual function that has to be specified for classes derived from GnomeMDIChild is used to create the new view.
void gnome_mdi_child_remove_view (GnomeMDIChild *mdi_child, GtkWidget *view); |
Removes view view from the list of mdi_child's views and unrefs it.
void gnome_mdi_child_set_name (GnomeMDIChild *mdi_child, gchar *name); |
Changes name of mdi_child to name. name is duplicated and stored in mdi_child. If mdi_child has already been added to GnomeMDI, it also takes care of updating it.
void gnome_mdi_child_set_menu_template (GnomeMDIChild *mdi_child, GnomeUIInfo *menu_tmpl); |
Sets the template for menus that are added and removed when differrent children get activated. This way, each child can modify the MDI menubar to suit its needs. If no template is set, the create_menus virtual function will be used for creating these menus (it has to return a GList of menu items). If no such function is specified, the menubar will be unchanged by MDI children.