annotate variant_effect_predictor/Bio/Graphics/Glyph/transcript2.pm @ 0:1f6dce3d34e0

Uploaded
author mahtabm
date Thu, 11 Apr 2013 02:01:53 -0400
parents
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::transcript2;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
2
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
3 # $Id: transcript2.pm,v 1.15.2.1 2003/07/05 00:32:04 lstein Exp $
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
4
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
5 use strict;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
6 use Bio::Graphics::Glyph::transcript;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
7 use vars '@ISA';
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
8 @ISA = 'Bio::Graphics::Glyph::transcript';
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
9
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
10 use constant MIN_WIDTH_FOR_ARROW => 8;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
11
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
12 sub pad_left {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
13 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
14 my $pad = $self->Bio::Graphics::Glyph::generic::pad_left;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
15 return $pad unless ($self->feature->strand||0) < 0; #uninitialized var warning
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
16 my $first = ($self->parts)[0] || $self;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
17 my @rect = $first->bounds();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
18 my $width = abs($rect[2] - $rect[0]);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
19 return $self->SUPER::pad_left if $width < MIN_WIDTH_FOR_ARROW;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
20 return $pad;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
21 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
22
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
23 sub pad_right {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
24 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
25 my $pad = $self->Bio::Graphics::Glyph::generic::pad_right;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
26 return $pad if $self->{level} > 0;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
27 my $last = ($self->parts)[-1] || $self;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
28 my @rect = $last->bounds();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
29 my $width = abs($rect[2] - $rect[0]);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
30 return $self->SUPER::pad_right if $width < MIN_WIDTH_FOR_ARROW;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
31 return $pad
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
32 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
33
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
34 sub draw_component {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
35 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
36 return unless $self->level > 0;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
37
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
38 my $gd = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
39 my ($left,$top) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
40 my @rect = $self->bounds(@_);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
41
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
42 my $width = abs($rect[2] - $rect[0]);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
43 my $filled = defined($self->{partno}) && $width >= MIN_WIDTH_FOR_ARROW;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
44
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
45 if ($filled) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
46 my $f = $self->feature;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
47 my $strand = $f->strand;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
48 my ($first,$last) = ($self->{partno} == 0 , $self->{partno} == $self->{total_parts}-1);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
49 ($first,$last) = ($last,$first) if $self->{flip};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
50
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
51 if ($strand < 0 && $first) { # first exon, minus strand transcript
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
52 $self->filled_arrow($gd,-1,@rect);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
53 } elsif ($strand >= 0 && $last) { # last exon, plus strand
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
54 $self->filled_arrow($gd,+1,@rect);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
55 } else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
56 $self->SUPER::draw_component($gd,@_);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
57 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
58 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
59
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
60 else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
61 $self->SUPER::draw_component($gd,@_);
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
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
66 sub draw_connectors {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
67 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
68 my ($gd,$dx,$dy) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
69
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
70 my $part;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
71 my $strand = $self->feature->strand;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
72 $strand *= -1 if $self->{flip}; #sigh
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
73 if (my @parts = $self->parts) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
74 $part = $strand >= 0 ? $parts[-1] : $parts[0];
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
75 } else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
76 # no parts -- so draw an intron spanning whole thing
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
77 my($x1,$y1,$x2,$y2) = $self->bounds(0,0);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
78 $self->_connector($gd,$dx,$dy,$x1,$y1,$x1,$y2,$x2,$y1,$x2,$y2);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
79 $part = $self;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
80 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
81 my @rect = $part->bounds();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
82 my $width = abs($rect[2] - $rect[0]);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
83 my $filled = $width >= MIN_WIDTH_FOR_ARROW;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
84
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
85 if ($filled) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
86 $self->Bio::Graphics::Glyph::generic::draw_connectors(@_);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
87 } else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
88 $self->SUPER::draw_connectors(@_);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
89 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
90 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
91
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
92 sub bump {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
93 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
94 return $self->SUPER::bump(@_) if $self->all_callbacks;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
95 return 0; # never allow our components to bump
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
96 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
97
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
98 1;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
99
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
100
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
101 __END__
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
102
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
103 =head1 NAME
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
104
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
105 Bio::Graphics::Glyph::transcript2 - The "transcript2" glyph
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
106
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
107 =head1 SYNOPSIS
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
108
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
109 See L<Bio::Graphics::Panel> and L<Bio::Graphics::Glyph>.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
110
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
111 =head1 DESCRIPTION
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
112
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
113 This glyph is used for drawing transcripts. It is like "transcript"
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
114 except that if there is sufficient room the terminal exon is shaped
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
115 like an arrow in order to indicate the direction of transcription. If
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
116 there isn't enough room, a small arrow is drawn.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
117
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
118 =head2 OPTIONS
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
119
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
120 The following options are standard among all Glyphs. See
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
121 L<Bio::Graphics::Glyph> for a full explanation.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
122
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
123 Option Description Default
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
124 ------ ----------- -------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
125
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
126 -fgcolor Foreground color black
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
127
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
128 -outlinecolor Synonym for -fgcolor
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
129
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
130 -bgcolor Background color turquoise
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
131
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
132 -fillcolor Synonym for -bgcolor
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
133
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
134 -linewidth Line width 1
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
135
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
136 -height Height of glyph 10
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
137
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
138 -font Glyph font gdSmallFont
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
139
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
140 -connector Connector type 0 (false)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
141
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
142 -connector_color
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
143 Connector color black
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
144
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
145 -label Whether to draw a label 0 (false)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
146
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
147 -description Whether to draw a description 0 (false)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
148
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
149 -strand_arrow Whether to indicate 0 (false)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
150 strandedness
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
151
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
152 In addition, the alignment glyph recognizes the following
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
153 glyph-specific options:
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
154
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
155 Option Description Default
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
156 ------ ----------- -------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
157
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
158 -arrow_length Length of the directional 8
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
159 arrow.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
160
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
161 =head1 BUGS
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
162
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
163 Please report them.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
164
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
165 =head1 SEE ALSO
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
166
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
167
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
168 L<Bio::Graphics::Panel>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
169 L<Bio::Graphics::Glyph>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
170 L<Bio::Graphics::Glyph::arrow>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
171 L<Bio::Graphics::Glyph::cds>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
172 L<Bio::Graphics::Glyph::crossbox>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
173 L<Bio::Graphics::Glyph::diamond>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
174 L<Bio::Graphics::Glyph::dna>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
175 L<Bio::Graphics::Glyph::dot>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
176 L<Bio::Graphics::Glyph::ellipse>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
177 L<Bio::Graphics::Glyph::extending_arrow>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
178 L<Bio::Graphics::Glyph::generic>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
179 L<Bio::Graphics::Glyph::graded_segments>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
180 L<Bio::Graphics::Glyph::heterogeneous_segments>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
181 L<Bio::Graphics::Glyph::line>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
182 L<Bio::Graphics::Glyph::pinsertion>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
183 L<Bio::Graphics::Glyph::primers>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
184 L<Bio::Graphics::Glyph::rndrect>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
185 L<Bio::Graphics::Glyph::segments>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
186 L<Bio::Graphics::Glyph::ruler_arrow>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
187 L<Bio::Graphics::Glyph::toomany>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
188 L<Bio::Graphics::Glyph::transcript>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
189 L<Bio::Graphics::Glyph::transcript2>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
190 L<Bio::Graphics::Glyph::translation>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
191 L<Bio::Graphics::Glyph::triangle>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
192 L<Bio::DB::GFF>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
193 L<Bio::SeqI>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
194 L<Bio::SeqFeatureI>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
195 L<Bio::Das>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
196 L<GD>
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
197
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
198 =head1 AUTHOR
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
199
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
200 Lincoln Stein E<lt>lstein@cshl.orgE<gt>
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
201
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
202 Copyright (c) 2001 Cold Spring Harbor Laboratory
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
203
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
204 This library is free software; you can redistribute it and/or modify
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
205 it under the same terms as Perl itself. See DISCLAIMER.txt for
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
206 disclaimers of warranty.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
207
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
208 =cut