annotate variant_effect_predictor/Bio/Graphics/Glyph/pinsertion.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::pinsertion;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
2 # package to use for drawing P insertion as a triangle
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
3 # p insertion is a point (one base).
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
4
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
5 use strict;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
6 use GD;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
7 use vars '@ISA';
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
8 @ISA = 'Bio::Graphics::Glyph::generic';
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
9 use Bio::Graphics::Glyph::generic;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
10
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
11 sub box {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
12 my $self = shift;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
13 my $half = $self->insertion_width/2;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
14 return ($self->left-$half,$self->top,$self->right+$half,$self->bottom);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
15 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
16
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
17 sub insertion_width {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
18 my $self = shift;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
19 return $self->option('insertion_width') || 6;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
20 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
21
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
22 # override draw method
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
23 sub draw {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
24 my $self = shift;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
25
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
26 my $gd = shift;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
27 my ($left,$top) = @_;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
28 my ($x1,$y1,$x2,$y2) = $self->calculate_boundaries(@_);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
29
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
30 my $height = $self->height;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
31
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
32 my $half = $self->insertion_width/2;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
33
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
34 my $fill = $self->bgcolor;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
35
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
36 my $poly = GD::Polygon->new;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
37
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
38 if ($self->feature->strand > 0) { #plus strand
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
39 $poly->addPt($x1 - $half, $y1);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
40 $poly->addPt($x1 + ($half), $y1);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
41 $poly->addPt($x1, $y2); #pointer down
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
42 } else {
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
43 $poly->addPt($x1, $y1); #pointer up
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
44 $poly->addPt($x1 - $half, $y2);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
45 $poly->addPt($x1 + ($half), $y2);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
46 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
47 $gd->filledPolygon($poly, $fill);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
48 $gd->polygon($poly, $fill);
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
49
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
50 # add a label if requested
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
51 $self->draw_label($gd,$left,$top) if $self->option('label');
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
52 $self->draw_description($gd,$left,$top) if $self->option('description');
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
53 }
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
54
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
55
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
56 1;
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
57
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
58 =head1 NAME
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
59
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
60 Bio::Graphics::Glyph::pinsertion - The "Drosophila P-element Insertion" glyph
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
61
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
62 =head1 SYNOPSIS
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
63
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
64 See L<Bio::Graphics::Panel> and L<Bio::Graphics::Glyph>.
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
65
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
66 =head1 DESCRIPTION
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
67
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
68 This glyph was designed to show P-element insertions in the Drosophila
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
69 genome, but in fact is suitable for any type of zero-width feature.
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
70 Also see the triangle glyph.
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
71
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
72 =head2 OPTIONS
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
73
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
74 In addition to the generic options, this glyph recognizes:
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
75
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
76 Option Name Description Default
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
77 ----------- ----------- -------
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
78
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
79 -insertion_width Width of glyph in pixels 3
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
80
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
81 =head1 BUGS
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
82
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
83 Please report them.
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
84
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
85 =head1 SEE ALSO
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
86
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
87 L<Bio::Graphics::Panel>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
88 L<Bio::Graphics::Glyph>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
89 L<Bio::Graphics::Glyph::arrow>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
90 L<Bio::Graphics::Glyph::cds>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
91 L<Bio::Graphics::Glyph::crossbox>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
92 L<Bio::Graphics::Glyph::diamond>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
93 L<Bio::Graphics::Glyph::dna>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
94 L<Bio::Graphics::Glyph::dot>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
95 L<Bio::Graphics::Glyph::ellipse>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
96 L<Bio::Graphics::Glyph::extending_arrow>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
97 L<Bio::Graphics::Glyph::generic>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
98 L<Bio::Graphics::Glyph::graded_segments>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
99 L<Bio::Graphics::Glyph::heterogeneous_segments>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
100 L<Bio::Graphics::Glyph::line>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
101 L<Bio::Graphics::Glyph::pinsertion>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
102 L<Bio::Graphics::Glyph::primers>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
103 L<Bio::Graphics::Glyph::rndrect>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
104 L<Bio::Graphics::Glyph::segments>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
105 L<Bio::Graphics::Glyph::ruler_arrow>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
106 L<Bio::Graphics::Glyph::toomany>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
107 L<Bio::Graphics::Glyph::transcript>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
108 L<Bio::Graphics::Glyph::transcript2>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
109 L<Bio::Graphics::Glyph::translation>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
110 L<Bio::Graphics::Glyph::triangle>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
111 L<Bio::DB::GFF>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
112 L<Bio::SeqI>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
113 L<Bio::SeqFeatureI>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
114 L<Bio::Das>,
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
115 L<GD>
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
116
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
117 =head1 AUTHOR
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
118
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
119 Allen Day E<lt>day@cshl.orgE<gt>, Shengqiang Shu E<lt>sshu@bdgp.lbl.govE<gt>
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
120
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
121 Copyright (c) 2001 Cold Spring Harbor Laboratory, BDGP
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
122
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
123 This library is free software; you can redistribute it and/or modify
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
124 it under the same terms as Perl itself. See DISCLAIMER.txt for
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
125 disclaimers of warranty.
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
126
21066c0abaf5 Uploaded
willmclaren
parents:
diff changeset
127 =cut