forked from PDLPorters/PDL-Graphics-Prima
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathChanges
485 lines (283 loc) · 15.7 KB
/
Changes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
Put changes under the appropriate header. Headers can include API CHANGES,
DIFFERENT BEHAVIOR, BUG FIXES, DEPENDENCIES, ENHANCEMENTS, NEW FEATURES, and
OTHER. Entries should be in chronological order, i.e. oldest at the top
0.18 YYYY-MM-DD
[MAJOR CHANGES]
- New capability: color map support. PDL::Graphics::Prima has been able to
use color to visualize data, especially heat maps, for quite some time.
However, apart from printing information to the terminal, there was no way
to know what quantities the different colors represented. This meant that
heat maps and other uses of palettes were, at best, only good for relative
comparisons or meticulously crafted plots that depicted the color scaling
on their own. The new changes make it possible (and fairly easy) to render
and quantitatively label a color bar. This is made possible by a significant
extension to the capabilities of Palettes. Note that because Prima itself
uses the term "Palette" in its gradient API, these are called color maps.
[API CHANGES]
- The Simple interface now accepts additional arguments that can be used to
configure all elements of the plot command.
- New plot widget keys default_save_dir and default_save_format. When a user
right-clicks and chooses to save the figure, these settings will be used as
the starting points rather than the defaults of the current directory and
.bmp format.
- Although plotTypes that have historically expected a palette (ppair::Matrix)
will continue to accept them under that keyword, it is now officially
discouraged. The preferred keyword is color_map.
- Palettes no longer have the copy method. Having removed their association
with a given plotType, this seems to be unnecessary capability, and
extending it with the newer features seemed fraught with potential errors.
[DIFFERENT BEHAVIOR]
- Change zoom-out factor so that a zoom-in/zoom-out pair takes us back to
to starting zoom level.
- When using a Grid datatype, if no palette is explicitly specified, the grid
activates the new plot-wide color map. Activating the color map causes it to
be rendered, which can significantly alter the appearance of the plot.
[ENHANCEMENTS]
- Palettes have always determined the mapping from values to color using the
minimum and maximum values of the data. They now give you the option of
specifying explicit minimum and maximum values.
- Palettes now accept a scaling parameter that can be any valid scaling type.
Palettes always used to do linear, so basically this means it is now easy
to get logarithmic color palettes.
- Palettes now take a whole range of new (optional) arguments related to
rendering. Only the plot-wide palette---called the color map---is rendered
in the new changes, though it may be possible and useful to render a palette
in a different context. In that case it should be possible to use all of
these to tweak that rendering.
- Palettes now have a property for specifying a color to use if they
encounter bad data. Ideally this color should fall somewhere outside of
the palette's range. The default value, brown, was chosen specifically for
this reason.
- For the above enhancements, note that Palettes that implement their
functionality via a custom "apply" method do not have access to the palette
object, and so do now have access to any of these new parameters.
- It is possible to specify the color map for a dataset or the plot as a whole
via the color_map key. It is possible to specify a color map at each level;
the level closest to the data is the one that is used. Also, only the plot's
color map is rendered.
[NEW FEATURES]
- New module PDL::Graphics::Prima::SizeSpec facilitates expressing, parsing,
and computing pixel equivalents for sophisticated combinations of distances
in terms of multiple, meaningful units of measure.
- PDL::Graphics::Prima::Simple now looks for a prima-simple.ini file for
default settings for simple plots.
0.17 2014-08-25
[BUG FIXES]
- Fixed minor bug in logic for determining if error bars are specified.
Previously I had returned two checks combined with "or", but the return
keyword has higher precedence than the "or" boolean operator! So now it
uses ||. The upshot was that if only lower error bars were specified, the
library determined that no error bars were present.
0.16 2014-08-25
- Fixed Changes file to conform to the spec
0.15 2014-08-25
- Added a $VERSION to each module in the distribution.
0.14 2014-08-25
[API CHANGES]
- Meaningful drawing now happens in the draw_plot method. Changes in the title
drawing revealed a subtle bug in the on_paint method. This bug is most
easily solved by factoring the plot drawing code into its own function.
Subclasses of Prima::Plot that wish to modify how the widget implements its
drawing should override draw_plot, not on_paint.
[DEPENDENCIES]
- The latest version of Prima, v1.40, provides Prima::Drawable::Subcanvas.
This is needed to get proper subfigure drawing for postscript output, as
well as proper EPS output format.
[DIFFERENT BEHAVIOR]
- You can now specify the fill color for the ppair::Histogram plot type via
the backColor or backColors property. Normal rectangles do not appear to
pay any attention to this property, so now a set of bars are drawn with
the backColor before the rectangles are rendered.
- As mentioned in the NEW FEATURES, it is now possible to specify the title
font specification with much greater precision. I have never been very happy
with the default title font or spacing, so with this change I have taken the
liberty of updating it. The font height now scales with the size of the plot
widget, and the title space now scales with the font size, making the title
size and spacing much more sensible for user interaction (i.e. resizing).
This is expected to have negative impacts for animations if not handled
carefully, but those impacts have not been benchmarked yet.
- The rainbow palette now runs for hue values from 0 to 300 instead of 0 to
360. The problem with the original behavior is that the smallest and largest
values were nearly identical, and indistinguishable. However, it also
removes a sixth of the color spectrum from the palette.
- The save-as-postscript dialog now refers to Encapsulated Postscript
files, with the file extension .eps. A default file extension is
appended if the .eps extension is missing. This usually Does What You
Mean, but also means that users cannot use their own file extension when
using the save-as-postscript dialog.
[NEW FEATURES]
- There is a new property for setting the title's font, called titleFont. In
addition to the normal settings, you can also indicate that the font size,
width, and/or height should be percentages of the canvas's width or height,
or a multiple of the canvas's font's feature.
- The titleSpace property is now much more flexible. In additon to the integer
number of pixels for the title space, the property now accepts either a
subref that is expected to compute the titleSpace (in pixels) or a specially
formatted string for a set of pre-canned calculations.
- Added tick labeling callback (thanks Vikas!). Now users can specify an
arbitrary tick labeling function that will be called for each tick that
needs to be labeled, allowing the user to return a string with the desired
label.
- Added pal::RainbowSV to make less-than-bright rainbow palettes eaiser to
create.
- Added a new Propeties dialog box and associated entry to the pop-up menu.
The dialog box lets the user set the title, axis labels, axis extrema,
and axis scaling type. Furthermore, the user can continue manipulating
the plot with their mouse, and the properties will automatically update
to the currently displayed values.
- If you simply want to specify an axis label, you can now specify it as
x => $x_label rather than x => { label => $x_label }
[ENHANCEMENTS]
- Different means for rendering a plot on a raster image are now documented
and tested.
- Added a Changes file.
- Made file output *much* more robust. Postscript and raster file outputs now
give results that look nearly identical or identical compared with the
figure in the original plot window. Also, a window is not created
unnecessarily if the script only uses Prima to create the images.
- Added proper handling of weird/bad values for annotation positions. Now, if
you specify a position that includes 'bad, 'inf', or 'nan', the annotation
machinery will Just Work, by skipping the annotation drawing.
- Postscript output uses a feature of Prima v1.40 to set the postscript
output as EPS. This is important for proper rendering through LaTeX and
on Mac Preview.
[BUG FIXES]
- Fixed png and ps example scripts. These spuriously called PDL::IO::Pic due
some experiments I was running. These changes never should have gone into
the distribution. Oops.
- The twiddle() method of Simple now does nothing if Simple's plot() method is
overwritten. Overwriting the plot() method is supported, but code that
called twiddle() after calling said overwritten plot() would cause the
script to hang with no way to exit the event loop.
- The default apply() method in PDL::Graphics::Prima::Palette now correctly
supplies its arguments to the supplied subref.
- Logarithmic scaling detection works for ds::Grid (fixed assignment typo).
0.13 2013-03-13
[API CHANGES]
- Deprecated lm::Hold to make way for a new limit, lm::NextTick, to be
developed in the future.
- Renamed ds::Set to ds::Dist.
- Removed pset::CDF; see ds::Dist.
[DIFFERENT BEHAVIOR]
- Slightly repositioned the x-axis label so that tails on letters like 'y'
are no longer clipped with postscript output.
[ENHANCEMENTS]
- Made palettes much more robust.
- Numerous property handling improvements.
- Reduced the number of circular dependencies (and therefore memory leaks).
I'm sure there are other circular references, but at least a good many of
them were removed.
- Made annotation datasets more robust.
- Axis Component objects can now have arbitrary names.
- Improved ReadLine detection and integration, and added support for twiddling.
- Improved binning behavior for ppair::Histogram when bin boundaries are
not identical.
- Lots of documentation updates.
[BUG FIXES]
- Fixed non-functioning matrix_plot and imag_plot, which had been broken
since December of 2011!
[NEW FEATURES]
- Added bin types for ds::Dist, including bt::CDF, bt::Linear, bt::Log,
and bt::StrictLog.
- Created ds::Dist, which inherits from ds::Pair and can use all plot types
from that distribution type.
0.12 2013-01-21
[BUG FIXES]
- Included PDL::Graphics::Prima::ReadLine in the MANIFEST file.
0.11 2013-01-20
[BUG FIXES]
- Inherited autoscaling now works with Callback plot type.
[ENHANCEMENTS]
- We now have usable postscript output, though it's not perfect.
0.10 Not Released
- Another version bump gone awry.
0.09 2012-08-06
[BUG FIXES]
- Finally got save-to-image behavior working, thanks to Dmitry!
[ENHANCEMENTS]
- PDL::Drawing::Prima saw an extensive overhaul with the release of PDP v0.07,
one which handles singular as well as plural properties, and correctly
restores the canvas state after the drawing operation is complete. That
allowed me to simplify the canvas property handling in PDL::Graphics::Prima.
It also means that singular properties Just Work now! :-D
0.08 2012-07-01
[ENHANCEMENTS]
- Build.PL is more specific about its requirements.
- Super-simple pairwise api functions now accept single piddles as arguments,
taking them as y-values and creating sequential x-values.
0.07 2012-06-25
[BUG FIXES]
- The Palette suffered a divide by zero bug when sent data with identical
values. Also, empty piddles sent to Palette are now handled more gracefully.
- Linear scaling now handles degenerate input more gracefully. In particular,
when the data is all the same *negative* value, it now gives useful minima
and maxima.
- A recent revision in x autoscaling generated a bug in y autoscaling, such
that y-axes would autoscale even when I explicitly set their min and/or max.
[ENHANCEMENTS]
- The plot constructor now accepts axis objects. Before, it only accepted a
hash with the axis properties.
- Histogram autoscaling now performs the correct threaded calculations.
[NEW FEATURES]
- Added image_plot to the Simple interface.
0.06 Not Released
- I hadn't realized that I had already incremented the version number. Oops.
0.05 2012-03-15
- Minor docs typo fixes and bug fixes
0.04 2012-02-29
- Added dependency on Prima in the Build.PL file
0.03 2012-02-28
- Added dependency on PDL in the Build.PL file
0.02 2012-02-26
- First CPAN release
- Switched to Module::Build
[API CHANGES]
- Changed naming from pt::<Type> to pseq::<Type>.
- Differentiated datasets and introduced short-form dataset constructors.
- Switched name from pseq::<Type> to ppair::<Type>.
- Lots of naming consolidation.
[ENHANCEMENTS]
- Added first tests to check that the modules load.
- Smooth axis movement.
- Improved autoscaling.
[NEW FEATURES]
- Added ds::Func, ds::Image, and ds::Grid.
- Added pimage::Basic and pgrid::matrix.
- Preliminary postscript output.
0.01 2011-12-22
- Added pt::NGons, renamed to pt::Symbols; added lots of derived plot types;
added pt::TrendLines.
- Simple API now includes plot, line_plot, circle plot, triangle_plot,
square_plot, diamond_plot, cross_plot, X_plot, asterisk_plot, hist_plot,
matrix_plot, and func_plot.
- Right-click menu added.
- Postscript and clipboard output added.
0.00_05 2011-10-25
- Windows is now preliminarily supported.
- DataSets are now plotted in asciibetical order, by name.
0.00_04 2011-10-19
- Added PDL::Graphics::Prima::Simple and PDL::Graphics::Prima::Palette.
- Pushed label handling from a plot responsibility to an axis responsibility.
- Implemented collation-based autoscaling.
0.00_03 2011-09-20
- Added pt::Spikes, pt::CallBack, pt::ErrorBars, pt::ColorGrid
- Switched DataSet handling from being a tied array to a tied hash.
- Renamed from Prima::Ex::Graph to PDL::Graphics::Prima and shuffled the files
into a more standard CPAN distribution layout.
- Moved PDL::PP code into PDL::Drawing::Prima
- Added logarithmic scaling
0.00_02 2011-02-03
- First realization as a widget is completed under the name Prima::Ex::Graph.
The primary components of the library included Axis.pm, DataSet.pm,
Graph.pm, Limits.pm, PlotType.pm, Scaling.pm, and pdlprima.pd.
- Plot types included pt::Lines, pt::Blobs, and pt::Histogram
- Scaling.pm included linear scaling, but not yet logarithmic.
0.00_01 2011-01-20
- Basic line plotting, histogram binning and drawing, and axes scaling and
tick drawing were prototyped in per-widget onDraw callbacks. These callbacks
were added systematically to a widget via the endow_widget function.
- Very first plotting interface was a Prima::Drawable method called graph(),
followed shortly by an additional Drawable method called bin()
0.00_00 2011-01-15
- Initially conceived as PDL::PrimaPoly, a set of PDL bindings to Prima's
polyline method. This would eventually grow into PDL::Drawing::Prima.