aboutsummaryrefslogtreecommitdiffstats
path: root/libgnomecanvas/gnome-canvas-shape.h
blob: dcd1c01305e1dc059ca9e7cc47f8150424490c78 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
/* Generic bezier shape item for GnomeCanvas
 *
 * GnomeCanvas is basically a port of the Tk toolkit's most excellent canvas widget.  Tk is
 * copyrighted by the Regents of the University of California, Sun Microsystems, and other parties.
 *
 * Copyright (C) 1998,1999 The Free Software Foundation
 *
 * Authors: Federico Mena <federico@nuclecu.unam.mx>
 *          Raph Levien <raph@acm.org>
 *          Lauris Kaplinski <lauris@ximian.com>
 *          Rusty Conover <rconover@bangtail.net>
 */

#ifndef GNOME_CANVAS_SHAPE_H
#define GNOME_CANVAS_SHAPE_H

#include <libgnomecanvas/gnome-canvas.h>
#include <libgnomecanvas/gnome-canvas-path-def.h>

G_BEGIN_DECLS

/* Shape item for the canvas.
 *
 * The following object arguments are available:
 *
 * name         type            read/write  description
 * ------------------------------------------------------------------------------------------
 * fill_color       string          W       X color specification for fill color,
 *                              or NULL pointer for no color (transparent).
 * fill_color_gdk   GdkColor*       RW      Allocated GdkColor for fill.
 * outline_color    string          W       X color specification for outline color,
 *                              or NULL pointer for no color (transparent).
 * outline_color_gdk    GdkColor*       RW      Allocated GdkColor for outline.
 * width_pixels     uint            RW      Width of the outline in pixels.  The outline will
 *                              not be scaled when the canvas zoom factor is changed.
 * width_units      gdouble         RW      Width of the outline in canvas units.  The outline
 *                              will be scaled when the canvas zoom factor is changed.
 * cap_style        cairo_line_cap_t        RW      Cap ("endpoint") style for the bpath.
 * join_style       cairo_line_join_t   RW      Join ("vertex") style for the bpath.
 * wind                 cairo_fill_rule_t       RW              Winding rule for the bpath.
 * dash         XXX: disabled           RW      Dashing pattern
 * miterlimit       gdouble         RW      Minimum angle between segments, where miter join
 *                              rule is applied.
 */

#define GNOME_TYPE_CANVAS_SHAPE            (gnome_canvas_shape_get_type ())
#define GNOME_CANVAS_SHAPE(obj)            (G_TYPE_CHECK_INSTANCE_CAST ((obj), GNOME_TYPE_CANVAS_SHAPE, GnomeCanvasShape))
#define GNOME_CANVAS_SHAPE_CLASS(klass)    (G_TYPE_CHECK_CLASS_CAST ((klass), GNOME_TYPE_CANVAS_SHAPE, GnomeCanvasShapeClass))
#define GNOME_IS_CANVAS_SHAPE(obj)         (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GNOME_TYPE_CANVAS_SHAPE))
#define GNOME_IS_CANVAS_SHAPE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GNOME_TYPE_CANVAS_SHAPE))

typedef struct _GnomeCanvasShape GnomeCanvasShape;
typedef struct _GnomeCanvasShapePriv GnomeCanvasShapePriv;
typedef struct _GnomeCanvasShapeClass GnomeCanvasShapeClass;

struct _GnomeCanvasShape {
    GnomeCanvasItem item;

    GnomeCanvasShapePriv *priv; /* Private data */
};

struct _GnomeCanvasShapeClass {
    GnomeCanvasItemClass parent_class;
};

/* WARNING! These are not usable from modifying shapes from user programs */
/* These are meant, to set master shape from subclass ::update method */
void gnome_canvas_shape_set_path (GnomeCanvasShape *shape, cairo_path_t *path);
const cairo_path_t *gnome_canvas_shape_get_path (GnomeCanvasShape *shape);

/* Standard Gtk function */
GType gnome_canvas_shape_get_type (void) G_GNUC_CONST;

G_END_DECLS

#endif