|  |  |  | GooCanvas Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | Prerequisites | Known Implementations | Properties | Signals | ||||
GooCanvasItemModel; struct GooCanvasItemModelIface; void goo_canvas_item_model_translate (GooCanvasItemModel *model,gdouble tx,gdouble ty); void goo_canvas_item_model_scale (GooCanvasItemModel *model,gdouble sx,gdouble sy); void goo_canvas_item_model_rotate (GooCanvasItemModel *model,gdouble degrees,gdouble cx,gdouble cy); void goo_canvas_item_model_skew_x (GooCanvasItemModel *model,gdouble degrees,gdouble cx,gdouble cy); void goo_canvas_item_model_skew_y (GooCanvasItemModel *model,gdouble degrees,gdouble cx,gdouble cy); gboolean goo_canvas_item_model_get_transform (GooCanvasItemModel *model,cairo_matrix_t *transform); void goo_canvas_item_model_set_transform (GooCanvasItemModel *model,const cairo_matrix_t *transform); gboolean goo_canvas_item_model_get_simple_transform (GooCanvasItemModel *model,gdouble *x,gdouble *y,gdouble *scale,gdouble *rotation); void goo_canvas_item_model_set_simple_transform (GooCanvasItemModel *model,gdouble x,gdouble y,gdouble scale,gdouble rotation); void goo_canvas_item_model_animate (GooCanvasItemModel *model,gdouble x,gdouble y,gdouble scale,gdouble degrees,gboolean absolute,gint duration,gint step_time,GooCanvasAnimateType type); void goo_canvas_item_model_stop_animation (GooCanvasItemModel *model); void goo_canvas_item_model_raise (GooCanvasItemModel *model,GooCanvasItemModel *above); void goo_canvas_item_model_lower (GooCanvasItemModel *model,GooCanvasItemModel *below); void goo_canvas_item_model_remove (GooCanvasItemModel *model); GooCanvasItemModel * goo_canvas_item_model_get_parent (GooCanvasItemModel *model); void goo_canvas_item_model_set_parent (GooCanvasItemModel *model,GooCanvasItemModel *parent); gboolean goo_canvas_item_model_is_container (GooCanvasItemModel *model); gint goo_canvas_item_model_get_n_children (GooCanvasItemModel *model); GooCanvasItemModel * goo_canvas_item_model_get_child (GooCanvasItemModel *model,gint child_num); void goo_canvas_item_model_add_child (GooCanvasItemModel *model,GooCanvasItemModel *child,gint position); void goo_canvas_item_model_move_child (GooCanvasItemModel *model,gint old_position,gint new_position); void goo_canvas_item_model_remove_child (GooCanvasItemModel *model,gint child_num); gint goo_canvas_item_model_find_child (GooCanvasItemModel *model,GooCanvasItemModel *child); GooCanvasStyle * goo_canvas_item_model_get_style (GooCanvasItemModel *model); void goo_canvas_item_model_set_style (GooCanvasItemModel *model,GooCanvasStyle *style); void goo_canvas_item_model_class_install_child_property (GObjectClass *mclass,guint property_id,GParamSpec *pspec); GParamSpec ** goo_canvas_item_model_class_list_child_properties (GObjectClass *mclass,guint *n_properties); GParamSpec * goo_canvas_item_model_class_find_child_property (GObjectClass *mclass,const gchar *property_name); void goo_canvas_item_model_get_child_property (GooCanvasItemModel *model,GooCanvasItemModel *child,const gchar *property_name,GValue *value); void goo_canvas_item_model_set_child_property (GooCanvasItemModel *model,GooCanvasItemModel *child,const gchar *property_name,const GValue *value); void goo_canvas_item_model_get_child_properties (GooCanvasItemModel *model,GooCanvasItemModel *child,...); void goo_canvas_item_model_get_child_properties_valist (GooCanvasItemModel *model,GooCanvasItemModel *child,va_list var_args); void goo_canvas_item_model_set_child_properties (GooCanvasItemModel *model,GooCanvasItemModel *child,...); void goo_canvas_item_model_set_child_properties_valist (GooCanvasItemModel *model,GooCanvasItemModel *child,va_list var_args);
GooCanvasItemModel is implemented by GooCanvasEllipseModel, GooCanvasGridModel, GooCanvasGroupModel, GooCanvasImageModel, GooCanvasItemModelSimple, GooCanvasPathModel, GooCanvasPolylineModel, GooCanvasRectModel, GooCanvasTableModel and GooCanvasTextModel.
"can-focus" gboolean : Read / Write "description" gchar* : Read / Write "parent" GooCanvasItemModel* : Read / Write "pointer-events" GooCanvasPointerEvents : Read / Write "title" gchar* : Read / Write "tooltip" gchar* : Read / Write "transform" GooCairoMatrix* : Read / Write "visibility" GooCanvasItemVisibility : Read / Write "visibility-threshold" gdouble : Read / Write
"animation-finished" :Run Last"changed" :Run Last"child-added" :Run Last"child-moved" :Run Last"child-notify" :No Hooks"child-removed" :Run Last
GooCanvasItemModel defines the interface that models for canvas items must implement, and contains methods for operating on canvas item models.
The Model/View canvas feature may be removed in a future version of GooCanvas.
typedef struct _GooCanvasItemModel GooCanvasItemModel;
GooCanvasItemModel is a typedef used for objects that implement the GooCanvasItemModel interface.
(There is no actual GooCanvasItemModel struct, since it is only an interface. But using 'GooCanvasItemModel' is more helpful than using 'GObject'.)
struct GooCanvasItemModelIface {
  /* Virtual methods that group models must implement. */
  gint		       (* get_n_children)		(GooCanvasItemModel *model);
  GooCanvasItemModel*  (* get_child)			(GooCanvasItemModel *model,
							 gint			 child_num);
  /* Virtual methods that group models may implement. */
  void                 (* add_child)			(GooCanvasItemModel *model,
							 GooCanvasItemModel *child,
							 gint			 position);
  void                 (* move_child)			(GooCanvasItemModel *model,
							 gint			 old_position,
							 gint			 new_position);
  void                 (* remove_child)			(GooCanvasItemModel *model,
							 gint			 child_num);
  void                 (* get_child_property)		(GooCanvasItemModel *model,
							 GooCanvasItemModel *child,
							 guint			 property_id,
							 GValue			*value,
							 GParamSpec		*pspec);
  void                 (* set_child_property)		(GooCanvasItemModel *item,
							 GooCanvasItemModel *child,
							 guint			 property_id,
							 const GValue		*value,
							 GParamSpec		*pspec);
  /* Virtual methods that all item models must implement. */
  GooCanvasItemModel*  (* get_parent)			(GooCanvasItemModel *model);
  void                 (* set_parent)			(GooCanvasItemModel *model,
							 GooCanvasItemModel *parent);
  GooCanvasItem*       (* create_item)			(GooCanvasItemModel *model,
							 GooCanvas		*canvas);
  /* Virtual methods that all item models may implement. */
  gboolean             (* get_transform)		(GooCanvasItemModel *model,
							 cairo_matrix_t         *transform);
  void                 (* set_transform)		(GooCanvasItemModel *model,
							 const cairo_matrix_t *transform);
  GooCanvasStyle*      (* get_style)			(GooCanvasItemModel *model);
  void                 (* set_style)			(GooCanvasItemModel *model,
							 GooCanvasStyle		*style);
  /* Signals. */
  void                 (* child_added)			(GooCanvasItemModel *model,
							 gint			 child_num);
  void                 (* child_moved)			(GooCanvasItemModel *model,
							 gint			 old_child_num,
							 gint			 new_child_num);
  void                 (* child_removed)		(GooCanvasItemModel *model,
							 gint			 child_num);
  void                 (* changed)			(GooCanvasItemModel *model,
							 gboolean		 recompute_bounds);
  void                 (* child_notify)			(GooCanvasItemModel *model,
							 GParamSpec		*pspec);
  void		       (* animation_finished)		(GooCanvasItemModel     *model,
							 gboolean                stopped);
};
GooCanvasItemModelIFace holds the virtual methods that make up the GooCanvasItemModel interface.
Simple item models only need to implement the get_parent(), set_parent()
and create_item() methods.
Items that support transforms should also implement get_transform() and
set_transform(). Items that support styles should implement get_style()
and set_style().
Container items must implement get_n_children() and get_child().
Containers that support dynamic changes to their children should implement
add_child(), move_child() and remove_child().
Layout containers like GooCanvasTable may implement
get_child_property() and set_child_property().
| returns the number of children of the model. | |
| returns the child at the given index. | |
| adds a child. | |
| moves a child up or down the stacking order. | |
| removes a child. | |
| gets a child property of a given child model, e.g. the "row" or "column" property of a model in a GooCanvasTableModel. | |
| sets a child property for a given child model. | |
| gets the model's parent. | |
| sets the model's parent. | |
| creates a default canvas item to view the model. | |
| gets the model's transformation matrix. | |
| sets the model's transformation matrix. | |
| gets the model's style. | |
| sets the model's style. | |
| signal emitted when a child is added. | |
| signal emitted when a child is moved in the stacking order. | |
| signal emitted when a child is removed. | |
| signal emitted when the model has changed. | |
| signal emitted when a child property has changed. | |
| signal emitted when the model's animation has finished. | 
void goo_canvas_item_model_translate (GooCanvasItemModel *model,gdouble tx,gdouble ty);
Translates the origin of the model's coordinate system by the given amounts.
| 
 | an item model. | 
| 
 | the amount to move the origin in the horizontal direction. | 
| 
 | the amount to move the origin in the vertical direction. | 
void goo_canvas_item_model_scale (GooCanvasItemModel *model,gdouble sx,gdouble sy);
Scales the model's coordinate system by the given amounts.
| 
 | an item model. | 
| 
 | the amount to scale the horizontal axis. | 
| 
 | the amount to scale the vertical axis. | 
void goo_canvas_item_model_rotate (GooCanvasItemModel *model,gdouble degrees,gdouble cx,gdouble cy);
Rotates the model's coordinate system by the given amount, about the given origin.
| 
 | an item model. | 
| 
 | the clockwise angle of rotation. | 
| 
 | the x coordinate of the origin of the rotation. | 
| 
 | the y coordinate of the origin of the rotation. | 
void goo_canvas_item_model_skew_x (GooCanvasItemModel *model,gdouble degrees,gdouble cx,gdouble cy);
Skews the model's coordinate system along the x axis by the given amount, about the given origin.
| 
 | an item model. | 
| 
 | the skew angle. | 
| 
 | the x coordinate of the origin of the skew transform. | 
| 
 | the y coordinate of the origin of the skew transform. | 
void goo_canvas_item_model_skew_y (GooCanvasItemModel *model,gdouble degrees,gdouble cx,gdouble cy);
Skews the model's coordinate system along the y axis by the given amount, about the given origin.
| 
 | an item model. | 
| 
 | the skew angle. | 
| 
 | the x coordinate of the origin of the skew transform. | 
| 
 | the y coordinate of the origin of the skew transform. | 
gboolean goo_canvas_item_model_get_transform (GooCanvasItemModel *model,cairo_matrix_t *transform);
Gets the transformation matrix of an item model.
| 
 | an item model. | 
| 
 | the place to store the transform. | 
| Returns : | TRUEif a transform is set. | 
void goo_canvas_item_model_set_transform (GooCanvasItemModel *model,const cairo_matrix_t *transform);
Sets the transformation matrix of an item model.
| 
 | an item model. | 
| 
 | the new transformation matrix, or NULLto reset the
transformation to the identity matrix. | 
gboolean goo_canvas_item_model_get_simple_transform (GooCanvasItemModel *model,gdouble *x,gdouble *y,gdouble *scale,gdouble *rotation);
This function can be used to get the position, scale and rotation of an
item model, providing that the model has a simple transformation matrix
(e.g. set with goo_canvas_item_model_set_simple_transform(), or using a
combination of simple translate, scale and rotate operations). If the model
has a complex transformation matrix the results will be incorrect.
| 
 | an item model. | 
| 
 | returns the x coordinate of the origin of the model's coordinate space. | 
| 
 | returns the y coordinate of the origin of the model's coordinate space. | 
| 
 | returns the scale of the model. | 
| 
 | returns the clockwise rotation of the model, in degrees (0-360). | 
| Returns : | TRUEif a transform is set. | 
void goo_canvas_item_model_set_simple_transform (GooCanvasItemModel *model,gdouble x,gdouble y,gdouble scale,gdouble rotation);
A convenience function to set the item model's transformation matrix.
| 
 | an item model. | 
| 
 | the x coordinate of the origin of the model's coordinate space. | 
| 
 | the y coordinate of the origin of the model's coordinate space. | 
| 
 | the scale of the model. | 
| 
 | the clockwise rotation of the model, in degrees. | 
void goo_canvas_item_model_animate (GooCanvasItemModel *model,gdouble x,gdouble y,gdouble scale,gdouble degrees,gboolean absolute,gint duration,gint step_time,GooCanvasAnimateType type);
Animates a model from its current position to the given offsets, scale and rotation.
| 
 | an item model. | 
| 
 | the final x coordinate. | 
| 
 | the final y coordinate. | 
| 
 | the final scale. | 
| 
 | the final rotation. This can be negative to rotate anticlockwise, and can also be greater than 360 to rotate a number of times. | 
| 
 | if the x,y,scaleanddegreesvalues are absolute, or
relative to the current transform. Note that absolute animations only work
if the model currently has a simple transform. If the model has a shear or
some other complicated transform it may result in strange animations. | 
| 
 | the duration of the animation, in milliseconds (1/1000ths of a second). | 
| 
 | the time between each animation step, in milliseconds. | 
| 
 | specifies what happens when the animation finishes. | 
void                goo_canvas_item_model_stop_animation
                                                        (GooCanvasItemModel *model);
Stops any current animation for the given model, leaving it at its current position.
| 
 | an item model. | 
void goo_canvas_item_model_raise (GooCanvasItemModel *model,GooCanvasItemModel *above);
Raises a model in the stacking order.
| 
 | an item model. | 
| 
 | the item model to raise modelabove, orNULLto raisemodelto the top
of the stack. | 
void goo_canvas_item_model_lower (GooCanvasItemModel *model,GooCanvasItemModel *below);
Lowers a model in the stacking order.
| 
 | an item model. | 
| 
 | the item model to lower modelbelow, orNULLto lowermodelto the
bottom of the stack. | 
void                goo_canvas_item_model_remove        (GooCanvasItemModel *model);
Removes a model from its parent. If the model is in a canvas it will be removed.
This would normally also result in the model being freed.
| 
 | an item model. | 
GooCanvasItemModel * goo_canvas_item_model_get_parent   (GooCanvasItemModel *model);
Gets the parent of the given model.
| 
 | an item model. | 
| Returns : | the parent model, or NULLif the model has no parent. [transfer none] | 
void goo_canvas_item_model_set_parent (GooCanvasItemModel *model,GooCanvasItemModel *parent);
This function is only intended to be used when implementing new canvas item models (specifically container models such as GooCanvasGroupModel). It sets the parent of the child model.
| 
 | an item model. | 
| 
 | the new parent item model. | 
This function cannot be used to add a model to a group or to change the parent of a model. To do that use the "parent" property.
gboolean            goo_canvas_item_model_is_container  (GooCanvasItemModel *model);
Tests to see if the given item model is a container.
| 
 | an item model. | 
| Returns : | TRUEif the item model is a container. | 
gint                goo_canvas_item_model_get_n_children
                                                        (GooCanvasItemModel *model);
Gets the number of children of the container.
| 
 | an item model. | 
| Returns : | the number of children. | 
GooCanvasItemModel * goo_canvas_item_model_get_child (GooCanvasItemModel *model,gint child_num);
Gets the child at the given stack position.
| 
 | an item model. | 
| 
 | the position of a child in the container's stack. | 
| Returns : | the child at the given stack position, or NULLifchild_numis out of range. [transfer none] | 
void goo_canvas_item_model_add_child (GooCanvasItemModel *model,GooCanvasItemModel *child,gint position);
Adds a child at the given stack position.
| 
 | an item model. | 
| 
 | the child to add. | 
| 
 | the position of the child, or -1 to place it last (at the top of the stacking order). | 
void goo_canvas_item_model_move_child (GooCanvasItemModel *model,gint old_position,gint new_position);
Moves a child to a new stack position.
| 
 | an item model. | 
| 
 | the current position of the child. | 
| 
 | the new position of the child. | 
void goo_canvas_item_model_remove_child (GooCanvasItemModel *model,gint child_num);
Removes the child at the given position.
| 
 | an item model. | 
| 
 | the position of the child to remove. | 
gint goo_canvas_item_model_find_child (GooCanvasItemModel *model,GooCanvasItemModel *child);
Attempts to find the given child with the container's stack.
| 
 | an item model. | 
| 
 | the child to find. | 
| Returns : | the position of the given child, or -1 if it isn't found. | 
GooCanvasStyle *    goo_canvas_item_model_get_style     (GooCanvasItemModel *model);
Gets the model's style. If the model doesn't have its own style it will return its parent's style.
| 
 | an item model. | 
| Returns : | the model's style. [transfer none] | 
void goo_canvas_item_model_set_style (GooCanvasItemModel *model,GooCanvasStyle *style);
Sets the model's style, by copying the properties from the given style.
| 
 | an item model. | 
| 
 | a style. | 
void goo_canvas_item_model_class_install_child_property (GObjectClass *mclass,guint property_id,GParamSpec *pspec);
This function is only intended to be used when implementing new canvas item models, specifically layout container item models such as GooCanvasTableModel.
It installs a child property on a canvas item class.
| 
 | a GObjectClass | 
| 
 | the id for the property | 
| 
 | the GParamSpec for the property | 
GParamSpec ** goo_canvas_item_model_class_list_child_properties (GObjectClass *mclass,guint *n_properties);
This function is only intended to be used when implementing new canvas item models, specifically layout container item models such as GooCanvasTableModel.
It returns all child properties of a canvas item class.
| 
 | a GObjectClass | 
| 
 | location to return the number of child properties found | 
| Returns : | a newly allocated array of GParamSpec*. The array must be freed with g_free(). [array length=n_properties][element-type GLib.ParamSpec][transfer container] | 
GParamSpec * goo_canvas_item_model_class_find_child_property (GObjectClass *mclass,const gchar *property_name);
This function is only intended to be used when implementing new canvas item models, specifically layout container item models such as GooCanvasTableModel.
It finds a child property of a canvas item class by name.
| 
 | a GObjectClass | 
| 
 | the name of the child property to find | 
| Returns : | The GParamSpec of the child
property or NULLifclasshas no child property with that name. [type GLib.ParamSpec][transfer none] | 
void goo_canvas_item_model_get_child_property (GooCanvasItemModel *model,GooCanvasItemModel *child,const gchar *property_name,GValue *value);
Gets a child property of child.
| 
 | a GooCanvasItemModel. | 
| 
 | a child GooCanvasItemModel. | 
| 
 | the name of the child property to get. | 
| 
 | a location to return the value. | 
void goo_canvas_item_model_set_child_property (GooCanvasItemModel *model,GooCanvasItemModel *child,const gchar *property_name,const GValue *value);
Sets a child property of child.
| 
 | a GooCanvasItemModel. | 
| 
 | a child GooCanvasItemModel. | 
| 
 | the name of the child property to set. | 
| 
 | the value to set the property to. | 
void goo_canvas_item_model_get_child_properties (GooCanvasItemModel *model,GooCanvasItemModel *child,...);
Gets the values of one or more child properties of child.
| 
 | a GooCanvasItemModel. | 
| 
 | a child GooCanvasItemModel. | 
| 
 | pairs of property names and value pointers, and a terminating NULL. | 
void goo_canvas_item_model_get_child_properties_valist (GooCanvasItemModel *model,GooCanvasItemModel *child,va_list var_args);
Gets the values of one or more child properties of child.
| 
 | a GooCanvasItemModel. | 
| 
 | a child GooCanvasItemModel. | 
| 
 | pairs of property names and value pointers, and a terminating NULL. | 
void goo_canvas_item_model_set_child_properties (GooCanvasItemModel *model,GooCanvasItemModel *child,...);
Sets the values of one or more child properties of child.
| 
 | a GooCanvasItemModel. | 
| 
 | a child GooCanvasItemModel. | 
| 
 | pairs of property names and values, and a terminating NULL. | 
void goo_canvas_item_model_set_child_properties_valist (GooCanvasItemModel *model,GooCanvasItemModel *child,va_list var_args);
Sets the values of one or more child properties of child.
| 
 | a GooCanvasItemModel. | 
| 
 | a child GooCanvasItemModel. | 
| 
 | pairs of property names and values, and a terminating NULL. | 
"can-focus" property  "can-focus"                gboolean              : Read / Write
If the item can take the keyboard focus.
Default value: FALSE
"description" property  "description"              gchar*                : Read / Write
A description of the item for use by assistive technologies.
Default value: NULL
"pointer-events" property"pointer-events" GooCanvasPointerEvents : Read / Write
Specifies when the item receives pointer events.
Default value: GOO_CANVAS_EVENTS_VISIBLE_MASK|GOO_CANVAS_EVENTS_PAINTED_MASK|GOO_CANVAS_EVENTS_FILL_MASK|GOO_CANVAS_EVENTS_STROKE_MASK
"title" property  "title"                    gchar*                : Read / Write
A short context-rich description of the item for use by assistive technologies.
Default value: NULL
"tooltip" property  "tooltip"                  gchar*                : Read / Write
The tooltip to display for the item.
Default value: NULL
"transform" property"transform" GooCairoMatrix* : Read / Write
The transformation matrix of the item.
"visibility" property"visibility" GooCanvasItemVisibility : Read / Write
When the canvas item is visible.
Default value: GOO_CANVAS_ITEM_VISIBLE
"animation-finished" signalvoid                user_function                      (GooCanvasItemModel *item,
                                                        gboolean            stopped,
                                                        gpointer            user_data)      : Run Last
Emitted when the item model animation has finished.
| 
 | the item model that received the signal. | 
| 
 | if the animation was explicitly stopped. | 
| 
 | user data set when the signal handler was connected. | 
"changed" signalvoid                user_function                      (GooCanvasItemModel *model,
                                                        gboolean            recompute_bounds,
                                                        gpointer            user_data)             : Run Last
Emitted when the item model has been changed.
| 
 | the item model that received the signal. | 
| 
 | if the bounds of the item need to be recomputed. | 
| 
 | user data set when the signal handler was connected. | 
"child-added" signalvoid                user_function                      (GooCanvasItemModel *model,
                                                        gint                child_num,
                                                        gpointer            user_data)      : Run Last
Emitted when a child has been added.
| 
 | the item model that received the signal. | 
| 
 | the index of the new child. | 
| 
 | user data set when the signal handler was connected. | 
"child-moved" signalvoid                user_function                      (GooCanvasItemModel *model,
                                                        gint                old_child_num,
                                                        gint                new_child_num,
                                                        gpointer            user_data)          : Run Last
Emitted when a child has been moved in the stacking order.
| 
 | the item model that received the signal. | 
| 
 | the old index of the child. | 
| 
 | the new index of the child. | 
| 
 | user data set when the signal handler was connected. | 
"child-notify" signalvoid                user_function                      (GooCanvasItemModel *item,
                                                        GParamSpec         *pspec,
                                                        gpointer            user_data)      : No Hooks
Emitted for each child property that has changed. The signal's detail holds the property name.
| 
 | the item model that received the signal. | 
| 
 | the GParamSpec of the changed child property. [type GLib.ParamSpec] | 
| 
 | user data set when the signal handler was connected. | 
"child-removed" signalvoid                user_function                      (GooCanvasItemModel *model,
                                                        gint                child_num,
                                                        gpointer            user_data)      : Run Last
Emitted when a child has been removed.
| 
 | the item model that received the signal. | 
| 
 | the index of the child that was removed. | 
| 
 | user data set when the signal handler was connected. |