|  |  |  | GooCanvas Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | Implemented Interfaces | Properties | ||||
GooCanvasItemSimple; GooCanvasItemSimpleData; GooCanvasItemSimpleClass; void goo_canvas_item_simple_check_style (GooCanvasItemSimple *item); gdouble goo_canvas_item_simple_get_line_width (GooCanvasItemSimple *item); void goo_canvas_item_simple_get_path_bounds (GooCanvasItemSimple *item,cairo_t *cr,GooCanvasBounds *bounds); void goo_canvas_item_simple_user_bounds_to_device (GooCanvasItemSimple *item,cairo_t *cr,GooCanvasBounds *bounds); void goo_canvas_item_simple_user_bounds_to_parent (GooCanvasItemSimple *item,cairo_t *cr,GooCanvasBounds *bounds); gboolean goo_canvas_item_simple_check_in_path (GooCanvasItemSimple *item,gdouble x,gdouble y,cairo_t *cr,GooCanvasPointerEvents pointer_events); void goo_canvas_item_simple_paint_path (GooCanvasItemSimple *item,cairo_t *cr); void goo_canvas_item_simple_changed (GooCanvasItemSimple *item,gboolean recompute_bounds); void goo_canvas_item_simple_set_model (GooCanvasItemSimple *item,GooCanvasItemModel *model);
  GObject
   +----GooCanvasItemSimple
         +----GooCanvasWidget
         +----GooCanvasRect
         +----GooCanvasGroup
         +----GooCanvasPath
         +----GooCanvasEllipse
         +----GooCanvasText
         +----GooCanvasPolyline
         +----GooCanvasImage
         +----GooCanvasGrid
"antialias" GooCairoAntialias : Read / Write "clip-fill-rule" GooCairoFillRule : Read / Write "clip-path" gchar* : Write "fill-color" gchar* : Write "fill-color-rgba" guint : Read / Write "fill-pattern" GooCairoPattern* : Read / Write "fill-pixbuf" GdkPixbuf* : Write "fill-rule" GooCairoFillRule : Read / Write "font" gchar* : Read / Write "font-desc" PangoFontDescription* : Read / Write "hint-metrics" GooCairoHintMetrics : Read / Write "line-cap" GooCairoLineCap : Read / Write "line-dash" GooCanvasLineDash* : Read / Write "line-join" GooCairoLineJoin : Read / Write "line-join-miter-limit" gdouble : Read / Write "line-width" gdouble : Read / Write "operator" GooCairoOperator : Read / Write "stroke-color" gchar* : Write "stroke-color-rgba" guint : Read / Write "stroke-pattern" GooCairoPattern* : Read / Write "stroke-pixbuf" GdkPixbuf* : Write
GooCanvasItemSimple is used as a base class for all of the standard canvas items. It can also be used as the base class for new custom canvas items.
It provides default implementations for many of the GooCanvasItem methods.
For very simple items, all that is needed is to implement the create_path()
method. (GooCanvasEllipse, GooCanvasRect and GooCanvasPath do this.)
More complicated items need to implement the update(), paint() and
is_item_at() methods instead. (GooCanvasImage, GooCanvasPolyline,
GooCanvasText and GooCanvasWidget do this.) They may also need to
override some of the other GooCanvasItem methods such as set_canvas(),
set_parent() or allocate_area() if special code is needed. (GooCanvasWidget
does this to make sure the GtkWidget is embedded in the GooCanvas widget
correctly.)
typedef struct {
  GooCanvas *canvas;
  GooCanvasItem *parent;
  GooCanvasItemModelSimple *model;
  GooCanvasItemSimpleData *simple_data;
  GooCanvasBounds bounds;
  guint need_update			: 1;
  guint need_entire_subtree_update      : 1;
} GooCanvasItemSimple;
The GooCanvasItemSimple struct contains the basic data needed to implement canvas items.
| GooCanvas * | the canvas. | 
| GooCanvasItem * | the parent item. | 
| GooCanvasItemModelSimple * | the item's model, if it has one. | 
| GooCanvasItemSimpleData * | data that is common to both the model and view classes. If the canvas item has a model, this will point to the model's GooCanvasItemSimpleData, otherwise the canvas item will have its own GooCanvasItemSimpleData. | 
| GooCanvasBounds  | the bounds of the item, in device space. | 
| if the item needs to recompute its bounds and redraw. | |
| if all descendants need to be updated. | 
typedef struct {
  GooCanvasStyle *style;
  cairo_matrix_t *transform;
  GArray *clip_path_commands;
  gchar *tooltip;
  gdouble visibility_threshold;
  guint visibility			: 2;
  guint pointer_events			: 4;
  guint can_focus                       : 1;
  guint own_style                       : 1;
  guint clip_fill_rule			: 4;
  guint is_static			: 1;
} GooCanvasItemSimpleData;
This is the data common to both the model and view classes.
| GooCanvasStyle * | the style to draw with. | 
| cairo_matrix_t * | the transformation matrix of the item, or NULL. | 
| an array of GooCanvasPathCommand specifying the clip
 path of the item, or NULL. | |
| the item's tooltip. | |
| the threshold scale setting at which to show the item
 (if the visibilitysetting is set toVISIBLE_ABOVE_THRESHOLD). | |
| the GooCanvasItemVisibility setting specifying whether the item is visible, invisible, or visible above a given canvas scale setting. | |
| the GooCanvasPointerEvents setting specifying the events the item should receive. | |
| if the item can take the keyboard focus. | |
| if the item has its own style, rather than using its parent's. | |
| the cairo_fill_rule_t setting specifying the fill rule used for the clip path. | |
| if the item is static. | 
typedef struct {
  void		 (* simple_create_path) (GooCanvasItemSimple   *simple,
					 cairo_t               *cr);
  void           (* simple_update) (GooCanvasItemSimple   *simple,
					 cairo_t               *cr);
  void           (* simple_paint) (GooCanvasItemSimple   *simple,
					 cairo_t               *cr,
					 const GooCanvasBounds *bounds);
  gboolean       (* simple_is_item_at)  (GooCanvasItemSimple   *simple,
					 gdouble                x,
					 gdouble                y,
					 cairo_t               *cr,
					 gboolean               is_pointer_event);
} GooCanvasItemSimpleClass;
The GooCanvasItemSimpleClass struct contains several methods that subclasses can override.
Simple items need only implement the create_path() method. More complex
items must override the update(), paint() and is_item_at() methods instead.
| simple subclasses that draw basic shapes and paths only
 need to override this one method. It creates the path for the item.
 All updating, painting and hit-testing is provided automatically by the
 GooCanvasItemSimple class. (This method is used by the builtin
 GooCanvasEllipse, GooCanvasRect and GooCanvasPath items.)
 More complicated subclasses must override simple_update,simple_paintandsimple_is_item_atinstead. | |
| subclasses should override this to calculate their new bounds, in user space. | |
| subclasses should override this to paint their item. | |
| subclasses should override this to do hit-testing. | 
void                goo_canvas_item_simple_check_style  (GooCanvasItemSimple *item);
This function is intended to be used by subclasses of GooCanvasItemSimple,
typically in their update() or get_requested_area() methods.
It ensures that the item's style is setup correctly. If the item has its own GooCanvasStyle it makes sure the parent is set correctly. If it doesn't have its own style it uses the parent item's style.
| 
 | a GooCanvasItemSimple. | 
gdouble             goo_canvas_item_simple_get_line_width
                                                        (GooCanvasItemSimple *item);
Gets the item's line width.
| 
 | a GooCanvasItemSimple. | 
| Returns : | the item's line width. | 
void goo_canvas_item_simple_get_path_bounds (GooCanvasItemSimple *item,cairo_t *cr,GooCanvasBounds *bounds);
This function is intended to be used by subclasses of GooCanvasItemSimple,
typically in their update() or get_requested_area() methods.
It calculates the bounds of the current path, using the item's style settings, and stores the results in the given GooCanvasBounds struct.
The returned bounds contains the bounding box of the path in device space,
converted to user space coordinates. To calculate the bounds completely in
user space, use cairo_identity_matrix() to temporarily reset the current
transformation matrix to the identity matrix.
| 
 | a GooCanvasItemSimple. | 
| 
 | a cairo context. | 
| 
 | the GooCanvasBounds struct to store the resulting bounding box. | 
void goo_canvas_item_simple_user_bounds_to_device (GooCanvasItemSimple *item,cairo_t *cr,GooCanvasBounds *bounds);
This function is intended to be used by subclasses of GooCanvasItemSimple,
typically in their update() or get_requested_area() methods.
It converts the item's bounds to a bounding box in the canvas (device) coordinate space.
| 
 | a GooCanvasItemSimple. | 
| 
 | a cairo context. | 
| 
 | the bounds of the item, in the item's coordinate space. | 
void goo_canvas_item_simple_user_bounds_to_parent (GooCanvasItemSimple *item,cairo_t *cr,GooCanvasBounds *bounds);
This function is intended to be used by subclasses of GooCanvasItemSimple,
typically in their get_requested_area() method.
It converts the item's bounds to a bounding box in its parent's coordinate space. If the item has no transformation matrix set then no conversion is needed.
| 
 | a GooCanvasItemSimple. | 
| 
 | a cairo context. | 
| 
 | the bounds of the item, in the item's coordinate space. | 
gboolean goo_canvas_item_simple_check_in_path (GooCanvasItemSimple *item,gdouble x,gdouble y,cairo_t *cr,GooCanvasPointerEvents pointer_events);
This function is intended to be used by subclasses of GooCanvasItemSimple.
It checks if the given point is in the current path, using the item's style settings.
| 
 | a GooCanvasItemSimple. | 
| 
 | the x coordinate of the point. | 
| 
 | the y coordinate of the point. | 
| 
 | a cairo context. | 
| 
 | specifies which parts of the path to check. | 
| Returns : | TRUEif the given point is in the current path. | 
void goo_canvas_item_simple_paint_path (GooCanvasItemSimple *item,cairo_t *cr);
This function is intended to be used by subclasses of GooCanvasItemSimple.
It paints the current path, using the item's style settings.
| 
 | a GooCanvasItemSimple. | 
| 
 | a cairo context. | 
void goo_canvas_item_simple_changed (GooCanvasItemSimple *item,gboolean recompute_bounds);
This function is intended to be used by subclasses of GooCanvasItemSimple.
It is used as a callback for the "changed" signal of the item models. It requests an update or redraw of the item as appropriate.
| 
 | a GooCanvasItemSimple. | 
| 
 | if the item's bounds need to be recomputed. | 
void goo_canvas_item_simple_set_model (GooCanvasItemSimple *item,GooCanvasItemModel *model);
This function should be called by subclasses of GooCanvasItemSimple
in their set_model() method.
| 
 | a GooCanvasItemSimple. | 
| 
 | the model that itemwill view. | 
"antialias" property"antialias" GooCairoAntialias : Read / Write
The antialiasing mode to use.
Default value: CAIRO_ANTIALIAS_GRAY
"clip-fill-rule" property"clip-fill-rule" GooCairoFillRule : Read / Write
The fill rule used to determine which parts of the item are clipped.
Default value: CAIRO_FILL_RULE_WINDING
"clip-path" property  "clip-path"                gchar*                : Write
The sequence of commands describing the clip path of the item, specified as a string using the same syntax as in the Scalable Vector Graphics (SVG) path element.
Default value: NULL
"fill-color" property  "fill-color"               gchar*                : Write
The color to use to paint the interior of the item. To disable painting set the 'fill-pattern' property to NULL.
Default value: NULL
"fill-color-rgba" property  "fill-color-rgba"          guint                 : Read / Write
The color to use to paint the interior of the item, specified as a 32-bit integer value. To disable painting set the 'fill-pattern' property to NULL.
Default value: 0
"fill-pattern" property"fill-pattern" GooCairoPattern* : Read / Write
The pattern to use to paint the interior of the item, or NULL to disable painting.
"fill-pixbuf" property  "fill-pixbuf"              GdkPixbuf*            : Write
The pixbuf to use to paint the interior of the item. To disable painting set the 'fill-pattern' property to NULL.
"fill-rule" property"fill-rule" GooCairoFillRule : Read / Write
The fill rule used to determine which parts of the item are filled.
Default value: CAIRO_FILL_RULE_WINDING
"font" property  "font"                     gchar*                : Read / Write
The base font to use for the text.
Default value: NULL
"font-desc" property  "font-desc"                PangoFontDescription*  : Read / Write
The attributes specifying which font to use.
"hint-metrics" property"hint-metrics" GooCairoHintMetrics : Read / Write
The hinting to be used for font metrics.
Default value: CAIRO_HINT_METRICS_OFF
"line-cap" property"line-cap" GooCairoLineCap : Read / Write
The line cap style to use.
Default value: CAIRO_LINE_CAP_BUTT
"line-join" property"line-join" GooCairoLineJoin : Read / Write
The line join style to use.
Default value: CAIRO_LINE_JOIN_MITER
"line-join-miter-limit" property  "line-join-miter-limit"    gdouble               : Read / Write
The smallest angle to use with miter joins, in degrees. Bevel joins will be used below this limit.
Allowed values: >= 0
Default value: 10
"line-width" property  "line-width"               gdouble               : Read / Write
The line width to use for the item's perimeter.
Allowed values: >= 0
Default value: 2
"operator" property"operator" GooCairoOperator : Read / Write
The compositing operator to use.
Default value: CAIRO_OPERATOR_OVER
"stroke-color" property  "stroke-color"             gchar*                : Write
The color to use for the item's perimeter. To disable painting set the 'stroke-pattern' property to NULL.
Default value: NULL
"stroke-color-rgba" property  "stroke-color-rgba"        guint                 : Read / Write
The color to use for the item's perimeter, specified as a 32-bit integer value. To disable painting set the 'stroke-pattern' property to NULL.
Default value: 0
"stroke-pattern" property"stroke-pattern" GooCairoPattern* : Read / Write
The pattern to use to paint the perimeter of the item, or NULL disable painting.