2000-07-15 19:51:35 +00:00
|
|
|
|
2003-12-09 01:23:28 +00:00
|
|
|
import wx
|
2000-07-15 19:51:35 +00:00
|
|
|
|
|
|
|
#---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
buttonDefs = {
|
2004-01-13 03:17:17 +00:00
|
|
|
814 : ('GridSimple', ' Simple wx.Grid, catching all events '),
|
|
|
|
815 : ('GridStdEdRend', ' wx.Grid showing Editors and Renderers '),
|
|
|
|
818 : ('GridHugeTable', ' A wx.Grid with a HUGE table (100 MILLION cells!) '),
|
|
|
|
817 : ('GridCustTable', ' wx.Grid using a custom Table, with non-string data '),
|
2003-03-25 06:35:27 +00:00
|
|
|
819 : ('GridEnterHandler',' Remapping keys to behave differently '),
|
|
|
|
820 : ('GridCustEditor', ' Shows how to create a custom Cell Editor '),
|
2004-01-13 03:17:17 +00:00
|
|
|
821 : ('GridDragable', ' A wx.Grid with dragable rows and columns '),
|
2003-12-09 01:23:28 +00:00
|
|
|
822 : ('GridDragAndDrop', ' Shows how to make a grid a drop target for files'),
|
2000-07-15 19:51:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2003-12-09 01:23:28 +00:00
|
|
|
class ButtonPanel(wx.Panel):
|
2000-07-15 19:51:35 +00:00
|
|
|
def __init__(self, parent, log):
|
2003-12-09 01:23:28 +00:00
|
|
|
wx.Panel.__init__(self, parent, -1)
|
2000-07-15 19:51:35 +00:00
|
|
|
self.log = log
|
|
|
|
|
2003-12-11 19:55:48 +00:00
|
|
|
box = wx.BoxSizer(wx.VERTICAL)
|
2003-11-21 07:36:53 +00:00
|
|
|
box.Add((20, 20))
|
2000-07-15 19:51:35 +00:00
|
|
|
keys = buttonDefs.keys()
|
|
|
|
keys.sort()
|
2003-12-09 01:23:28 +00:00
|
|
|
|
2000-07-15 19:51:35 +00:00
|
|
|
for k in keys:
|
|
|
|
text = buttonDefs[k][1]
|
2003-12-09 01:23:28 +00:00
|
|
|
btn = wx.Button(self, k, text)
|
|
|
|
box.Add(btn, 0, wx.ALIGN_CENTER|wx.ALL, 10)
|
|
|
|
self.Bind(wx.EVT_BUTTON, self.OnButton, btn)
|
2000-07-15 19:51:35 +00:00
|
|
|
|
|
|
|
self.SetSizer(box)
|
2006-11-16 23:43:03 +00:00
|
|
|
box.Fit(self)
|
|
|
|
|
2000-07-15 19:51:35 +00:00
|
|
|
|
|
|
|
def OnButton(self, evt):
|
|
|
|
modName = buttonDefs[evt.GetId()][0]
|
|
|
|
module = __import__(modName)
|
2000-11-04 07:38:17 +00:00
|
|
|
frame = module.TestFrame(None, self.log)
|
2003-03-25 06:35:27 +00:00
|
|
|
frame.Show(True)
|
2000-07-15 19:51:35 +00:00
|
|
|
|
|
|
|
|
|
|
|
#---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
def runTest(frame, nb, log):
|
|
|
|
win = ButtonPanel(nb, log)
|
|
|
|
return win
|
|
|
|
|
|
|
|
#---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
overview = """\
|
|
|
|
<html><body>
|
2004-01-13 03:17:17 +00:00
|
|
|
<h2>wx.Grid</h2>
|
2000-07-15 19:51:35 +00:00
|
|
|
|
|
|
|
This demo shows various ways of using the <b><i>new and
|
2004-01-13 03:17:17 +00:00
|
|
|
improved</i></b> wx.Grid class. Unfortunatly it has not been
|
2000-07-15 19:51:35 +00:00
|
|
|
documented yet, and while it is somewhat backwards compatible, if you
|
2004-01-13 03:17:17 +00:00
|
|
|
try to go by the current wx.Grid documentation you will probably just
|
2000-07-15 19:51:35 +00:00
|
|
|
confuse yourself.
|
|
|
|
<p>
|
|
|
|
You can look at the sources for these samples to learn a lot about how
|
|
|
|
the new classes work.
|
|
|
|
<p><ol>
|
|
|
|
<li><a href="GridSimple.py">GridSimple.py</a> A simple grid that shows
|
|
|
|
how to catch all the various events.
|
|
|
|
|
|
|
|
<p>
|
|
|
|
<li><a href="GridStdEdRend.py">GridStdEdRend.py</a> A grid that
|
|
|
|
uses non-default Cell Editors and Cell Renderers.
|
|
|
|
|
|
|
|
<p>
|
|
|
|
<li><a href="GridHugeTable.py">GridHugeTable.py</a> A grid that
|
|
|
|
uses a non-default Grid Table. This table is read-only and simply
|
|
|
|
generates on the fly a unique string for each cell.
|
|
|
|
|
|
|
|
<p>
|
|
|
|
<li><a href="GridCustTable.py">GridCustTable.py</a> This grid
|
|
|
|
shows how to deal with tables that have non-string data, and how Cell
|
|
|
|
Editors and Cell Renderers are automatically chosen based on the data
|
|
|
|
type.
|
|
|
|
|
|
|
|
<p>
|
|
|
|
<li><a href="GridEnterHandler.py">GridEnterHandler.py</a>This one
|
|
|
|
changes how the ENTER key works, moving the current cell left to right
|
|
|
|
and wrapping around to the next row when needed.
|
|
|
|
</ol>
|
|
|
|
<p>
|
|
|
|
|
|
|
|
"""
|
|
|
|
|
2002-08-24 21:44:02 +00:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
import sys,os
|
|
|
|
import run
|
2004-03-05 00:06:33 +00:00
|
|
|
run.main(['', os.path.basename(sys.argv[0])] + sys.argv[1:])
|
2002-08-24 21:44:02 +00:00
|
|
|
|