/[thuban]/branches/greater-ms3/thuban/ChangeLog
ViewVC logotype

Diff of /branches/greater-ms3/thuban/ChangeLog

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 776 by jonathan, Tue Apr 29 14:41:34 2003 UTC revision 889 by jonathan, Fri May 9 16:41:52 2003 UTC
# Line 1  Line 1 
1    2003-05-09  Jonathan Coles   <[email protected]>
2    
3            Introduces Range class from SciParam into the ClassGroupRange class,
4            and such ranges can now be saved and loaded from disk.
5    
6            Quantiles are now available in the Classification Generator.
7    
8            Initial support for building Queries on a table. Doesn't do anything
9            but run some tests.
10    
11            * Thuban/Model/classification.py: Explicit imports.
12            (ClassGroupRange): Use the Range class to store the underlying
13            range information. The interface remains the same, except for
14            GetRange(), and you can also supply a Range object as the min
15            parameter to SetRange or __init__.
16    
17            * Thuban/Model/load.py (XMLReader.encode): New. Encodes the given
18            string appropriately for use in Thuban. Fixes RTbug #1851.
19            (SessionLoader.end_projection): Handle the context of the
20            projection tag a bit better by looking at what objects are not
21            None. There was an assumption that a projection tag for a map
22            could occur before any layers.
23            (SessionLoader.start_clrange): Provide backward compatibility for
24            reading min/max values as well as the new range parameter.
25    
26            * Thuban/Model/map.py: Explicit imports.
27    
28            * Thuban/Model/resource.py: Import _.
29            (ProjFileSaver.write): write header using projfile.dtd.
30    
31            * Thuban/Model/save.py: Explicit imports.
32            (XMLWriter.encode): New. Encode the given string from a format
33            used by Thuban into UTF-8. Fixes RTbug #1851.
34    
35            * Thuban/UI/classgen.py: Explicit imports.
36            (ClassGenDialog.__init__): Clean up the code and add support
37            for Quantiles.
38            (ClassGenDialog.OnOK): Add support for Quantiles.
39            (GenQuantilesPanel): New. Input panel for Quantiles.
40            (ClassGenerator, CustomRamp, MonochromaticRamp, GreyRamp, RedRamp,
41            GreenRamp, BlueRamp, HotToColdRamp): Move to Thuban/Model/classgen.py
42    
43            * Thuban/Model/classgen.py: New. Contains all the classes named above.
44    
45            * Thuban/UI/classifier.py: Explicit imports.
46            (ClassTable.GetValueAsCust, ClassTable.__ParseInput,
47            ClassTable.SetValueAsCustom): Reworked to use new Range class.
48    
49            * Thuban/UI/legend.py: Explicit imports.
50    
51            * Thuban/UI/mainwindow.py: Add support for the Join Dialog. Added
52            a Table menu and associated method calls.
53            (MainWindow.choose_color): Removed. No longer needed.
54    
55            * Thuban/UI/projdialog.py (ProjFrame.__VerifyButtons): Save button
56            should be disabled if no projection is selected in the available
57            list.
58    
59            * Thuban/UI/renderer.py: Explicit imports.
60    
61            * Thuban/UI/tableview.py (TableGrid.OnRangeSelect): Fix some issues
62            with correctly selecting the rows and issuing the right events.
63            Be sure to call Skip() to allow the grid to do some of its own
64            handling which allows the rows to actually be selected.
65            (LayerTableGrid.select_shapes): Rename from select_shape. Supports
66            selecting multiple shapes.
67            (LayerTableFrame): Support for building Queries.
68            (LayerTableFrame.select_shapes): Allow multiple shapes to be selected.
69    
70            * Thuban/UI/tree.py: Explicit imports.
71    
72            * Thuban/UI/view.py (MapCanvas): Delegate "SelectedShapes" so the
73            table view can call it.
74    
75            * test/test_classification.py: Explicit imports.
76            (TestClassification.test_ClassGroupRange): Fix test for new
77            Range class.
78    
79            * Doc/thuban.dtd: Add range parameter for clrange.
80    
81            * Thuban/Model/range.py: Taken from SciParam. Used as the underlying
82            object in ClassGroupRange, and also uesd for inputting ranges in
83            the classifer table and elsewhere.
84    
85            * Thuban/UI/join.py: New. Initial Join dialog. No real functionality
86            yet.
87    
88    2003-05-09  Frank Koormann <[email protected]>
89    
90            * Thuban/UI/scalebar.py (DrawScaleBar): Draw only if interval > 0.0.
91    
92    2003-05-08  Frank Koormann <[email protected]>
93    
94            Coding style updates
95    
96            * test/test_scalebar.py: Replaced tab indentation by spaces.
97    
98            * Thuban/UI/scalebar.py: Explicit imports.
99    
100    2003-05-08  Frank Koormann <[email protected]>
101    
102            * Thuban/UI/scalebar.py
103            (ScaleBar.DrawScalebar): Format string bug fixed.
104    
105    2003-05-08  Frank Koormann <[email protected]>
106    
107            Reorganization of scalebar component (no wx in Thuban/Model)
108    
109            * Thuban/Model/scalebar.py: Rendering moved to Thuban/UI/scalebar.py
110            (deriveInterval):
111            Calculate scalebar interval and unit which fits in width for scale.
112            (roundInterval): Round float.
113    
114            * Thuban/UI/scalebar.py (ScaleBar): Scalebar rendering
115    
116            * test/test_scalebar.py: Test for Thuban/Model/scalebar.py methods.
117    
118            * Thuban/UI/legend.py: Import Thuban.UI.scalebar
119    
120    2003-05-08  Frank Koormann <[email protected]>
121    
122            * Thuban/UI/legend.py (ScalebarBitmap.SetCanvas):
123            Initialize ScaleBar with canvas.map
124    
125            * Thuban/Model/scalebar.py (ScaleBar.roundInterval()): New,
126            round intervals to display smarter lengths
127            (ScaleBar.DrawScalebar): Draw Scalebar only if the map contains a
128            layer. If the maps has no projection applied grey the scalebar.
129    
130    2003-05-07  Frank Koormann <[email protected]>
131            
132            Basic Scalebar features added.
133    
134            * Thuban/Model/scalebar.py (ScaleBar): New, scalebar rendering.
135    
136            * Thuban/UI/legend.py (LegendPanel): Added scalebar bitmap
137            (ScaleBarBitmap): New, links the scalebar bitmap with view messages
138            and the renderer.
139    
140            * Thuban/UI/view.py (MapCanvas.set_view_transform): Issue SCALE_CHANGED.
141    
142            * Thuban/UI/messages.py: SCALE_CHANGED added.
143    
144    2003-05-07  Bernhard Herzog  <[email protected]>
145    
146            * Thuban/Model/session.py (Session.__init__): New instance
147            variable shapestores to hold a list of all open shapestore objects
148            (Session.ShapeStores): New. Accessor method for the shapestores
149            list.
150            (Session._add_shapestore, Session._clean_weak_store_refs): New.
151            Internal methods to maintain the shapestores list.
152            (Session.Tables): New. Return all tables open in the session.
153            (Session.OpenShapefile): Insert the new ShapeStore into the
154            shapestores list.
155    
156            * test/test_session.py (TestSessionSimple.test_initial_state): Add
157            tests for ShapeStores and Tables
158            (TestSessionWithContent.test_shape_stores)
159            (TestSessionWithContent.test_tables): New. Test cases for
160            ShapeStores and Tables
161    
162    2003-05-07  Bernhard Herzog  <[email protected]>
163    
164            * Thuban/Model/transientdb.py (TransientTableBase.ReadRowAsDict):
165            Add comments about the optimizations used.
166            (AutoTransientTable.ReadValue, TransientTableBase.ReadValue): New.
167            Implement the ReadValue table interface method.
168    
169            * test/test_transientdb.py
170            (TestTransientTable.run_iceland_political_tests)
171            (TestTransientTable.test_transient_joined_table): Add tests for
172            ReadValue
173    
174    2003-05-07  Frank Koormann <[email protected]>
175    
176            * Resources/Bitmaps/fulllayerextent.xpm,
177            Resources/Bitmaps/fullselextent.xpm: Replaced the place holders with
178            new icons.
179    
180    2003-05-06  Bernhard Herzog  <[email protected]>
181    
182            * Thuban/Model/transientdb.py (AutoTransientTable.SimpleQuery):
183            New. Simply delegate to the transient table's version.
184    
185            * test/test_transientdb.py
186            (TestTransientTable.test_auto_transient_table_query): New. Test
187            case for AutoTransientTable's SimpleQuery
188    
189    2003-05-06  Bernhard Herzog  <[email protected]>
190    
191            * Thuban/Model/transientdb.py (TransientTableBase.SimpleQuery):
192            Implement a simple query method for the query dialog
193            (TransientTableBase.create): Add an INTEGER PRIMARY KEY that holds
194            the row index or shapeid.
195            (TransientTable.create): Insert the right value of the row index
196            (TransientJoinedTable.create): Copy the row index of the left
197            table to the joined result table
198    
199            * test/test_transientdb.py
200            (TestTransientTable.test_transient_table_read_twice): Fix
201            doc-string
202            (TestTransientTable.test_transient_table_query): New. Test for the
203            SimpleQuery method
204    
205    2003-05-06  Bernhard Herzog  <[email protected]>
206    
207            Convert all table users to use the new table interface. This only
208            covers Thuban itself, not GREAT-ER or other applications built on
209            Thuban yet, so the compatibility interface stays in place for the
210            time being but it now issues DeprecationWarnings.
211    
212            Finally, the new Table interface has a new method, HasColumn.
213    
214            * Thuban/Model/table.py (OldTableInterfaceMixin): All methods
215            issue deprecation warnings when they're. The warnings refer to the
216            caller of the method.
217            (OldTableInterfaceMixin.__deprecation_warning): New. Helper method
218            for the deprecation warnings
219    
220            * test/test_table.py: Ignore the deprecation warnings for the old
221            table in the tests in this module. The purpose of the tests is to
222            test the old interface, after all.
223    
224            * test/test_transientdb.py
225            (TestTransientTable.run_iceland_political_tests): Use the
226            constants for the types. Add a test for HasColumn
227            (TestTransientTable.test_transient_joined_table): Adapt to new
228            table interface. Add a test for HasColumn
229            (TestTransientTable.test_transient_table_read_twice): Adapt to new
230            table interface
231    
232            * Thuban/UI/tableview.py (DataTable.SetTable, DataTable.GetValue):
233            Adapt to new table interface
234    
235            * Thuban/UI/renderer.py (MapRenderer.draw_shape_layer): Adapt to
236            new table interface
237    
238            * Thuban/UI/controls.py (RecordListCtrl.fill_list)
239            (RecordTable.SetTable): Adapt to new table interface
240    
241            * Thuban/UI/classifier.py (Classifier.__init__)
242            (Classifier.__init__): Adapt to new table interface
243    
244            * Thuban/UI/classgen.py (ClassGenDialog.__init__)
245            (GenUniformPanel._OnRetrieve, GenUniquePanel._OnRetrieve): Adapt
246            to new table interface
247    
248            * Thuban/Model/transientdb.py (TransientTableBase.HasColumn)
249            (AutoTransientTable.HasColumn): Implement the new table interface
250            method
251            (AutoTransientTable.ReadRowAsDict, AutoTransientTable.ValueRange)
252            (AutoTransientTable.UniqueValues): Adapt to new table interface
253    
254            * Thuban/Model/layer.py (Layer.SetShapeStore, Layer.GetFieldType):
255            Adapt to new table interface
256    
257            * test/test_layer.py (TestLayer.open_shapefile): Helper method to
258            simplify opening shapefiles a bit easier.
259            (TestLayer.test_arc_layer, TestLayer.test_polygon_layer)
260            (TestLayer.test_point_layer): Use the new helper method
261            (TestLayer.test_get_field_type): New. Test for the GetFieldType
262            method
263    
264            * test/test_dbf_table.py (TestDBFTable.test_has_column): Test for
265            the new table method
266    
267            * test/test_memory_table.py (TestMemoryTable.test_has_column):
268            Test for the new table method HasColumn
269    
270    2003-05-06  Jonathan Coles   <[email protected]>
271    
272            Addresses the "Selection Extent" wish of RTbug #1787.
273    
274            * Resources/Bitmaps/fulllayerextent.xpm,
275            Resources/Bitmaps/fullselextent.xpm: Bitmaps for layer and selection
276            extent. These are just place holders for the real bitmaps.
277    
278            * Thuban/Model/layer.py (Shape): Since a Shape is immutable only
279            calculate the bounding box once (the first time compute_bbox() is
280            called).
281            (Layer.ShapesBoundingBox): New. Given a list of shape ids, return
282            the bounding box for the shapes in lat/long coordinates.
283    
284            * Thuban/UI/mainwindow.py: Added new "Full selection extent" menu
285            option.
286            (MainWindow.has_selected_shapes): New. Returns true if there are
287            any selected shapes.
288            (MainWindow.FullSelectionExtent): New. Calls
289            MapCanvas.FitSelectedToWindow() when the user selects the menu option.
290            (_has_selected_shapes): New. Returns true if there are any
291            selected shapes.
292    
293            * Thuban/UI/selection.py (Selection.HasSelectedShapes): New. Returns
294            true if there are any selected shapes.
295    
296            * Thuban/UI/view.py (MapCanvas): Added delegated method
297            HasSelectedShapes.
298            (MapCanvas.FitSelectedToWindow): New. Centers and scales any selected
299            shapes on the canvas using the map projection (if any).
300    
301            * test/test_layer.py (TestLayer.test_arc_layer): Add some tests
302            for Layer.ShapesBoundingBox().
303    
304    2003-05-06  Bernhard Herzog  <[email protected]>
305    
306            * Resources/Projections/defaults.proj: Fix spelling of Mercator
307    
308    2003-05-05  Jonathan Coles   <[email protected]>
309    
310            Addresses the "Full Layer Extent" wish of RTbug #1787.
311    
312            * Resources/Projections/defaults.proj: Added UK National Grid.
313    
314            * Thuban/UI/mainwindow.py: Added new "Full layer extent" menu option.
315            (MainWindow.FullLayerExtent): New. Calls MapCanvas.FitLayerToWindow()
316            when the user selects the menu option.
317    
318            * Thuban/UI/view.py (MapCanvas.FitLayerToWindow): New. Centers and
319            scales the given layer on the canvas using the map projection.
320    
321    2003-05-05  Bernhard Herzog  <[email protected]>
322    
323            Convert the table implementations to a new table interface. All
324            tables use a common mixin class to provide backwards compatibility
325            until all table users have been updated.
326    
327            * Thuban/Model/table.py (OldTableInterfaceMixin): Mixin class to
328            provide backwards compatibility for table classes implementing the
329            new interface
330            (DBFTable, MemoryTable): Implement the new table interface. Use
331            OldTableInterfaceMixin as base for compatibility
332            (DBFColumn, MemoryColumn): New. Column description for DBFTable
333            and MemoryTable resp.
334    
335            * test/test_dbf_table.py: New. Test cases for the DBFTable with
336            the new table interface.
337    
338            * test/test_memory_table.py: New. Test cases for the MemoryTable
339            with the new table interface.
340    
341            * test/test_table.py: Document the all tests in this file as only
342            for backwards compatibility. The equivalent tests for the new
343            interface are in test_memory_table.py and test_dbf_table.py
344            (MemoryTableTest.test_read): field_info should be returning tuples
345            with four items
346            (MemoryTableTest.test_write): Make doc-string a more precise.
347    
348            * Thuban/Model/transientdb.py (TransientTableBase): Convert to new
349            table interface. Derive from from OldTableInterfaceMixin for
350            compatibility.
351            (TransientTableBase.create): New intance variable column_map to
352            map from names and indices to column objects
353            (TransientTable.create): Use the new table interface of the input
354            table
355            (AutoTransientTable): Convert to new table interface. Derive from
356            from OldTableInterfaceMixin for compatibility.
357            (AutoTransientTable.write_record): Removed. It's not implemented
358            yet and we still have to decide how to handle writing with the new
359            table and data framework.
360    
361            * test/test_transientdb.py
362            (TestTransientTable.run_iceland_political_tests)
363            (TestTransientTable.test_transient_joined_table): Use the new
364            table interface
365    
366    2003-05-05  Jonathan Coles   <[email protected]>
367    
368            This is namely a collection of UI updates to improve user interactivity.
369            Tabbing between controls now exists and you can use ESC to close dialog
370            boxes; ENTER will active the default button.
371    
372            * Thuban/UI/classgen.py (ClassGenDialog.__init__): Rearrange the
373            order that the controls are created so that tabbing works correctly.
374            (ClassGenDialog.OnOK): Renamed from _OnGenerate() so that the
375            wxDialog can handle the default button correctly.
376            (ClassGenDialog.OnCancel): Renamed from _OnCloseBtn() for the
377            same reasons as for OnOK.
378            (GenUniformPanel._OnRetrieve): Call wxBeginBusyCursor/wxEndBusyCursor
379            when we ask the table for the maximum/minimum values of a field
380            which could take a very long time.
381    
382            * Thuban/UI/classifier.py (Classifier.__init__): Rearrange the
383            order that the controls are created so that tabbing works correctly.
384            (SelectPropertiesDialog.__init__): Rearrange the order that the
385            controls are created so that tabbing works correctly.
386    
387            * Thuban/UI/dialogs.py: Copied NonModalDialog box and changed it
388            to derive from a wxDialog but behave like the original implementation
389            which was derived from a wxFrame. wxDialog provides useful key
390            handling functionality like ESC calling OnCancel and ENTER calling
391            OnOK which is lost with wxFrame.
392    
393            * Thuban/UI/mainwindow.py: Add "..." to menu items that will open
394            new dialogs.
395    
396            * Thuban/UI/projdialog.py (ProjFrame.__init__): Rearrange the
397            order that the controls are created so that tabbing works correctly.
398            (ProjFrame.OnApply): Renamed from _OnTry() to use wxDialog behaviour.
399            (ProjFrame.OnOK): Renamed from _OnOK() to use wxDialog behaviour.
400            (ProjFrame.OnCancel): Renamed from _OnClose() to use wxDialog behaviour.
401            (ProjPanel.__init__): Add "Airy" to the list of ellipsoids so we
402            can provide the "UK National Grid" as a default projection.
403            (UTMPanel.__init__): Rearrange the order that the controls are
404            created so that tabbing works correctly.
405    
406    2003-05-05  Bernhard Herzog  <[email protected]>
407    
408            * extensions/thuban/wxproj.cpp: Fix some of the comments.
409            (project_point): If a map projection but no layer projection is
410            given, convert degrees to radians before applying the map
411            projection.
412    
413            * Thuban/UI/tableview.py (TableGrid.disallow_messages)
414            (TableGrid.allow_messages): New methods to make it possible to
415            inhibit message sending.
416            (TableGrid.issue): Only send the message if not inhibited.
417            (LayerTableGrid.select_shape): Use the new methods to make sure
418            that no ROW_SELECTED message is sent while we're updating the
419            selected rows to match the selected shapes.
420    
421    2003-05-02  Jan-Oliver Wagner <[email protected]>
422    
423            Implementation of MemoryTable.
424    
425            * Thuban/Model/table.py (MemoryTable): New. Quite simple table
426            implementation that operates on a list of tuples. All of the data
427            are kept in the memory.
428    
429            * test/test_table.py (MemoryTableTest): New.
430    
431            * test/test_transientdb.py (SimpleTable): Removed.
432            (TestTransientTable.test_transient_joined_table,
433            (TestTransientTable.test_transient_table_read_twice): Replaced
434            SimpleTable by MemoryTable.
435    
436    2003-04-30  Jonathan Coles   <[email protected]>
437    
438            * Data/iceland_sample.thuban: Now contains correct projections
439            for each of the layers.
440    
441            * Resources/Projections/defaults.proj: Geographic projection
442            contains unit conversion parameter.
443    
444    2003-04-30  Jonathan Coles   <[email protected]>
445    
446            The most important part of this putback is the projection changes.
447            It should now be possible to specify the projection that a layer
448            is in and then specify a different projection for the map. The
449            projection dialog has an extra parameter for a geographic projection
450            which lets the user select if the input is in degrees or radians.
451    
452            * Thuban/Model/layer.py (Layer.ShapesInRegion): Fix docstring
453            to say that the parameter is a tuple of unprojected
454            points (which is what the callers to this method were assuming).
455            Also, since the points are unprojected we need to projected them.
456    
457            * Thuban/UI/legend.py (LegendTree.MoveCurrentItemUp,
458            LegendTree.MoveCurrentItemDown): If the layer or any of the layer's
459            groups are selected, move the layer up/down. Fixes RTbug #1833.
460    
461            * Thuban/UI/mainwindow.py: Move menu item map_rename up.
462    
463            * Thuban/UI/projdialog.py (ProjFrame._OnSave): Add missing
464            parameter in call to SetClientData.
465            (GeoPanel): Add support for selecting the units that the
466            source data is in (Radians or Degrees).
467    
468            * Thuban/UI/renderer.py (MapRenderer.draw_shape_layer): Optimize
469            the rendering loop by reducing the number of if's, removing the
470            unnecessary try/except block, and checking if the old group
471            is the same as the new one (which happens a lot if there is
472            no classification, or lots of shapes are in the same group).
473    
474            * Thuban/UI/view.py (MapCanvas.OnPaint): Add a try/except block
475            around the redraw routine to try to catch problems that the user
476            may create by selecting invalid projections for the data set and
477            map. Clears the display if there are any problems and prints the
478            error.
479            (MapCanvas.do_redraw): Use DC.Clear() instead of drawing a filled
480            rectangle.
481    
482            * extensions/thuban/wxproj.cpp (project_point): First invert the
483            supplied point (which should be in projected coordinates) using
484            the layer's projection and then project the point using the
485            map's projection.
486            (project_points): Use project_point() to project each point.
487    
488    2003-04-30  Jan-Oliver Wagner <[email protected]>
489    
490            * Thuban/Model/layer.py (Layer.SetShapeStore): Fixed a bug:
491            don't set the Classification to None if the classfication field
492            is None (ie only a DEFAULT).
493    
494    2003-04-30  Bernhard Herzog  <[email protected]>
495    
496            * Thuban/UI/view.py: Fix some typos.
497    
498            * Thuban/UI/mainwindow.py (MainWindow.identify_view_on_demand): Do
499            not pop up the dialog if the selection becomes empty (this could
500            happen if e.g. a new selection is opened while the identify tool
501            is active and dialog had been closed)
502    
503    2003-04-30  Bernhard Herzog  <[email protected]>
504    
505            * Thuban/Model/transientdb.py (TransientTableBase.__init__): New
506            instance variable read_record_last_result
507            (TransientTableBase.read_record): Make sure reading the same
508            record twice works. The implementation uses the new instance
509            variable read_record_last_result
510    
511            * test/test_transientdb.py
512            (TestTransientTable.test_transient_table_read_twice): New test
513            case for the above bug-fix.
514    
515    2003-04-29  Jonathan Coles   <[email protected]>
516    
517            * Thuban/common.py: Removed. No longer needed Str2Num. RTbug #1832.
518    
519            * Thuban/UI/classgen.py: Remove all uses of Str2Num.
520    
521            * Thuban/UI/classifier.py: Remove all uses of Str2Num.
522            (ClassTable.SetValueAsCustom): Rename keyword argument in
523            ClassGroup* constructors to match argument name.
524    
525    2003-04-29  Bernhard Herzog  <[email protected]>
526    
527            * Thuban/Model/session.py (Session.Destroy): Explicitly close the
528            transient DB if it exists to make sure it doesn't leave a journal
529            file in the temp directory.
530    
531            * Thuban/Model/transientdb.py (TransientDatabase.close): Set
532            self.conn to None after closing the connection to make sure it's
533            not closed twice
534    
535  2003-04-29  Jonathan Coles   <[email protected]>  2003-04-29  Jonathan Coles   <[email protected]>
536    
537          Add a visible parameter in the layer XML tag. The default value is          Add a visible parameter in the layer XML tag. The default value is

Legend:
Removed from v.776  
changed lines
  Added in v.889

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26