annotate variant_effect_predictor/Bio/Graphics/Glyph/heterogeneous_segments.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::heterogeneous_segments;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
2
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
3 # this glyph acts like graded_segments but the bgcolor of each segment is
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
4 # controlled by the source field of the feature. Use the source field name
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
5 # to set the background color:
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
6 # -waba_strong => 'blue'
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
7 # -waba_weak => 'red'
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
8 # -waba_coding => 'green'
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
9
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
10 # $Id: heterogeneous_segments.pm,v 1.5 2002/12/23 01:33:41 lstein Exp $
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
11
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
12 use strict;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
13 use Bio::Graphics::Glyph::graded_segments;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
14 use vars '@ISA';
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
15 @ISA = 'Bio::Graphics::Glyph::graded_segments';
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
16
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
17 # override draw method to calculate the min and max values for the components
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
18 sub draw {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
19 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
20
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
21 # bail out if this isn't the right kind of feature
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
22 # handle both das-style and Bio::SeqFeatureI style,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
23 # which use different names for subparts.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
24 my @parts = $self->parts;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
25 @parts = $self if !@parts && $self->level == 0;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
26 return $self->SUPER::draw(@_) unless @parts;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
27
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
28 # figure out the colors
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
29 $self->{source2color} ||= {};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
30 my $fill = $self->bgcolor;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
31 for my $part (@parts) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
32 my $s = eval { $part->feature->source_tag } or next;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
33 $self->{source2color}{$s} ||= $self->color(lc($s)."_color") || $fill;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
34 $part->{partcolor} = $self->{source2color}{$s};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
35 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
36
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
37 $self->Bio::Graphics::Glyph::generic::draw(@_);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
38 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
39
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
40
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
41 # synthesize a key glyph
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
42 sub keyglyph {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
43 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
44
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
45 my $scale = 1/$self->scale; # base pairs/pixel
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
46
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
47 # two segments, at pixels 0->50, 60->80
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
48 my $offset = $self->panel->offset;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
49
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
50 my $feature =
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
51 Bio::Graphics::Feature->new(
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
52 -segments=>[ [ 0*$scale +$offset,25*$scale+$offset],
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
53 [ 25*$scale +$offset,50*$scale+$offset],
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
54 [ 50*$scale+$offset, 75*$scale+$offset]
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
55 ],
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
56 -name => $self->option('key'),
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
57 -strand => '+1');
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
58 my @sources = grep {/_color$/} $self->factory->options;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
59 foreach (@sources) {s/_color$//}
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
60 ($feature->segments)[0]->source_tag($sources[1]);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
61 ($feature->segments)[1]->source_tag($sources[0]);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
62 ($feature->segments)[2]->source_tag($sources[2]);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
63 my $factory = $self->factory->clone;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
64 $factory->set_option(label => 1);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
65 $factory->set_option(bump => 0);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
66 $factory->set_option(connector => 'solid');
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
67 my $glyph = $factory->make_glyph(0,$feature);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
68 return $glyph;
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 =head1 NAME
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
74
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
75 Bio::Graphics::Glyph::heterogeneous_segments - The "heterogeneous_segments" glyph
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
76
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
77 =head1 SYNOPSIS
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
78
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
79 See L<Bio::Graphics::Panel> and L<Bio::Graphics::Glyph>.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
80
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
81 =head1 DESCRIPTION
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
82
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
83 This glyph acts like graded_segments but the bgcolor of each segment (sub-feature)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
84 can be individually set using the source field of the feature.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
85
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
86 Each segment type color is specified using the following nomenclature:
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
87
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
88 -{source}_color => $color
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
89
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
90 For example, if the feature consists of a gene containing both
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
91 confirmed and unconfirmed exons, you can make the confirmed exons
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
92 green and the unconfirmed ones red this way:
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
93
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
94 -confirmed_color => 'green',
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
95 -unconfirmed_color => 'red'
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
96
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
97 =head2 OPTIONS
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
98
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
99 The following options are standard among all Glyphs. See
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
100 L<Bio::Graphics::Glyph> for a full explanation.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
101
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
102 Option Description Default
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
103 ------ ----------- -------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
104
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
105 -fgcolor Foreground color black
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
106
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
107 -outlinecolor Synonym for -fgcolor
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
108
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
109 -bgcolor Background color turquoise
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
110
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
111 -fillcolor Synonym for -bgcolor
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
112
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
113 -linewidth Line width 1
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
114
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
115 -height Height of glyph 10
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
116
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
117 -font Glyph font gdSmallFont
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
118
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
119 -connector Connector type 0 (false)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
120
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
121 -connector_color
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
122 Connector color black
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
123
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
124 -label Whether to draw a label 0 (false)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
125
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
126 -description Whether to draw a description 0 (false)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
127
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
128 =head1 BUGS
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
129
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
130 Please report them.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
131
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
132 =head1 SEE ALSO
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
133
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
134 L<Bio::Graphics::Panel>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
135 L<Bio::Graphics::Glyph>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
136 L<Bio::Graphics::Glyph::arrow>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
137 L<Bio::Graphics::Glyph::cds>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
138 L<Bio::Graphics::Glyph::crossbox>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
139 L<Bio::Graphics::Glyph::diamond>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
140 L<Bio::Graphics::Glyph::dna>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
141 L<Bio::Graphics::Glyph::dot>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
142 L<Bio::Graphics::Glyph::ellipse>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
143 L<Bio::Graphics::Glyph::extending_arrow>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
144 L<Bio::Graphics::Glyph::generic>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
145 L<Bio::Graphics::Glyph::graded_segments>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
146 L<Bio::Graphics::Glyph::heterogeneous_segments>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
147 L<Bio::Graphics::Glyph::line>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
148 L<Bio::Graphics::Glyph::pinsertion>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
149 L<Bio::Graphics::Glyph::primers>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
150 L<Bio::Graphics::Glyph::rndrect>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
151 L<Bio::Graphics::Glyph::segments>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
152 L<Bio::Graphics::Glyph::ruler_arrow>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
153 L<Bio::Graphics::Glyph::toomany>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
154 L<Bio::Graphics::Glyph::transcript>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
155 L<Bio::Graphics::Glyph::transcript2>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
156 L<Bio::Graphics::Glyph::translation>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
157 L<Bio::Graphics::Glyph::triangle>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
158 L<Bio::DB::GFF>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
159 L<Bio::SeqI>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
160 L<Bio::SeqFeatureI>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
161 L<Bio::Das>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
162 L<GD>
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
163
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
164 =head1 AUTHOR
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
165
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
166 Lincoln Stein E<lt>lstein@cshl.orgE<gt>
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
167
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
168 Copyright (c) 2001 Cold Spring Harbor Laboratory
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
169
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
170 This library is free software; you can redistribute it and/or modify
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
171 it under the same terms as Perl itself. See DISCLAIMER.txt for
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
172 disclaimers of warranty.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
173
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
174 =cut