| Bio-Graphics documentation | Contained in the Bio-Graphics distribution. |
Bio::Graphics::Glyph::repeating_shape - A glyph that draws the same shape repeatedly.
See L<Bio::Graphics::Panel> and L<Bio::Graphics::Glyph>.
This glyph is a generic superclass for drawing the same shape repeatedly.
In addition to the common options, the following glyph-specific options are recognized:
Option Description Default ------ ----------- ------- -width Width of one tooth 10 -interval Interval between teeth 10
Please report them.
Bio::Graphics::Panel, Bio::Graphics::Glyph, Bio::Graphics::Glyph::arrow, Bio::Graphics::Glyph::cds, Bio::Graphics::Glyph::crossbox, Bio::Graphics::Glyph::diamond, Bio::Graphics::Glyph::dna, Bio::Graphics::Glyph::dot, Bio::Graphics::Glyph::ellipse, Bio::Graphics::Glyph::extending_arrow, Bio::Graphics::Glyph::generic, Bio::Graphics::Glyph::graded_segments, Bio::Graphics::Glyph::heterogeneous_segments, Bio::Graphics::Glyph::line, Bio::Graphics::Glyph::pinsertion, Bio::Graphics::Glyph::primers, Bio::Graphics::Glyph::rndrect, Bio::Graphics::Glyph::segments, Bio::Graphics::Glyph::ruler_arrow, Bio::Graphics::Glyph::toomany, Bio::Graphics::Glyph::transcript, Bio::Graphics::Glyph::transcript2, Bio::Graphics::Glyph::translation, Bio::Graphics::Glyph::triangle, Bio::DB::GFF, Bio::SeqI, Bio::SeqFeatureI, Bio::Das, GD
Vsevolod (Simon) Ilyushchenko <simonf@cshl.edu>.
Copyright (c) 2004 Cold Spring Harbor Laboratory
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself. See DISCLAIMER.txt for disclaimers of warranty.
| Bio-Graphics documentation | Contained in the Bio-Graphics distribution. |
package Bio::Graphics::Glyph::repeating_shape; # DAS-compatible package to use for drawing a line of repeating shapes use strict; use base qw(Bio::Graphics::Glyph::generic); sub default_width { return 10; } sub default_interval { return 10; } sub connector { 'none' } sub draw_component { my $self = shift; my $gd = shift; my $fg = $self->fgcolor; my $width = defined $self->option('width') ? $self->option('width') : $self->default_width; my $interval = defined $self->option('interval') ? $self->option('interval') : $self->default_interval; # find the center and vertices my ($x1,$y1,$x2,$y2) = $self->calculate_boundaries(@_); my $bWidth = $x2-$x1; if ($bWidth < $width) { $self->draw_repeating_shape($gd,$x1,$y1,$x2,$y2,$fg); return; } if ($bWidth < $width+2*$interval) { my $leftoverInterval = $bWidth - $width; my $halfInt = $leftoverInterval/2; $halfInt = 0 unless $interval; $gd->line($x1,$y2,$x1+$halfInt,$y2,$fg); $self->draw_repeating_shape($gd,$x1+$halfInt,$y1,$x2-$halfInt,$y2,$fg); $gd->line($x2-$halfInt,$y2,$x2,$y2,$fg); return; } my $count = int ($bWidth / ($width+$interval)); my $leftoverInterval = $bWidth % ($width+$interval)+$interval; my $halfInt = $leftoverInterval/2; $halfInt = 0 unless $interval; $gd->line($x1,$y2,$x1+$halfInt,$y2,$fg); foreach (my $i=1; $i<=$count; $i++) { my $shapeStart = $x1 + $halfInt + ($i-1)*($width+$interval); $self->draw_repeating_shape($gd,$shapeStart,$y1,$shapeStart+$width,$y2,$fg); if ($i < $count) { $gd->line($shapeStart+$width,$y2,$shapeStart+$width+$interval,$y2,$fg); } } $gd->line($x2-$halfInt,$y2,$x2,$y2,$fg); } sub draw_repeating_shape { warn "Subclasses must implement 'draw_repeating_shape'!\n"; } 1; __END__