f581a26df9
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@3279 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
382 lines
12 KiB
Plaintext
382 lines
12 KiB
Plaintext
wxPython README
|
|
---------------
|
|
|
|
Welcome to the wonderful world of wxPython!
|
|
|
|
Once you have installed the wxPython extension module, you can try it
|
|
out by going to the [install dir]\wxPython\demo directory and typing:
|
|
|
|
python demo.py
|
|
|
|
There are also some other sample files there for you to play with and
|
|
learn from.
|
|
|
|
If you selected to install the documentation then point your browser
|
|
to [install dir]\wxPython\docs\index.htm and you will then be looking
|
|
at the docs for wxWindows. For the most part you can use the C++ docs
|
|
as most classes and methods are used identically. Where there are
|
|
differences they are documented with a "wxPython Note."
|
|
|
|
On Win32 systems the binary self-installer creates a program group on
|
|
the Start Menu that contains a link to running the demo and a link to
|
|
the help file. To help you save disk space I'm now using Microsoft's
|
|
HTML Help format. If your system doesn't know what to do with the help
|
|
file, you can install the HTML Help Viewer as part of IE 4+, NT
|
|
Service Pack 4+, or the HTML Workshop at
|
|
|
|
http://msdn.microsoft.com/workshop/author/htmlhelp/download.asp.
|
|
|
|
|
|
|
|
Getting Help
|
|
------------
|
|
|
|
Since wxPython is a blending of multiple technologies, help comes from
|
|
multiple sources. See the http://alldunn.com/wxPython for details on
|
|
various sources of help, but probably the best source is the
|
|
wxPython-users mail list. You can view the archive or subscribe by
|
|
going to
|
|
|
|
http://starship.python.net/mailman/listinfo/wxpython-users
|
|
|
|
Or you can send mail directly to the list using this address:
|
|
|
|
wxpython-users@starship.python.net
|
|
|
|
----------------------------------------------------------------------
|
|
|
|
What's new in 2.1b2
|
|
--------------------
|
|
|
|
Added the missing wxWindow.GetUpdateRegion() method.
|
|
|
|
Made a new change in SWIG (update your patches everybody) that
|
|
provides a fix for global shadow objects that get an exception in
|
|
their __del__ when their extension module has already been deleted.
|
|
It was only a 1 line change in .../SWIG/Modules/pycpp.cxx at about
|
|
line 496 if you want to do it by hand.
|
|
|
|
It is now possible to run through MainLoop more than once in any one
|
|
process. The cleanup that used to happen as MainLoop completed (and
|
|
prevented it from running again) has been delayed until the wxc module
|
|
is being unloaded by Python.
|
|
|
|
I fixed a bunch of stuff in the C++ version of wxGrid so it wouldn't
|
|
make wxPython look bad.
|
|
|
|
wxWindow.PopupMenu() now takes a wxPoint instead of x,y. Added
|
|
wxWindow.PopupMenuXY to be consistent with some other methods.
|
|
|
|
Added wxGrid.SetEditInPlace and wxGrid.GetEditInPlace.
|
|
|
|
You can now provide your own app.MainLoop method. See
|
|
wxPython/demo/demoMainLoop.py for an example and some explaination.
|
|
|
|
Got the in-place-edit for the wxTreeCtrl fixed and added some demo
|
|
code to show how to use it.
|
|
|
|
Put the wxIcon constructor back in for GTK as it now has one that
|
|
matches MSW's.
|
|
|
|
Added wxGrid.GetCells
|
|
|
|
Added wxSystemSettings static methods as functions with names like
|
|
wxSystemSettings_GetSystemColour.
|
|
|
|
Removed wxPyMenu since using menu callbacks have been depreciated in
|
|
wxWindows. Use wxMenu and events instead.
|
|
|
|
Added alternate wxBitmap constructor (for MSW only) as
|
|
wxBitmapFromData(data, type, width, height, depth = 1)
|
|
|
|
Added a helper function named wxPyTypeCast that can convert shadow
|
|
objects of one type into shadow objects of another type. (Like doing
|
|
a down-cast.) See the implementation in wx.py for some docs.
|
|
|
|
Fixed wxImage GetData and SetData to properly use String objects for
|
|
data transfer.
|
|
|
|
Added access methods to wxGridEvent.
|
|
|
|
New Makefile/Setup files supporting multiple dynamic extension modules
|
|
for unix systems.
|
|
|
|
Fixes for the wxGLCanvas demo to work around a strange bug in gtk.
|
|
|
|
SWIG support routines now compiled separately instead of being bundled
|
|
in wx.cpp.
|
|
|
|
|
|
|
|
|
|
|
|
What's new in 2.1b1
|
|
--------------------
|
|
Fixed wxComboBox.SetSelection so that it actually sets the selected
|
|
item. (Actually just removed it from wxPython and let it default to
|
|
wxChoice.SetSelection which was already doing the right thing.)
|
|
|
|
Added the Printing Framework.
|
|
|
|
Switched back to using the wxWindows DLL for the pre-built Win32
|
|
version. The problem was needing to reinitialize static class info
|
|
data after loading each extension module.
|
|
|
|
Lots of little tweaks and additions to reflect changes to various
|
|
wxWindows classes.
|
|
|
|
Fixed a bug with attaching objects to tree items. Actually was a
|
|
symptom of a larger problem with not obtaining the interpreter lock
|
|
when doing any Py_DECREFs.
|
|
|
|
wxSizer and friends. Sizers are layout tools that manage a colection
|
|
of windows and sizers. Different types of sizers apply different
|
|
types of layout algorithms. You saw it here first! These classes are
|
|
not even in the wxWindows C++ library yet!
|
|
|
|
|
|
|
|
What's new in 2.0b9
|
|
-------------------
|
|
Bug fix for ListCtrl in test4.py (Was a missing file... DSM!)
|
|
|
|
Bug fix for occassional GPF on Win32 systems upon termination of a
|
|
wxPython application.
|
|
|
|
Added wxListBox.GetSelections returning selections as a Tuple.
|
|
|
|
Added a wxTreeItemData that is able to hold any Python object and be
|
|
associated with items in a wxTreeCtrl. Added test pytree.py to show
|
|
this feature off.
|
|
|
|
Added wxSafeYield function.
|
|
|
|
OpenGL Canvas can be optionally compiled in to wxPython.
|
|
|
|
Awesome new Demo Framework for showing off wxPython and for learning
|
|
how it all works.
|
|
|
|
The pre-built Win32 version is no longer distributing the wxWindows
|
|
DLL. It is statically linked with the wxWindows library instead.
|
|
|
|
Added a couple missing items from the docs.
|
|
|
|
Added wxImage, wxImageHandler, wxPNGHandler, wxJPEGHandler,
|
|
wxGIFHandler and wxBMPHandler.
|
|
|
|
Added new methods to wxTextCtrl.
|
|
|
|
Fixed some problems with how SWIG was wrapping some wxTreeCtrl
|
|
methods.
|
|
|
|
|
|
|
|
What's new in 2.0b8
|
|
-------------------
|
|
Support for using Python threads in wxPython apps.
|
|
|
|
Several missing methods from various classes.
|
|
|
|
Various bug fixes.
|
|
|
|
|
|
|
|
What's new in 2.0b7
|
|
-------------------
|
|
Added DLG_PNT and DLG_SZE convienience methods to wxWindow class.
|
|
|
|
Added missing constructor and other methods for wxMenuItem.
|
|
|
|
|
|
|
|
What's new in 2.0b6
|
|
-------------------
|
|
Just a quickie update to fix the self-installer to be compatible with
|
|
Python 1.5.2b2's Registry settings.
|
|
|
|
|
|
What's new in 2.0b5
|
|
-------------------
|
|
Well obviously the numbering scheme has changed. I did this to
|
|
reflect the fact that this truly is the second major revision of
|
|
wxPython, (well the third actually if you count the one I did for
|
|
wxWindows 1.68 and then threw away...) and also that it is associated
|
|
with the 2.0 version of wxWindows.
|
|
|
|
I have finally started documenting wxPython. There are several pages
|
|
in the wxWindows documentation tree specifically about wxPython, and I
|
|
have added notes within the class references about where and how wxPython
|
|
diverges from wxWindows.
|
|
|
|
Added wxWindow_FromHWND(hWnd) for wxMSW to construct a wxWindow from a
|
|
window handle. If you can get the window handle into the python code,
|
|
it should just work... More news on this later.
|
|
|
|
Added wxImageList, wxToolTip.
|
|
|
|
Re-enabled wxConfig.DeleteAll() since it is reportedly fixed for the
|
|
wxRegConfig class.
|
|
|
|
As usual, some bug fixes, tweaks, etc.
|
|
|
|
|
|
|
|
What's new in 0.5.3
|
|
-------------------
|
|
Added wxSashWindow, wxSashEvent, wxLayoutAlgorithm, etc.
|
|
|
|
Various cleanup, tweaks, minor additions, etc. to maintain
|
|
compatibility with the current wxWindows.
|
|
|
|
|
|
|
|
What's new in 0.5.0
|
|
-------------------
|
|
Changed the import semantics from "from wxPython import *" to "from
|
|
wxPython.wx import *" This is for people who are worried about
|
|
namespace pollution, they can use "from wxPython import wx" and then
|
|
prefix all the wxPython identifiers with "wx."
|
|
|
|
Added wxTaskbarIcon for wxMSW.
|
|
|
|
Made the events work for wxGrid.
|
|
|
|
Added wxConfig.
|
|
|
|
Added wxMiniFrame for wxGTK.
|
|
|
|
Changed many of the args and return values that were pointers to gdi
|
|
objects to references to reflect changes in the wxWindows API.
|
|
|
|
Other assorted fixes and additions.
|
|
|
|
|
|
|
|
|
|
What's new in 0.4.2
|
|
-------------------
|
|
|
|
wxPython on wxGTK works!!! Both dynamic and static on Linux and
|
|
static on Solaris have been tested. Many thanks go to Harm
|
|
<H.v.d.Heijden@phys.tue.nl> for his astute detective work on tracking
|
|
down a nasty DECREF bug. Okay so I have to confess that it was just a
|
|
DSM (Dumb Stupid Mistake) on my part but it was nasty none the less
|
|
because the behavior was so different on different platforms.
|
|
|
|
The dynamicly loaded module on Solaris is still segfaulting, so it
|
|
must have been a different issue all along...
|
|
|
|
|
|
|
|
What's New in 0.4
|
|
-----------------
|
|
|
|
1. Worked on wxGTK compatibility. It is partially working. On a
|
|
Solaris/Sparc box wxPython is working but only when it is statically
|
|
linked with the Python interpreter. When built as a dyamically loaded
|
|
extension module, things start acting weirdly and it soon seg-faults.
|
|
And on Linux both the statically linked and the dynamically linked
|
|
version segfault shortly after starting up.
|
|
|
|
2. Added Toolbar, StatusBar and SplitterWindow classes.
|
|
|
|
3. Varioius bug fixes, enhancements, etc.
|
|
|
|
----------------------------------------------------------------------
|
|
|
|
|
|
|
|
Build Instructions
|
|
------------------
|
|
I used SWIG (http://www.swig.org) to create the source code for the
|
|
extension module. This enabled me to only have to deal with a small
|
|
amount of code and only have to bother with the exceptional issues.
|
|
SWIG takes care of the rest and generates all the repetative code for
|
|
me. You don't need SWIG to build the extension module as all the
|
|
generated C++ code is included under the src directory.
|
|
|
|
I added a few minor features to SWIG to control some of the code
|
|
generation. If you want to playaround with this the patches are in
|
|
wxPython/SWIG.patches and they should be applied to the 1.1p5 version
|
|
of SWIG. These new patches are documented at
|
|
http://starship.skyport.net/crew/robind/#swig, and they should also
|
|
end up in the 1.2 version of SWIG.
|
|
|
|
wxPython is organized as a Python package. This means that the
|
|
directory containing the results of the build process should be a
|
|
subdirectory of a directory on the PYTHONPATH. (And preferably should
|
|
be named wxPython.) You can control where the build process will dump
|
|
wxPython by setting the TARGETDIR makefile variable. The default is
|
|
$(WXWIN)/utils/wxPython, where this README.txt is located. If you
|
|
leave it here then you should add $(WXWIN)/utils to your PYTHONPATH.
|
|
However, you may prefer to use something that is already on your
|
|
PYTHONPATH, such as the site-packages directory on Unix systems.
|
|
|
|
|
|
Win32
|
|
-----
|
|
|
|
1. Build wxWindows with wxUSE_RESOURCE_LOADING_IN_MSW set to 1 in
|
|
include/wx/msw/setup.h so icons can be loaded dynamically. While
|
|
there, make sure wxUSE_OWNER_DRAWN is also set to 1.
|
|
|
|
2. Change into the $(WXWIN)/utils/wxPython/src directory.
|
|
|
|
3. Edit makefile.vc and specify where your python installation is at.
|
|
You may also want to fiddle with the TARGETDIR variable as described
|
|
above.
|
|
|
|
4. Run nmake -f makefile.vc
|
|
|
|
5. If it builds successfully, congratulations! Move on to the next
|
|
step. If not then you can try mailing me for help. Also, I will
|
|
always have a pre-built win32 version of this extension module at
|
|
http://alldunn.com/wxPython/.
|
|
|
|
6. Change to the $(WXWIN)/utils/wxPython/demo directory.
|
|
|
|
7. Try executing the demo program. For example:
|
|
|
|
python demo.py
|
|
|
|
To run it without requiring a console, you can use the pythonw.exe
|
|
version of Python either from the command line or from a shortcut.
|
|
|
|
|
|
|
|
Unix
|
|
----
|
|
0. I configure wxWindows like this, YMMV:
|
|
|
|
./configure --with-gtk --disable-shared --enable-threads --disable-unicode
|
|
|
|
1. Change into the $(WXWIN)/utils/wxPython/src directory.
|
|
|
|
2. Edit Setup.in and ensure that the flags, directories, and toolkit
|
|
options are correct. See the above commentary about TARGETDIR. There
|
|
are a few sample Setup.in.[platform] files provided.
|
|
|
|
3. Run this command to generate a makefile:
|
|
|
|
make -f Makefile.pre.in boot
|
|
|
|
4. Run these commands to build and then install the wxPython extension
|
|
module:
|
|
|
|
make
|
|
make install
|
|
|
|
|
|
5. Change to the $(WXWIN)/utils/wxPython/demo directory.
|
|
|
|
6. Try executing the demo program. For example:
|
|
|
|
python demo.py
|
|
|
|
----------------
|
|
Robin Dunn
|
|
robin@alldunn.com
|
|
|
|
|
|
|