annotate template.eps @ 3:a0b27058dcac draft

Uploaded
author davidvanzessen
date Wed, 17 Sep 2014 07:25:17 -0400
parents 2f4298673519
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
1 %!PS-Adobe-3.0 EPSF-3.0
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
2 %%Title: Sequence Logo : {$TITLE}
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
3 %%Creator: {$CREATOR}
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
4 %%CreationDate: {$CREATIONDATE}
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
5 %%BoundingBox: 0 0 {$LOGOWIDTHPOINTS} {$LOGOHEIGHTPOINTS}
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
6 %%Pages: 0
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
7 %%DocumentFonts:
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
8 %%EndComments
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
9
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
10 {$DESC}
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
11
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
12
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
13 % ---- CONSTANTS ----
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
14 /cmfactor 72 2.54 div def % defines points -> cm conversion
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
15 /cm {cmfactor mul} bind def % defines centimeters
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
16
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
17
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
18 % ---- VARIABLES ----
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
19
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
20 {$COLORDEF}
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
21
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
22 /logoWidth {$LOGOWIDTH} cm def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
23 /logoHeight {$LOGOLINEHEIGHT} cm def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
24 /logoTitle ({$TITLE}) def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
25
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
26 /yaxis {$YAXIS} def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
27 /yaxisLabel ({$YAXIS_LABEL}) def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
28 /yaxisBits {$BARBITS} def % bits
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
29 /yaxisTicBits {$TICBITS} def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
30
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
31
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
32 /xaxis {$NUMBERING} def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
33 /xaxisLabel ({$XAXIS_LABEL}) def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
34 /showEnds ({$SHOWENDS}) def % d: DNA, p: PROTEIN, -: none
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
35
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
36 /showFineprint true def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
37 /fineprint ({$FINEPRINT}) def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
38
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
39 /charsPerLine {$CHARSPERLINE} def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
40 /logoLines {$LOGOLINES} def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
41
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
42 /showingBox ({$SHOWINGBOX}) def %n s f
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
43 /shrinking {$SHRINKBOOLEAN} def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
44 /shrink {$SHRINKFACTOR} def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
45 /outline {$OUTLINE} def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
46
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
47 /IbeamFraction {$ERRORBARFRACTION} def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
48 /IbeamGray 0.50 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
49 /IbeamLineWidth 0.5 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
50
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
51 /fontsize 12 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
52 /titleFontsize 14 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
53 /smallFontsize 6 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
54
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
55 /defaultColor {$DEFAULT_COLOR} def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
56
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
57 {$COLORDICT}
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
58
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
59 % Standard DNA/RNA color scheme
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
60 % /colorDict <<
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
61 % (G) orange
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
62 % (T) red
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
63 % (C) blue
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
64 % (A) green
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
65 % (U) red
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
66 % >> def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
67
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
68 % Standard Amino Acid colors
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
69 %/colorDict <<
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
70 % (G) green
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
71 % (S) green
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
72 % (T) green
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
73 % (Y) green
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
74 % (C) green
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
75 % (N) purple
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
76 % (Q) purple
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
77 % (K) blue
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
78 % (R) blue
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
79 % (H) blue
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
80 % (D) red
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
81 % (E) red
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
82 % (P) black
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
83 % (A) black
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
84 % (W) black
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
85 % (F) black
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
86 % (L) black
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
87 % (I) black
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
88 % (M) black
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
89 % (V) black
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
90 %>> def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
91
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
92
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
93
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
94 % ---- DERIVED PARAMETERS ----
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
95
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
96 /leftMargin
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
97 fontsize 3.5 mul
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
98
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
99 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
100
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
101 /bottomMargin
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
102 fontsize 0.75 mul
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
103
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
104 % Add extra room for axis
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
105 xaxis {fontsize 1.75 mul add } if
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
106 xaxisLabel () eq {} {fontsize 0.75 mul add} ifelse
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
107 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
108
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
109
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
110 /topMargin
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
111 logoTitle () eq { 10 }{titleFontsize 4 add} ifelse
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
112 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
113
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
114 /rightMargin
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
115 %Add extra room if showing ends
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
116 showEnds (-) eq { fontsize}{fontsize 1.5 mul} ifelse
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
117 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
118
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
119 /yaxisHeight
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
120 logoHeight
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
121 bottomMargin sub
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
122 topMargin sub
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
123 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
124
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
125 /ticWidth fontsize 2 div def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
126
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
127 /pointsPerBit yaxisHeight yaxisBits div def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
128
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
129 /isBoxed
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
130 showingBox (s) eq
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
131 showingBox (f) eq or {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
132 true
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
133 } {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
134 false
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
135 } ifelse
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
136 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
137
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
138 /stackMargin 1 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
139
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
140 % Do not add space aroung characters if characters are boxed
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
141 /charRightMargin
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
142 isBoxed { 0.0 } {stackMargin} ifelse
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
143 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
144
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
145 /charTopMargin
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
146 isBoxed { 0.0 } {stackMargin} ifelse
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
147 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
148
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
149 /charWidth
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
150 logoWidth
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
151 leftMargin sub
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
152 rightMargin sub
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
153 charsPerLine div
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
154 charRightMargin sub
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
155 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
156
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
157 /charWidth4 charWidth 4 div def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
158 /charWidth2 charWidth 2 div def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
159
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
160 /stackWidth
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
161 charWidth charRightMargin add
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
162 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
163
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
164 /numberFontsize
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
165 fontsize charWidth lt {fontsize}{charWidth} ifelse
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
166 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
167
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
168 % movements to place 5'/N and 3'/C symbols
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
169 /leftEndDeltaX fontsize neg def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
170 /leftEndDeltaY fontsize 1.5 mul neg def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
171 /rightEndDeltaX fontsize 0.25 mul def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
172 /rightEndDeltaY leftEndDeltaY def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
173
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
174 % Outline width is proporional to charWidth,
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
175 % but no less that 1 point
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
176 /outlinewidth
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
177 charWidth 32 div dup 1 gt {}{pop 1} ifelse
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
178 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
179
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
180
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
181 % ---- PROCEDURES ----
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
182
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
183 /StartLogo {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
184 % Save state
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
185 save
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
186 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
187
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
188 % Print Logo Title, top center
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
189 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
190 SetTitleFont
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
191
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
192 logoWidth 2 div
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
193 logoTitle
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
194 stringwidth pop 2 div sub
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
195 logoHeight logoLines mul
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
196 titleFontsize sub
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
197 moveto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
198
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
199 logoTitle
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
200 show
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
201 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
202
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
203 % Print X-axis label, bottom center
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
204 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
205 SetStringFont
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
206
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
207 logoWidth 2 div
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
208 xaxisLabel stringwidth pop 2 div sub
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
209 fontsize 3 div
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
210 moveto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
211
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
212 xaxisLabel
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
213 show
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
214 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
215
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
216 % Show Fine Print
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
217 showFineprint {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
218 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
219 SetSmallFont
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
220 logoWidth
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
221 fineprint stringwidth pop sub
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
222 smallFontsize sub
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
223 smallFontsize 3 div
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
224 moveto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
225
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
226 fineprint show
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
227 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
228 } if
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
229
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
230 % Move to lower left corner of last line, first stack
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
231 leftMargin bottomMargin translate
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
232
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
233 % Move above first line ready for StartLine
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
234 0 logoLines logoHeight mul translate
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
235
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
236 SetLogoFont
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
237 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
238
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
239 /EndLogo {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
240 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
241 showpage
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
242 restore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
243 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
244
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
245
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
246 /StartLine{
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
247 % move down to the bottom of the line:
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
248 0 logoHeight neg translate
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
249
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
250 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
251 yaxis { MakeYaxis } if
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
252 xaxis { ShowLeftEnd } if
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
253 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
254
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
255 /EndLine{
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
256 xaxis { ShowRightEnd } if
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
257 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
258 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
259
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
260
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
261 /MakeYaxis {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
262 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
263 stackMargin neg 0 translate
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
264 ShowYaxisBar
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
265 ShowYaxisLabel
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
266 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
267 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
268
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
269
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
270 /ShowYaxisBar {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
271 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
272 SetStringFont
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
273
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
274 /str 10 string def % string to hold number
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
275 /smallgap stackMargin 2 div def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
276
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
277 % Draw first tic and bar
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
278 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
279 ticWidth neg 0 moveto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
280 ticWidth 0 rlineto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
281 0 yaxisHeight rlineto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
282 stroke
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
283 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
284
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
285
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
286 % Draw the tics
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
287 % initial increment limit proc for
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
288 0 yaxisTicBits yaxisBits abs %cvi
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
289 {/loopnumber exch def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
290
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
291 % convert the number coming from the loop to a string
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
292 % and find its width
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
293 loopnumber 10 str cvrs
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
294 /stringnumber exch def % string representing the number
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
295
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
296 stringnumber stringwidth pop
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
297 /numberwidth exch def % width of number to show
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
298
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
299 /halfnumberheight
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
300 stringnumber CharBoxHeight 2 div
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
301 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
302
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
303 numberwidth % move back width of number
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
304 neg loopnumber pointsPerBit mul % shift on y axis
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
305 halfnumberheight sub % down half the digit
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
306
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
307 moveto % move back the width of the string
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
308
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
309 ticWidth neg smallgap sub % Move back a bit more
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
310 0 rmoveto % move back the width of the tic
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
311
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
312 stringnumber show
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
313 smallgap 0 rmoveto % Make a small gap
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
314
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
315 % now show the tic mark
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
316 0 halfnumberheight rmoveto % shift up again
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
317 ticWidth 0 rlineto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
318 stroke
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
319 } for
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
320 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
321 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
322
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
323 /ShowYaxisLabel {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
324 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
325 SetStringFont
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
326
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
327 % How far we move left depends on the size of
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
328 % the tic labels.
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
329 /str 10 string def % string to hold number
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
330 yaxisBits yaxisTicBits div cvi yaxisTicBits mul
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
331 str cvs stringwidth pop
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
332 ticWidth 1.5 mul add neg
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
333
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
334
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
335 yaxisHeight
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
336 yaxisLabel stringwidth pop
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
337 sub 2 div
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
338
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
339 translate
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
340 90 rotate
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
341 0 0 moveto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
342 yaxisLabel show
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
343 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
344 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
345
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
346
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
347 /StartStack { % <stackNumber> startstack
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
348 xaxis {MakeNumber}{pop} ifelse
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
349 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
350 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
351
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
352 /EndStack {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
353 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
354 stackWidth 0 translate
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
355 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
356
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
357
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
358 % Draw a character whose height is proportional to symbol bits
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
359 /MakeSymbol{ % charbits character MakeSymbol
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
360 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
361 /char exch def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
362 /bits exch def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
363
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
364 /bitsHeight
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
365 bits pointsPerBit mul
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
366 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
367
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
368 /charHeight
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
369 bitsHeight charTopMargin sub
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
370 dup
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
371 0.0 gt {}{pop 0.0} ifelse % if neg replace with zero
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
372 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
373
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
374 charHeight 0.0 gt {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
375 char SetColor
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
376 charWidth charHeight char ShowChar
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
377
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
378 showingBox (s) eq { % Unfilled box
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
379 0 0 charWidth charHeight false ShowBox
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
380 } if
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
381
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
382 showingBox (f) eq { % Filled box
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
383 0 0 charWidth charHeight true ShowBox
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
384 } if
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
385
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
386 } if
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
387
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
388 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
389
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
390 0 bitsHeight translate
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
391 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
392
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
393
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
394 /ShowChar { % <width> <height> <char> ShowChar
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
395 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
396 /tc exch def % The character
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
397 /ysize exch def % the y size of the character
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
398 /xsize exch def % the x size of the character
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
399
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
400 /xmulfactor 1 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
401 /ymulfactor 1 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
402
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
403
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
404 % if ysize is negative, make everything upside down!
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
405 ysize 0 lt {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
406 % put ysize normal in this orientation
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
407 /ysize ysize abs def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
408 xsize ysize translate
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
409 180 rotate
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
410 } if
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
411
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
412 shrinking {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
413 xsize 1 shrink sub 2 div mul
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
414 ysize 1 shrink sub 2 div mul translate
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
415
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
416 shrink shrink scale
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
417 } if
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
418
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
419 % Calculate the font scaling factors
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
420 % Loop twice to catch small correction due to first scaling
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
421 2 {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
422 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
423 xmulfactor ymulfactor scale
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
424
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
425 ysize % desired size of character in points
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
426 tc CharBoxHeight
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
427 dup 0.0 ne {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
428 div % factor by which to scale up the character
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
429 /ymulfactor exch def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
430 } % end if
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
431 {pop pop}
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
432 ifelse
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
433
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
434 xsize % desired size of character in points
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
435 tc CharBoxWidth
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
436 dup 0.0 ne {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
437 div % factor by which to scale up the character
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
438 /xmulfactor exch def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
439 } % end if
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
440 {pop pop}
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
441 ifelse
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
442 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
443 } repeat
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
444
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
445 % Adjust horizontal position if the symbol is an I
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
446 tc (I) eq {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
447 charWidth 2 div % half of requested character width
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
448 tc CharBoxWidth 2 div % half of the actual character
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
449 sub 0 translate
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
450 % Avoid x scaling for I
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
451 /xmulfactor 1 def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
452 } if
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
453
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
454
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
455 % ---- Finally, draw the character
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
456
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
457 newpath
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
458 xmulfactor ymulfactor scale
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
459
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
460 % Move lower left corner of character to start point
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
461 tc CharBox pop pop % llx lly : Lower left corner
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
462 exch neg exch neg
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
463 moveto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
464
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
465 outline { % outline characters:
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
466 outlinewidth setlinewidth
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
467 tc true charpath
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
468 gsave 1 setgray fill grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
469 clip stroke
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
470 } { % regular characters
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
471 tc show
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
472 } ifelse
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
473
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
474 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
475 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
476
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
477
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
478 /ShowBox { % x1 y1 x2 y2 filled ShowBox
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
479 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
480 /filled exch def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
481 /y2 exch def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
482 /x2 exch def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
483 /y1 exch def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
484 /x1 exch def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
485 newpath
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
486 x1 y1 moveto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
487 x2 y1 lineto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
488 x2 y2 lineto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
489 x1 y2 lineto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
490 closepath
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
491
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
492 clip
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
493
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
494 filled {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
495 fill
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
496 }{
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
497 0 setgray stroke
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
498 } ifelse
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
499
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
500 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
501 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
502
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
503
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
504 /MakeNumber { % number MakeNumber
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
505 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
506 SetNumberFont
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
507 stackWidth 0 translate
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
508 90 rotate % rotate so the number fits
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
509 dup stringwidth pop % find the length of the number
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
510 neg % prepare for move
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
511 stackMargin sub % Move back a bit
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
512 charWidth (0) CharBoxHeight % height of numbers
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
513 sub 2 div %
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
514 moveto % move back to provide space
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
515 show
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
516 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
517 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
518
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
519
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
520 /Ibeam{ % heightInBits Ibeam
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
521 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
522 % Make an Ibeam of twice the given height in bits
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
523 /height exch pointsPerBit mul def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
524 /heightDRAW height IbeamFraction mul def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
525
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
526 IbeamLineWidth setlinewidth
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
527 IbeamGray setgray
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
528
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
529 charWidth2 height neg translate
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
530 ShowIbar
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
531 newpath
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
532 0 0 moveto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
533 0 heightDRAW rlineto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
534 stroke
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
535 newpath
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
536 0 height moveto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
537 0 height rmoveto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
538 currentpoint translate
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
539 ShowIbar
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
540 newpath
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
541 0 0 moveto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
542 0 heightDRAW neg rlineto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
543 currentpoint translate
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
544 stroke
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
545 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
546 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
547
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
548
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
549 /ShowIbar { % make a horizontal bar
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
550 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
551 newpath
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
552 charWidth4 neg 0 moveto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
553 charWidth4 0 lineto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
554 stroke
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
555 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
556 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
557
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
558
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
559 /ShowLeftEnd {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
560 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
561 SetStringFont
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
562 leftEndDeltaX leftEndDeltaY moveto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
563 showEnds (d) eq {(5) show ShowPrime} if
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
564 showEnds (p) eq {(N) show} if
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
565 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
566 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
567
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
568
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
569 /ShowRightEnd {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
570 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
571 SetStringFont
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
572 rightEndDeltaX rightEndDeltaY moveto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
573 showEnds (d) eq {(3) show ShowPrime} if
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
574 showEnds (p) eq {(C) show} if
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
575 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
576 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
577
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
578
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
579 /ShowPrime {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
580 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
581 SetPrimeFont
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
582 (\242) show
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
583 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
584 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
585
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
586
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
587 /SetColor{ % <char> SetColor
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
588 dup colorDict exch known {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
589 colorDict exch get aload pop setrgbcolor
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
590 } {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
591 pop
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
592 defaultColor aload pop setrgbcolor
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
593 } ifelse
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
594 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
595
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
596 % define fonts
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
597 /SetTitleFont {/Times-Bold findfont titleFontsize scalefont setfont} bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
598 /SetLogoFont {/Helvetica-Narrow-Bold findfont charWidth scalefont setfont} bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
599 /SetStringFont{/Helvetica-Bold findfont fontsize scalefont setfont} bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
600 /SetPrimeFont {/Symbol findfont fontsize scalefont setfont} bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
601 /SetSmallFont {/Helvetica findfont smallFontsize scalefont setfont} bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
602
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
603 /SetNumberFont {
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
604 /Helvetica-Bold findfont
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
605 numberFontsize
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
606 scalefont
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
607 setfont
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
608 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
609
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
610 %Take a single character and return the bounding box
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
611 /CharBox { % <char> CharBox <lx> <ly> <ux> <uy>
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
612 gsave
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
613 newpath
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
614 0 0 moveto
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
615 % take the character off the stack and use it here:
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
616 true charpath
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
617 flattenpath
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
618 pathbbox % compute bounding box of 1 pt. char => lx ly ux uy
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
619 % the path is here, but toss it away ...
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
620 grestore
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
621 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
622
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
623
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
624 % The height of a characters bounding box
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
625 /CharBoxHeight { % <char> CharBoxHeight <num>
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
626 CharBox
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
627 exch pop sub neg exch pop
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
628 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
629
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
630
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
631 % The width of a characters bounding box
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
632 /CharBoxWidth { % <char> CharBoxHeight <num>
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
633 CharBox
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
634 pop exch pop sub neg
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
635 } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
636
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
637
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
638 % Deprecated names
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
639 /startstack {StartStack} bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
640 /endstack {EndStack} bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
641 /makenumber {MakeNumber} bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
642 /numchar { MakeSymbol } bind def
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
643
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
644 %%EndProlog
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
645
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
646 %%Page: 1 1
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
647 StartLogo
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
648 StartLine % line number 1
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
649
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
650 {$DATA}
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
651
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
652 EndLine
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
653 EndLogo
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
654
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
655 %%EOF
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
656
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
657
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
658
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
659
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
660
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
661
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
662
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
663
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
664
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
665
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
666
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
667
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
668
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
669
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
670
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
671
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
672
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
673
2f4298673519 Uploaded
davidvanzessen
parents:
diff changeset
674