annotate variant_effect_predictor/Bio/Graphics/Glyph/redgreen_box.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::redgreen_box;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
2 #$Id: redgreen_box.pm,v 1.4.2.1 2003/07/05 00:32:04 lstein Exp $
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
3
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
4 use strict;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
5 use Bio::Graphics::Glyph::generic;
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
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
9 sub bgcolor {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
10 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
11 $self->{force_bgcolor};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
12 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
13
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
14 sub fgcolor {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
15 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
16 return $self->option('border') ? $self->SUPER::fgcolor : $self->{force_bgcolor};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
17 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
18
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 $val = $self->feature->score;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
22
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
23 # we're going to force all our parts to share the same colors
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
24 # since the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
25 my @parts = $self->parts;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
26 @parts = $self if !@parts && $self->level == 0;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
27 my @rgb = map {int($_)} HSVtoRGB(120*(1-$val),1,255);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
28 my $color = $self->panel->translate_color(@rgb);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
29 $_->{force_bgcolor} = $color foreach @parts;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
30
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
31 $self->SUPER::draw(@_);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
32 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
33
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
34 sub HSVtoRGB ($$$) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
35 my ($h,$s,$v)=@_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
36 my ($r,$g,$b,$i,$f,$p,$q,$t);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
37
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
38 if( $s == 0 ) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
39 ## achromatic (grey)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
40 return ($v,$v,$v);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
41 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
42
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
43 $h /= 60; ## sector 0 to 5
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
44 $i = int($h);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
45 $f = $h - $i; ## factorial part of h
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
46 $p = $v * ( 1 - $s );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
47 $q = $v * ( 1 - $s * $f );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
48 $t = $v * ( 1 - $s * ( 1 - $f ) );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
49
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
50 if($i<1) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
51 $r = $v;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
52 $g = $t;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
53 $b = $p;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
54 } elsif($i<2){
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
55 $r = $q;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
56 $g = $v;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
57 $b = $p;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
58 } elsif($i<3){
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
59 $r = $p;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
60 $g = $v;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
61 $b = $t;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
62 } elsif($i<4){
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
63 $r = $p;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
64 $g = $q;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
65 $b = $v;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
66 } elsif($i<5){
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
67 $r = $t;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
68 $g = $p;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
69 $b = $v;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
70 } else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
71 $r = $v;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
72 $g = $p;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
73 $b = $q;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
74 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
75 return ($r,$g,$b);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
76 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
77
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
78 sub mMin {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
79 my $n=10000000000000;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
80 map { $n=($n>$_) ? $_ : $n } @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
81 return($n);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
82 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
83
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
84 sub mMax {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
85 my $n=0;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
86 map { $n=($n<$_) ? $_ : $n } @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
87 return($n);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
88 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
89
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
90
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
91 1;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
92
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
93 =head1 NAME
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
94
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
95 Bio::Graphics::Glyph::redgreen_box - The "redgreen_box" glyph
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
96
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
97 =head1 SYNOPSIS
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
98
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
99 See L<Bio::Graphics::Panel> and L<Bio::Graphics::Glyph>.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
100
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
101 =head1 DESCRIPTION
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
102
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
103 This glyph is similar to the graded_segments glyph except that it
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
104 generates a green-E<gt>red gradient suitable for use with microarray data.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
105 A feature score of 0 is full green; a feature score of 1.0 is full
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
106 red; intermediate scores are shades of yellow.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
107
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
108 =head2 OPTIONS
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
109
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
110 The following options are standard among all Glyphs. See
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
111 L<Bio::Graphics::Glyph> for a full explanation.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
112
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
113 Option Description Default
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
114 ------ ----------- -------
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
115
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
116 -fgcolor Foreground color black
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
117
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
118 -outlinecolor Synonym for -fgcolor
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
119
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
120 -bgcolor Background color turquoise
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
121
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
122 -fillcolor Synonym for -bgcolor
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
123
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
124 -linewidth Line width 1
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
125
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
126 -height Height of glyph 10
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
127
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
128 -font Glyph font gdSmallFont
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
129
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
130 -connector Connector type 0 (false)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
131
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
132 -connector_color
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
133 Connector color black
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
134
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
135 -label Whether to draw a label 0 (false)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
136
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
137 -description Whether to draw a description 0 (false)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
138
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
139 The following glyph-specific option is recognized:
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
140
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
141 -border Draw a fgcolor border around 0 (false)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
142 the box
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
143
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
144
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
145 =head1 BUGS
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
146
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
147 Please report them.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
148
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
149 =head1 SEE ALSO
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
150
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
151 L<Bio::Graphics::Panel>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
152 L<Bio::Graphics::Glyph>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
153 L<Bio::Graphics::Glyph::arrow>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
154 L<Bio::Graphics::Glyph::cds>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
155 L<Bio::Graphics::Glyph::crossbox>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
156 L<Bio::Graphics::Glyph::diamond>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
157 L<Bio::Graphics::Glyph::dna>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
158 L<Bio::Graphics::Glyph::dot>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
159 L<Bio::Graphics::Glyph::ellipse>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
160 L<Bio::Graphics::Glyph::extending_arrow>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
161 L<Bio::Graphics::Glyph::generic>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
162 L<Bio::Graphics::Glyph::graded_segments>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
163 L<Bio::Graphics::Glyph::heterogeneous_segments>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
164 L<Bio::Graphics::Glyph::line>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
165 L<Bio::Graphics::Glyph::pinsertion>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
166 L<Bio::Graphics::Glyph::primers>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
167 L<Bio::Graphics::Glyph::rndrect>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
168 L<Bio::Graphics::Glyph::segments>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
169 L<Bio::Graphics::Glyph::ruler_arrow>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
170 L<Bio::Graphics::Glyph::toomany>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
171 L<Bio::Graphics::Glyph::transcript>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
172 L<Bio::Graphics::Glyph::transcript2>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
173 L<Bio::Graphics::Glyph::translation>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
174 L<Bio::Graphics::Glyph::triangle>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
175 L<Bio::DB::GFF>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
176 L<Bio::SeqI>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
177 L<Bio::SeqFeatureI>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
178 L<Bio::Das>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
179 L<GD>
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
180
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
181 =head1 AUTHOR
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
182
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
183 Lincoln Stein E<lt>lstein@cshl.orgE<gt>
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
184
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
185 Copyright (c) 2001 Cold Spring Harbor Laboratory
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
186
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
187 This library is free software; you can redistribute it and/or modify
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
188 it under the same terms as Perl itself. See DISCLAIMER.txt for
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
189 disclaimers of warranty.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
190
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
191 =cut