annotate variant_effect_predictor/Bio/Graphics/Glyph/primers.pm @ 2:a5976b2dce6f

changing defualt values for ensembl database
author mahtabm
date Thu, 11 Apr 2013 17:15:42 +1000
parents 1f6dce3d34e0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
1 package Bio::Graphics::Glyph::primers;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
2 # package to use for drawing something that looks like
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
3 # primer pairs.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
4
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
5 use strict;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
6 use vars '@ISA';
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
7 @ISA = 'Bio::Graphics::Glyph::generic';
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
8 use Bio::Graphics::Glyph::generic;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
9
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
10 use constant HEIGHT => 4;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
11
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
12 # we do not need the default amount of room
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
13 #sub calculate_height {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
14 # my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
15 # return $self->option('label') ? HEIGHT + $self->labelheight + 2 : HEIGHT;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
16 #}
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
17
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
18 # override draw method
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
19 sub draw {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
20 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
21 my $gd = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
22 my ($x1,$y1,$x2,$y2) = $self->calculate_boundaries(@_);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
23
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
24 my $fg = $self->fgcolor;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
25 my $a2 = HEIGHT/2;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
26 my $center = $y1 + $a2;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
27
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
28 # just draw us as a solid line -- very simple
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
29 if ($x2-$x1 < HEIGHT*2) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
30 $gd->line($x1,$center,$x2,$center,$fg);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
31 return;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
32 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
33
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
34 # otherwise draw two pairs of arrows
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
35 # --> <--
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
36 my $trunc_left = $x1 < $self->panel->left;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
37 my $trunc_right = $x2 > $self->panel->right;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
38
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
39 unless ($trunc_left) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
40 $gd->line($x1,$center,$x1 + HEIGHT,$center,$fg);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
41 $gd->line($x1 + HEIGHT,$center,$x1 + HEIGHT - $a2,$center-$a2,$fg);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
42 $gd->line($x1 + HEIGHT,$center,$x1 + HEIGHT - $a2,$center+$a2,$fg);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
43 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
44
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
45 unless ($trunc_right) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
46 $gd->line($x2,$center,$x2 - HEIGHT,$center,$fg);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
47 $gd->line($x2 - HEIGHT,$center,$x2 - HEIGHT + $a2,$center+$a2,$fg);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
48 $gd->line($x2 - HEIGHT,$center,$x2 - HEIGHT + $a2,$center-$a2,$fg);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
49 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
50
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
51 # connect the dots if requested
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
52 if ($self->connect) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
53 my $c = $self->color('connect_color') || $self->bgcolor;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
54 $gd->line($x1 + ($trunc_left ? 0 : HEIGHT + 2),$center,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
55 $x2 - ($trunc_right ? 0 : HEIGHT + 2),$center,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
56 $c);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
57 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
58
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
59 # add a label if requested
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
60 $self->draw_label($gd,@_) if $self->option('label');
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
61 $self->draw_description($gd,@_) if $self->option('description');
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
62
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
63 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
64
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
65 sub connect {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
66 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
67 return $self->option('connect') if defined $self->option('connect');
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
68 1; # default
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
69 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
70
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
71 1;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
72
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
73 __END__
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
74
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
75 =head1 NAME
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
76
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
77 Bio::Graphics::Glyph::primers - The "STS primers" glyph
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
78
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
79 =head1 SYNOPSIS
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
80
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
81 See L<Bio::Graphics::Panel> and L<Bio::Graphics::Glyph>.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
82
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
83 =head1 DESCRIPTION
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
84
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
85 This glyph draws two arrows oriented towards each other and connected
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
86 by a line of a contrasting color. The length of the arrows is
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
87 immaterial, but the length of the glyph itself corresponds to the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
88 length of the scaled feature.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
89
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
90 =head2 OPTIONS
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
91
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
92 In addition to the common options, the following glyph-specific
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
93 options are recognized:
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
94
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
95 Option Description Default
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
96 ------ ----------- -------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
97
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
98 -connect Whether to connect the true
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
99 two arrowheads by a line.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
100
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
101 -connect_color The color to use for the bgcolor
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
102 connecting line.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
103
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
104 =head1 BUGS
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
105
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
106 Please report them.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
107
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
108 =head1 SEE ALSO
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
109
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
110
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
111 L<Bio::Graphics::Panel>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
112 L<Bio::Graphics::Glyph>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
113 L<Bio::Graphics::Glyph::arrow>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
114 L<Bio::Graphics::Glyph::cds>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
115 L<Bio::Graphics::Glyph::crossbox>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
116 L<Bio::Graphics::Glyph::diamond>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
117 L<Bio::Graphics::Glyph::dna>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
118 L<Bio::Graphics::Glyph::dot>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
119 L<Bio::Graphics::Glyph::ellipse>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
120 L<Bio::Graphics::Glyph::extending_arrow>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
121 L<Bio::Graphics::Glyph::generic>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
122 L<Bio::Graphics::Glyph::graded_segments>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
123 L<Bio::Graphics::Glyph::heterogeneous_segments>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
124 L<Bio::Graphics::Glyph::line>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
125 L<Bio::Graphics::Glyph::pinsertion>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
126 L<Bio::Graphics::Glyph::primers>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
127 L<Bio::Graphics::Glyph::rndrect>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
128 L<Bio::Graphics::Glyph::segments>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
129 L<Bio::Graphics::Glyph::ruler_arrow>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
130 L<Bio::Graphics::Glyph::toomany>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
131 L<Bio::Graphics::Glyph::transcript>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
132 L<Bio::Graphics::Glyph::transcript2>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
133 L<Bio::Graphics::Glyph::translation>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
134 L<Bio::Graphics::Glyph::triangle>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
135 L<Bio::DB::GFF>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
136 L<Bio::SeqI>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
137 L<Bio::SeqFeatureI>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
138 L<Bio::Das>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
139 L<GD>
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
140
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
141 =head1 AUTHOR
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
142
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
143 Allen Day E<lt>day@cshl.orgE<gt>.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
144
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
145 Copyright (c) 2001 Cold Spring Harbor Laboratory
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
146
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
147 This library is free software; you can redistribute it and/or modify
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
148 it under the same terms as Perl itself. See DISCLAIMER.txt for
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
149 disclaimers of warranty.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
150
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
151 =cut