tzh
2024-08-22 c7d0944258c7d0943aa7b2211498fd612971ce27
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";