| Bio-Graphics documentation | Contained in the Bio-Graphics distribution. |
Bio::Graphics::Glyph::flag - the "flag" glyph
See L<Bio::Graphics::Panel> and L<Bio::Graphics::Glyph>.
This glyph draws a flag with a text next to it.
In addition to the common options, the following glyph-specific options are recognized:
Option Description Default ------ ----------- ------- -text Text to draw next to the flag ori -width Width of the flag 20
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::flag; # $Id: flag.pm,v 1.2 2009-03-23 17:24:14 lstein Exp $ # Non object-oriented utilities used here-and-there in Bio::Graphics modules sub my_description { return <<END; This glyph draws a flag with text next to it. END } sub my_options { { text => [ 'string', 'ori', 'Text to draw next to the flag.'], width => [ 'integer', 20, 'Width of the flag.'], } }
use strict; use base qw(Bio::Graphics::Glyph::generic); sub default_text { return "ori"; } sub default_width { return 20; } sub draw_component { my $self = shift; my $gd = shift; my ($x1,$y1,$x2,$y2) = $self->calculate_boundaries(@_); my $fg = $self->fgcolor; my $bg = $self->bgcolor; my $width = $self->option('width') || $self->default_width; my $text = $self->option('text') || $self->default_text; my $oneThirdY = $y1 + ($y2-$y1) / 3; my $twoThirdsY = $y1 + 2 * ($y2-$y1) / 3; my $poly_pkg = $self->polygon_package; my $polygon = $poly_pkg->new(); $polygon->addPt($x1, $y1); $polygon->addPt($x1+$width, $oneThirdY); $polygon->addPt($x1, $twoThirdsY); $gd->polygon($polygon, $fg); $gd->fillToBorder($x1+$width/2, $oneThirdY, $fg, $bg); $gd->line($x1, $y1, $x1, $y2, $fg); my $font = $self->option('labelfont') || $self->font; $gd->string($font, $x1 + 3, $twoThirdsY-3, $text, $self->fontcolor); } 1; __END__