Vertices(3)
abstract base class for graphics defined by a set of
SYNOPSIS
#include <Unidraw/Graphic/verts.h>
DESCRIPTION
Vertices is an abstract base class for graphics such as polygons and
splines whose geometry is specified by a set of coordinate pairs. The
Vertices class supports vertex-related operations common to all such
graphical objects and also supports extent caching.
PUBLIC OPERATIONS
- virtual ~Vertices()
-
The destructor deallocates the list of coordinate pairs stored in the
graphic.
- virtual int GetOriginal(const Coord*& x, const Coord*& y)
-
Return pointers to the arrays of Coords stored internally that define
the graphic's vertices. GetOriginal's return value reflects the size
of the arrays.
- virtual boolean operator == (Vertices&)
-
- virtual boolean operator != (Vertices&)
-
Compare this to the given Vertices instance and return whether
they (do not) store identical sets of vertices.
PROTECTED OPERATIONS
- Vertices(Graphic* = nil)
-
- Vertices(Coord* x, Coord* y, int count, Graphic* = nil)
-
The constructors are protected to disallow instantiation of the
abstract class. Subclasses can pass a set of vertices to copy into
internal storage and an optional graphic from which to obtain an
initial set of graphics state. Vertices itself stores no additional
graphics state over that in the Graphic base class.
- void s_getExtent(
-
- float&, float&, float&, float&, float&, Graphic*
-
- )
-
- void f_getExtent(
-
- float&, float&, float&, float&, float&, Graphic*
-
- )
-
Helper functions that return extent information based on the bounding
box that the vertices define. s_getExtent returns an extent that
accounts for the width of a brush, as would be necessary if the
vertices defined a stroked path, while f_getExtent assumes that the
vertices define the graphic's extremities, as would be the case if the
vertices defined a filled path. These operations cache the extent
they compute initially.