annotate variant_effect_predictor/Bio/Graphics/Glyph/transcript2.pm @ 1:d6778b5d8382 draft default tip

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