NAME

Graphics::Primitive::Driver - Role for driver implementations

DESCRIPTION

What good is a library agnostic intermediary representation of graphical components if you can't feed them to a library specific implementation that turns them into drawings? Psht, none!

To write a driver for Graphics::Primitive implemeent this role.

SYNOPSIS

my $c = Graphics::Primitive::Component->new({
  origin => Geometry::Primitive::Point->new({
      x => $x, y => $y
  }),
  width => 500, height => 350
});

CANVASES

When a path is added to the internal list via do, it is stored in the paths attribute as a hashref. The hashref has two keys: path and op. The path is, well, the path. The op is the operation provided to do. As canvases are just lists of paths you should consult the next section as well.

PATHS AND HINTING

Paths are lists of primitives. Primitives are all descendants of Geometry::Shape and therefore have point_start and point_end. These two attributes allow the chaining of primitives. To draw a path you should iterate over the primitives, drawing each.

When you pull each path from the arrayref you should pull it's accompanying hints via get_hint (the indexes match). The hint may provide you with additional information:

contiguous

True if this primitive is contiguous with the previous one. Example: Used to determine if a new sub-path is needed for the Cairo driver.

WARNING

Only this class or the driver itself should call methods starting with an underscore, as this interface may change.

METHODS

_do_stroke

Perform a stroke.

_do_fill

Perform a fill.

_draw_canvas

Draw a canvas.

_draw_component

Draw a component.

_draw_line

Draw a line.

_draw_arc

Draw an arc.

_draw_textbox

Draw a textbox.

data

Retrieve the results of this driver's operations.

draw

Draws the given Graphics::Primitive::Component. If the component is a container then all components therein are drawn, recursively.

get_text_bounding_box

Given a Font and a string, returns a bounding box of the rendered text.

write

Write out the results of this driver's operations to the specified file.

AUTHOR

Cory Watson, <gphat@cpan.org>

Infinity Interactive, http://www.iinteractive.com

BUGS

Please report any bugs or feature requests to bug-geometry-primitive at rt.cpan.org, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Geometry-Primitive. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.

COPYRIGHT & LICENSE

Copyright 2008 by Infinity Interactive, Inc.

http://www.iinteractive.com

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.