| 1 | |
|---|
| 2 | |
|---|
| 3 | |
|---|
| 4 | |
|---|
| 5 | use Image::Magick; |
|---|
| 6 | use Turtle; |
|---|
| 7 | |
|---|
| 8 | sub flower |
|---|
| 9 | { |
|---|
| 10 | my $flower = shift; |
|---|
| 11 | my ($width, $height) = $flower->Get('width', 'height'); |
|---|
| 12 | my ($x, $y) = $turtle->state(); |
|---|
| 13 | my ($geometry); |
|---|
| 14 | |
|---|
| 15 | $geometry = '+' . int($x-$width/2) . '+' . int($y-$height/2); |
|---|
| 16 | $im->Composite(image=>$flower, compose=>'over', geometry=>$geometry); |
|---|
| 17 | } |
|---|
| 18 | |
|---|
| 19 | sub lsys_init |
|---|
| 20 | { |
|---|
| 21 | my ($imagesize) = @_; |
|---|
| 22 | |
|---|
| 23 | %translate = |
|---|
| 24 | ( |
|---|
| 25 | 'S' => sub{ |
|---|
| 26 | $turtle->forward($changes->{"distance"}, |
|---|
| 27 | $changes->{"motionsub"}); |
|---|
| 28 | }, |
|---|
| 29 | '-' => sub{ $turtle->turn(-$changes->{"dtheta"}); }, |
|---|
| 30 | '+' => sub{ $turtle->turn($changes->{"dtheta"}); }, |
|---|
| 31 | 'M' => sub{ $turtle->mirror(); }, |
|---|
| 32 | '[' => sub{ push(@statestack, [$turtle->state()]); }, |
|---|
| 33 | ']' => sub{ $turtle->setstate(@{pop(@statestack)}); }, |
|---|
| 34 | '{' => sub{ @poly = (); $changes=\%polychanges; }, |
|---|
| 35 | '}' => sub{ |
|---|
| 36 | $im->Draw (primitive=>'Polygon', points=>join(' ',@poly), |
|---|
| 37 | fill=>'light green'); |
|---|
| 38 | $changes = \%stemchanges; |
|---|
| 39 | }, |
|---|
| 40 | 'f' => sub{ flower($pink_flower); }, |
|---|
| 41 | 'g' => sub{ flower($red_flower); }, |
|---|
| 42 | 'h' => sub{ flower($yellow_flower); } |
|---|
| 43 | ); |
|---|
| 44 | |
|---|
| 45 | |
|---|
| 46 | $im = new Image::Magick; |
|---|
| 47 | $im->Set(size=>$imagesize . 'x' . $imagesize); |
|---|
| 48 | $im->Read('xc:white'); |
|---|
| 49 | |
|---|
| 50 | |
|---|
| 51 | $pink_flower = new Image::Magick; |
|---|
| 52 | $pink_flower->Read('pink_flower.gif'); |
|---|
| 53 | |
|---|
| 54 | $red_flower = new Image::Magick; |
|---|
| 55 | $red_flower->Read('red_flower.gif'); |
|---|
| 56 | |
|---|
| 57 | $yellow_flower = new Image::Magick; |
|---|
| 58 | $yellow_flower->Read('yellow_flower.gif'); |
|---|
| 59 | |
|---|
| 60 | |
|---|
| 61 | $turtle=new Turtle($imagesize/2, $imagesize, 0, 1); |
|---|
| 62 | } |
|---|
| 63 | |
|---|
| 64 | sub lsys_execute |
|---|
| 65 | { |
|---|
| 66 | my ($string, $repetitions, $filename, %rule) = @_; |
|---|
| 67 | |
|---|
| 68 | my ($command); |
|---|
| 69 | |
|---|
| 70 | |
|---|
| 71 | for (1..$repetitions) |
|---|
| 72 | { |
|---|
| 73 | $string =~ s/./defined ($rule{$&}) ? $rule{$&} : $&/eg; |
|---|
| 74 | } |
|---|
| 75 | foreach $command (split(//, $string)) |
|---|
| 76 | { |
|---|
| 77 | if ($translate{$command}) { &{$translate{$command}}(); } |
|---|
| 78 | } |
|---|
| 79 | $im->Write($filename); |
|---|
| 80 | $im->Write('win:'); |
|---|
| 81 | } |
|---|
| 82 | |
|---|
| 83 | 1; |
|---|