wxMotif TODO
------------
-Updated: 16/10/98
+Updated: 28/12/98
-------------------------------o-------------------------
-High Priority
--------------
-
-- wxScreenDC
+General comment: see the following site for useful Motif widgets.
+ftp://ftp.x.org/contrib/widgets/motif
-- Extra wxBitmap formats. What about XPMs, can we assume
- libxpm exists and use that?
+Also, grep for TODO comments in source.
-- Work out why XFreeFont in font.cpp produces a segv. This is
- currently commented out, which presumably causes a memory leak.
+High Priority
+-------------
-- Bitmap versions of widgets (wxBitmapButton etc.)
+- Have a central/per app file for colour settings, with a wxWin
+ app to allow changing settings interactively.
-- wxRadioBox
+- Colour setting in widgets (almost done). Should scrollbars take
+ on the background colour? Not right for e.g. wxScrolledWindows,
+ so maybe have wxSystemSettings value for scrollbar colour, and/or
+ ability to set scrollbar colour independently.
-- wxRadioButton
+- Optimize wxWindow OnPaint to avoid flicker, collapsing Expose events
+ as per flicker fix in 1.68. It will be tricky to avoid
+ interfering with non-wxScrolledWindow widgets except by
+ explicitly testing for wxScrolledWindow.
-- wxComboBox: use combobox.c code as bundled in wxWin 1.68
+- Implementation of OnEraseBackground. How? Call OnEraseBackground
+ just before OnPaint? Will duplicate Xlib's own erase of the background.
+ However, this is usually OK, because the default wxWindow::OnEraseBackground
+ can do nothing (SetBackgroundColour will make the background look OK).
+ And if a custom OnEraseBackground uses the same colour as the window
+ background, no flicker will be seen. If it does something else, such as
+ painting a tiled bitmap, then a slight flicker might be seen unless
+ X can be persuaded not to repaint the window background by default.
-- wxGauge: use xmgauge as per wxWin 1.68
+- wxRadioBox doesn't show up in the controls sample, though it's
+ OK on other dialogs (e.g. printing sample).
- wxSpinButton
-- wxSlider
-
-- wxTextCtrl text file loading and saving.
-
-- A generic version of wxNotebook that can be used in wxMotif and
- other toolkits that don't have a native control. Perhaps use wxTab as a
- starting point.
-
-- MDI classes: use existing Motif widgets for this.
-
-- Dialogs e.g. wxFileSelector.
- Some others need tidying, such as the colour and font selectors.
-
-- Use generic wxTreeCtrl, wxListCtrl: enhance these.
+- wxToolTip
-- Write a better generic wxToolBar class than wxToolBarSimple.
- Alternatively, write a toolbar using Motif as described here:
- http://www.motifzone.com/tmd/articles/Kurt_Huhner/jun96.html.
- This article also explains how to implement tooltips.
+- Miscellaneous events.
-- Colour and font setting in widgets.
+- Use wxImage to load other formats into wxBitmaps, such as PNG, BMP.
-- wxSystemSettings
-
-- wxTimer
-
-- wxThread (hopefully, similar to wxGTK)
+Low Priority
+------------
-- Write makefiles for all samples.
+- Visuals: how to select an appropriate one? See Thomas Runge's
+ visual patch for 1.68 -- should be straightforward to port to 2.0.
-- Create some samples for testing.
+- Work out why XFreeFont in font.cpp produces a segv. This is
+ currently commented out, which presumably causes a memory leak.
-Low Priority
-------------
+- Better makefile system that can put objects in different dirs.
-- Print/preview framework in print.cpp (see wxGTK).
+- Extra wxBitmap formats: PNG, BMP. Could use old wxWin 1.68
+ wxImage code (derived from XV) for BMP/GIF but it's very bloated. However,
+ when implemented as extra bitmap handlers, the code won't be linked
+ unless needed. Update: see if wxImage can handle these formats.
- Enhance event handling such that you override e.g. left-click
and unless you call the base OnMouseEvent, the click won't be
- Get Dialog Editor working under Motif.
- New wxHelp version: try using the XmHTML widget at
- http://www.xs4all.nl/~ripley/XmHTML/
-
-- Optimize screen refresh for non-native widgets, e.g. wxWindow
- created with Create(), using technique in flicker patch for 1.68
- (see JACS for latest patch).
-
-- Copy and paste, drag and drop. Use a standard X drag
+ http://www.xs4all.nl/~ripley/XmHTML/.
+
+ We need to:
+ - make a minimal distribution under wx/src/xmhtml, just enough
+ to compile the source.
+ - add XMHTML_C_SRC to src/motif/makefile.unx with the source files
+ listed.
+ - make sure we can compile the sources, passing the correct
+ flags for zlib/png compilation.
+ - make a wxHTMLWindow class from e.g. examples/example_2.c. Should
+ probably make the cache and history facilities part of the class.
+ - add the driver code to src/motif/helphtml.cpp (a frame, toolbar,
+ history list).
+
+- Drag and drop. Use a standard X drag
and drop standard - see http://www.cco.caltech.edu/~jafl/xdnd/
or use Motif drag and drop as described here:
http://www.motifzone.com/tmd/articles/DnD/dnd.html
- Optimize colour management so we don't get clashes when e.g.
- Netscape is running.
+ Netscape is running. See:
+ http://www.motifzone.com/tmd/articles/John_Cwikla/index.html
+
+- wxRCConfig (a config class using X .rc files). Could simply
+ implement it in terms of current wxGet/WriteResource functions.
- wxCheckBoxList
-- Write generic wxDirDialog (directory selector).
+- wxBitmapCheckBox, wxBitmapRadioButton
-- Use native Motif dialogs for wxMessageBox.
+- Reimplement combobox using Lesstif's widget (avoiding GPL'ed
+ widget currently used).
- Miscellaneous classes e.g. wxJoystick (identical to GTK's one for
Linux)
+- Blit scaling
+
+- Get ODBC classes and sample working.
+- Work out why wxTextCtrl doesn't work as a stream buffer under
+ gcc
\ No newline at end of file