|  |  |  | GooCanvas Reference Manual | |
|---|---|---|---|---|
| Top | Description | ||||
GooCanvasBounds; enum GooCanvasItemVisibility; enum GooCanvasPointerEvents; enum GooCanvasAnimateType; GooCanvasPoints; GooCanvasPoints* goo_canvas_points_new (int num_points); GooCanvasPoints* goo_canvas_points_ref (GooCanvasPoints *points); void goo_canvas_points_unref (GooCanvasPoints *points); GooCanvasLineDash; GooCanvasLineDash* goo_canvas_line_dash_new (gint num_dashes,...); GooCanvasLineDash* goo_canvas_line_dash_newv (gint num_dashes,double *dashes); GooCanvasLineDash* goo_canvas_line_dash_ref (GooCanvasLineDash *dash); void goo_canvas_line_dash_unref (GooCanvasLineDash *dash); enum GooCanvasPathCommandType; union GooCanvasPathCommand; GArray* goo_canvas_parse_path_data (const gchar *path_data); void goo_canvas_create_path (GArray *commands,cairo_t *cr); typedef GooCairoAntialias; typedef GooCairoFillRule; typedef GooCairoHintMetrics; typedef GooCairoLineCap; typedef GooCairoLineJoin; typedef GooCairoOperator; typedef GooCairoMatrix; typedef GooCairoPattern;
typedef struct {
  gdouble x1, y1, x2, y2;
} GooCanvasBounds;
GooCanvasBounds represents the bounding box of an item in the canvas.
typedef enum
{
  GOO_CANVAS_ITEM_HIDDEN			= 0,
  GOO_CANVAS_ITEM_INVISIBLE			= 1,
  GOO_CANVAS_ITEM_VISIBLE			= 2,
  GOO_CANVAS_ITEM_VISIBLE_ABOVE_THRESHOLD = 3
} GooCanvasItemVisibility;
The GooCanvasItemVisibility enumeration is used to specify when a canvas item is visible.
| the item is invisible, and is not allocated any space in layout container items such as GooCanvasTable. | |
| the item is invisible, but it is still allocated space in layout container items. | |
| the item is visible. | |
| the item is visible when the canvas scale setting is greater than or equal to the item's visibility threshold setting. | 
typedef enum
{
  GOO_CANVAS_EVENTS_VISIBLE_MASK = 1 << 0,
  GOO_CANVAS_EVENTS_PAINTED_MASK = 1 << 1,
  GOO_CANVAS_EVENTS_FILL_MASK		= 1 << 2,
  GOO_CANVAS_EVENTS_STROKE_MASK		= 1 << 3,
  GOO_CANVAS_EVENTS_NONE		= 0,
  GOO_CANVAS_EVENTS_VISIBLE_PAINTED = GOO_CANVAS_EVENTS_VISIBLE_MASK | GOO_CANVAS_EVENTS_PAINTED_MASK | GOO_CANVAS_EVENTS_FILL_MASK | GOO_CANVAS_EVENTS_STROKE_MASK,
  GOO_CANVAS_EVENTS_VISIBLE_FILL = GOO_CANVAS_EVENTS_VISIBLE_MASK | GOO_CANVAS_EVENTS_FILL_MASK,
  GOO_CANVAS_EVENTS_VISIBLE_STROKE = GOO_CANVAS_EVENTS_VISIBLE_MASK | GOO_CANVAS_EVENTS_STROKE_MASK,
  GOO_CANVAS_EVENTS_VISIBLE		= GOO_CANVAS_EVENTS_VISIBLE_MASK | GOO_CANVAS_EVENTS_FILL_MASK | GOO_CANVAS_EVENTS_STROKE_MASK,
  GOO_CANVAS_EVENTS_PAINTED		= GOO_CANVAS_EVENTS_PAINTED_MASK | GOO_CANVAS_EVENTS_FILL_MASK | GOO_CANVAS_EVENTS_STROKE_MASK,
  GOO_CANVAS_EVENTS_FILL		= GOO_CANVAS_EVENTS_FILL_MASK,
  GOO_CANVAS_EVENTS_STROKE		= GOO_CANVAS_EVENTS_STROKE_MASK,
  GOO_CANVAS_EVENTS_ALL			= GOO_CANVAS_EVENTS_FILL_MASK | GOO_CANVAS_EVENTS_STROKE_MASK
} GooCanvasPointerEvents;
Specifies when an item receives pointer events such as mouse clicks.
| a mask indicating that the item only receives events when it is visible. | |
| a mask indicating that the item only receives events when the specified parts of it are painted. | |
| a mask indicating that the filled part of the item receives events. | |
| a mask indicating that the stroked part of the item receives events. | |
| the item doesn't receive events at all. | |
| the item receives events in its painted areas when it is visible (the default). | |
| the item's interior receives events when it is visible. | |
| the item's perimeter receives events when it is visible. | |
| the item receives events when it is visible, whether it is painted or not. | |
| the item receives events in its painted areas, whether it is visible or not. | |
| the item's interior receives events, whether it is visible or painted or not. | |
| the item's perimeter receives events, whether it is visible or painted or not. | |
| the item's perimeter and interior receive events, whether it is visible or painted or not. | 
typedef enum
{
  GOO_CANVAS_ANIMATE_FREEZE,
  GOO_CANVAS_ANIMATE_RESET,
  GOO_CANVAS_ANIMATE_RESTART,
  GOO_CANVAS_ANIMATE_BOUNCE
} GooCanvasAnimateType;
GooCanvasAnimateType is used to specify what happens when the end of an animation is reached.
| the item remains in the final position. | |
| the item is moved back to the initial position. | |
| the animation is restarted from the initial position. | |
| the animation bounces back and forth between the start and end positions. | 
typedef struct {
  double *coords;
  int num_points;
  int ref_count;
} GooCanvasPoints;
GooCairoPoints represents an array of points.
GooCanvasPoints*    goo_canvas_points_new               (int num_points);
Creates a new GooCanvasPoints struct with space for the given number of
points. It should be freed with goo_canvas_points_unref().
| 
 | the number of points to create space for. | 
| Returns : | a new GooCanvasPoints struct. | 
GooCanvasPoints*    goo_canvas_points_ref               (GooCanvasPoints *points);
Increments the reference count of the given GooCanvasPoints struct.
| 
 | a GooCanvasPoints struct. | 
| Returns : | the GooCanvasPoints struct. | 
void                goo_canvas_points_unref             (GooCanvasPoints *points);
Decrements the reference count of the given GooCanvasPoints struct, freeing it if the reference count falls to zero.
| 
 | a GooCanvasPoints struct. | 
typedef struct {
  int ref_count;
  int num_dashes;
  double *dashes;
  double dash_offset;
} GooCanvasLineDash;
GooCanvasLineDash specifies a dash pattern to be used when drawing items.
GooCanvasLineDash* goo_canvas_line_dash_new (gint num_dashes,...);
Creates a new dash pattern.
| 
 | the number of dashes and gaps in the pattern. | 
| 
 | the length of each dash and gap. | 
| Returns : | a new dash pattern. | 
GooCanvasLineDash* goo_canvas_line_dash_newv (gint num_dashes,double *dashes);
Creates a new dash pattern.  Takes ownership of the dashes vector.
| 
 | the number of dashes and gaps in the pattern. | 
| 
 | a g_new-allocated vector of doubles, the length of each dash and gap. | 
| Returns : | a new dash pattern. | 
GooCanvasLineDash*  goo_canvas_line_dash_ref            (GooCanvasLineDash *dash);
Increments the reference count of the dash pattern.
| 
 | a GooCanvasLineDash. | 
| Returns : | the dash pattern. | 
void                goo_canvas_line_dash_unref          (GooCanvasLineDash *dash);
Decrements the reference count of the dash pattern. If it falls to 0 it is freed.
| 
 | a GooCanvasLineDash. | 
typedef enum
{
  /* Simple commands like moveto and lineto: MmZzLlHhVv. */
  GOO_CANVAS_PATH_MOVE_TO,
  GOO_CANVAS_PATH_CLOSE_PATH,
  GOO_CANVAS_PATH_LINE_TO,
  GOO_CANVAS_PATH_HORIZONTAL_LINE_TO,
  GOO_CANVAS_PATH_VERTICAL_LINE_TO,
  /* Bezier curve commands: CcSsQqTt. */
  GOO_CANVAS_PATH_CURVE_TO,
  GOO_CANVAS_PATH_SMOOTH_CURVE_TO,
  GOO_CANVAS_PATH_QUADRATIC_CURVE_TO,
  GOO_CANVAS_PATH_SMOOTH_QUADRATIC_CURVE_TO,
  /* The elliptical arc commands: Aa. */
  GOO_CANVAS_PATH_ELLIPTICAL_ARC
} GooCanvasPathCommandType;
GooCanvasPathCommandType specifies the type of each command in the path. See the path element in the Scalable Vector Graphics (SVG) specification for more details.
| move to the given point. | |
| close the current path, drawing a line from the current position to the start of the path. | |
| draw a line to the given point. | |
| draw a horizontal line to the given x coordinate. | |
| draw a vertical line to the given y coordinate. | |
| draw a bezier curve using two control points to the given point. | |
| draw a bezier curve using a reflection of the last control point of the last curve as the first control point, and one new control point, to the given point. | |
| draw a quadratic bezier curve using a single control point to the given point. | |
| draw a quadratic bezier curve using a reflection of the control point from the previous curve as the control point, to the given point. | |
| draw an elliptical arc, using the given 2 radii, the x axis rotation, and the 2 flags to disambiguate the arc, to the given point. | 
GooCanvasPathCommand holds the data for each command in the path.
The relative flag specifies that the coordinates for the command are
relative to the current point. Otherwise they are assumed to be absolute
coordinates.
GArray*             goo_canvas_parse_path_data          (const gchar *path_data);
Parses the given SVG path specification string.
| 
 | the sequence of path commands, specified as a string using the same syntax as in the Scalable Vector Graphics (SVG) path element. | 
| Returns : | a GArray of GooCanvasPathCommand elements. | 
void goo_canvas_create_path (GArray *commands,cairo_t *cr);
Creates the path specified by the given GooCanvasPathCommand array.
| 
 | an array of GooCanvasPathCommand. | 
| 
 | a cairo context. | 
typedef cairo_antialias_t GooCairoAntialias;
GooCairoAntialias is simply a wrapper for the cairo_antialias_t type, allowing it to be used for GObject properties.
See the cairo_antialias_t documentation.
typedef cairo_fill_rule_t GooCairoFillRule;
GooCairoFillRule is simply a wrapper for the cairo_fill_rule_t type, allowing it to be used for GObject properties.
See the cairo_fill_rule_t documentation.
typedef cairo_hint_metrics_t GooCairoHintMetrics;
GooCairoHintMetrics is simply a wrapper for the cairo_hint_metrics_t type, allowing it to be used for GObject properties.
See the cairo_hint_metrics_t documentation.
typedef cairo_line_cap_t GooCairoLineCap;
GooCairoLineCap is simply a wrapper for the cairo_line_cap_t type, allowing it to be used for GObject properties.
See the cairo_line_cap_t documentation.
typedef cairo_line_join_t GooCairoLineJoin;
GooCairoLineJoin is simply a wrapper for the cairo_line_join_t type, allowing it to be used for GObject properties.
See the cairo_line_join_t documentation.
typedef cairo_operator_t GooCairoOperator;
GooCairoOperator is simply a wrapper for the cairo_operator_t type, allowing it to be used for GObject properties.
See the cairo_operator_t documentation.
typedef cairo_matrix_t GooCairoMatrix;
GooCairoMatrix is simply a wrapper for the cairo_matrix_t type, allowing it to be used for GObject properties.
See the cairo_matrix_t documentation.
typedef cairo_pattern_t GooCairoPattern;
GooCairoPattern is simply a wrapper for the cairo_pattern_t type, allowing it to be used for GObject properties.
See the cairo_pattern_t documentation.