annotate variant_effect_predictor/Bio/Graphics/Glyph/redgreen_segment.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::redgreen_segment;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
2 #$Id: redgreen_segment.pm,v 1.3.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::graded_segments;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
6 use vars '@ISA';
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
7 @ISA = 'Bio::Graphics::Glyph::graded_segments';
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
8
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
9 sub calculate_color {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
10 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
11 my $val = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
12 return (0,0,0) unless $val =~ /^[\d.]+$/;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
13 return HSVtoRGB(120*(1-$val),1,255);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
14 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
15
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
16 sub HSVtoRGB ($$$) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
17 my ($h,$s,$v)=@_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
18 my ($r,$g,$b,$i,$f,$p,$q,$t);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
19
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
20 if( $s == 0 ) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
21 ## achromatic (grey)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
22 return ($v,$v,$v);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
23 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
24
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
25 $h /= 60; ## sector 0 to 5
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
26 $i = int($h);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
27 $f = $h - $i; ## factorial part of h
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
28 $p = $v * ( 1 - $s );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
29 $q = $v * ( 1 - $s * $f );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
30 $t = $v * ( 1 - $s * ( 1 - $f ) );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
31
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
32 if($i<1) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
33 $r = $v;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
34 $g = $t;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
35 $b = $p;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
36 } elsif($i<2){
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
37 $r = $q;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
38 $g = $v;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
39 $b = $p;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
40 } elsif($i<3){
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
41 $r = $p;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
42 $g = $v;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
43 $b = $t;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
44 } elsif($i<4){
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
45 $r = $p;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
46 $g = $q;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
47 $b = $v;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
48 } elsif($i<5){
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
49 $r = $t;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
50 $g = $p;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
51 $b = $v;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
52 } else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
53 $r = $v;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
54 $g = $p;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
55 $b = $q;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
56 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
57 return ($r,$g,$b);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
58 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
59
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
60 sub mMin {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
61 my $n=10000000000000;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
62 map { $n=($n>$_) ? $_ : $n } @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
63 return($n);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
64 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
65
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
66 sub mMax {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
67 my $n=0;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
68 map { $n=($n<$_) ? $_ : $n } @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
69 return($n);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
70 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
71
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
72
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
73 1;
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::redgreen_segments - The "redgreen_segments" 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 is similar to the graded_segments glyph except that it
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
86 generates a green-E<gt>red gradient suitable for use with microarray data.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
87 A feature score of 0 is full green; a feature score of 1.0 is full
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
88 red; intermediate scores are shades of yellow.
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 The following options are standard among all Glyphs. See
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
93 L<Bio::Graphics::Glyph> for a full explanation.
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 -fgcolor Foreground color black
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
99
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
100 -outlinecolor Synonym for -fgcolor
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
101
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
102 -bgcolor Background color turquoise
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
103
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
104 -fillcolor Synonym for -bgcolor
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
105
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
106 -linewidth Line width 1
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
107
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
108 -height Height of glyph 10
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
109
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
110 -font Glyph font gdSmallFont
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
111
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
112 -connector Connector type 0 (false)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
113
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
114 -connector_color
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
115 Connector color black
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
116
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
117 -label Whether to draw a label 0 (false)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
118
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
119 -description Whether to draw a description 0 (false)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
120
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
121 =head1 BUGS
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
122
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
123 Please report them.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
124
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
125 =head1 SEE ALSO
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
126
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
127 L<Bio::Graphics::Panel>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
128 L<Bio::Graphics::Glyph>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
129 L<Bio::Graphics::Glyph::arrow>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
130 L<Bio::Graphics::Glyph::cds>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
131 L<Bio::Graphics::Glyph::crossbox>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
132 L<Bio::Graphics::Glyph::diamond>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
133 L<Bio::Graphics::Glyph::dna>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
134 L<Bio::Graphics::Glyph::dot>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
135 L<Bio::Graphics::Glyph::ellipse>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
136 L<Bio::Graphics::Glyph::extending_arrow>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
137 L<Bio::Graphics::Glyph::generic>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
138 L<Bio::Graphics::Glyph::graded_segments>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
139 L<Bio::Graphics::Glyph::heterogeneous_segments>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
140 L<Bio::Graphics::Glyph::line>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
141 L<Bio::Graphics::Glyph::pinsertion>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
142 L<Bio::Graphics::Glyph::primers>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
143 L<Bio::Graphics::Glyph::rndrect>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
144 L<Bio::Graphics::Glyph::segments>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
145 L<Bio::Graphics::Glyph::ruler_arrow>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
146 L<Bio::Graphics::Glyph::toomany>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
147 L<Bio::Graphics::Glyph::transcript>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
148 L<Bio::Graphics::Glyph::transcript2>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
149 L<Bio::Graphics::Glyph::translation>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
150 L<Bio::Graphics::Glyph::triangle>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
151 L<Bio::DB::GFF>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
152 L<Bio::SeqI>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
153 L<Bio::SeqFeatureI>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
154 L<Bio::Das>,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
155 L<GD>
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
156
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
157 =head1 AUTHOR
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
158
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
159 Lincoln Stein E<lt>lstein@cshl.orgE<gt>
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
160
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
161 Copyright (c) 2001 Cold Spring Harbor Laboratory
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
162
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
163 This library is free software; you can redistribute it and/or modify
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
164 it under the same terms as Perl itself. See DISCLAIMER.txt for
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
165 disclaimers of warranty.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
166
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
167 =cut