use LaTeX::TikZ::Set::Point;
+use LaTeX::TikZ::Interface;
use LaTeX::TikZ::Functor;
use Any::Moose;
+=head1 RELATIONSHIPS
+
+This class consumes the L<LaTeX::TikZ::Set::Op> role, and as such implements the L</path> method.
+
+=cut
+
with 'LaTeX::TikZ::Set::Op';
+=head1 ATTRIBUTES
+
+=head2 C<from>
+
+The first corner of the rectangle, as a L<LaTeX::TikZ::Set::Point> object.
+
+=cut
+
has 'from' => (
is => 'ro',
isa => 'LaTeX::TikZ::Set::Point',
coerce => 1,
);
+=head2 C<to>
+
+The opposite endpoint of the rectangle, also as a L<LaTeX::TikZ::Set::Point> object.
+
+=cut
+
has 'to' => (
is => 'ro',
isa => 'LaTeX::TikZ::Set::Point',
coerce => 1,
);
+=head2 C<width>
+
+The algebraic width of the rectangle.
+
+=cut
+
has 'width' => (
is => 'ro',
isa => 'Num',
);
+=head2 C<height>
+
+The algebraic height of the rectangle.
+
+=cut
+
has 'height' => (
is => 'ro',
isa => 'Num',
);
+=head1 METHODS
+
+=head2 C<path>
+
+=cut
+
sub path {
my $set = shift;
my $class = shift;
if (@_ == 2 and $tc1->check($_[0]) and $tc2->check($_[1])) {
+ my ($from, $to) = @_;
@_ = (
- from => $_[0],
- to => $_[1],
+ from => $from,
+ to => $to,
+ width => $to->x - $from->x,
+ height => $to->y - $from->y,
);
} else {
my %args = @_;
$class->$orig(@_);
};
-use LaTeX::TikZ::Interface rectangle => sub {
- shift;
- my ($p, $q) = @_;
+LaTeX::TikZ::Interface->register(
+ rectangle => sub {
+ shift;
+ my ($p, $q) = @_;
- my $is_relative = !blessed($q) && ref($q) eq 'HASH';
+ my $is_relative = !blessed($q) && ref($q) eq 'HASH';
- __PACKAGE__->new(
- from => $p,
- ($is_relative ? (map +($_ => $q->{$_}), qw/width height/) : (to => $q)),
- );
-};
+ __PACKAGE__->new(
+ from => $p,
+ ($is_relative ? (map +($_ => $q->{$_}), qw/width height/) : (to => $q)),
+ );
+ },
+);
LaTeX::TikZ::Functor->default_rule(
(__PACKAGE__) => sub {
__PACKAGE__->meta->make_immutable;
+=head1 SEE ALSO
+
+L<LaTeX::TikZ>, L<LaTeX::TikZ::Set::Op>.
+
=head1 AUTHOR
Vincent Pit, C<< <perl at profvince.com> >>, L<http://www.profvince.com>.