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
|
package
Turtle;
# Written by jreed@itis.com, adapted by Cristy.
sub new
{
my $class = shift;
my $self = {};
@{$self}{qw(x y theta mirror)} = @_;
bless $self, $class;
}
sub forward
{
my $self = shift;
my ($r, $what) = @_;
my ($newx, $newy)=($self->{x}+$r* sin($self->{theta}),
$self->{y}+$r*-cos($self->{theta}));
if ($what) {
&$what($self->{x}, $self->{y}, $newx, $newy); # motion
}
# According to the coderef passed in
($self->{x}, $self->{y})=($newx, $newy); # change the old coords
}
sub turn
{
my $self = shift;
my $dtheta = shift;
$self->{theta} += $dtheta*$self->{mirror};
}
sub state
{
my $self = shift;
@{$self}{qw(x y theta mirror)};
}
sub setstate
{
my $self = shift;
@{$self}{qw(x y theta mirror)} = @_;
}
sub mirror
{
my $self = shift;
$self->{mirror} *= -1;
}
"Turtle.pm";
|