Demo updates for new wx namespace, from Jeff Grimmett
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@24723 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -1,28 +1,32 @@
|
||||
from wxPython.wx import *
|
||||
from wxPython.grid import *
|
||||
# 11/6/2003 - Jeff Grimmett (grimmtooth@softhome.net)
|
||||
#
|
||||
# o Updated for wx namespace
|
||||
# o Also corrected minor bug where 'true' was being used instead of 'True'.
|
||||
# Doesn't fail for * import (I guess that is still defined in wx), but does
|
||||
# in the manner we're importing wx now.
|
||||
|
||||
import wx
|
||||
import wx.grid as gridlib
|
||||
|
||||
#---------------------------------------------------------------------------
|
||||
|
||||
class CustomDataTable(wxPyGridTableBase):
|
||||
"""
|
||||
"""
|
||||
|
||||
class CustomDataTable(gridlib.PyGridTableBase):
|
||||
def __init__(self, log):
|
||||
wxPyGridTableBase.__init__(self)
|
||||
gridlib.PyGridTableBase.__init__(self)
|
||||
self.log = log
|
||||
|
||||
self.colLabels = ['ID', 'Description', 'Severity', 'Priority', 'Platform',
|
||||
'Opened?', 'Fixed?', 'Tested?', 'TestFloat']
|
||||
|
||||
self.dataTypes = [wxGRID_VALUE_NUMBER,
|
||||
wxGRID_VALUE_STRING,
|
||||
wxGRID_VALUE_CHOICE + ':only in a million years!,wish list,minor,normal,major,critical',
|
||||
wxGRID_VALUE_NUMBER + ':1,5',
|
||||
wxGRID_VALUE_CHOICE + ':all,MSW,GTK,other',
|
||||
wxGRID_VALUE_BOOL,
|
||||
wxGRID_VALUE_BOOL,
|
||||
wxGRID_VALUE_BOOL,
|
||||
wxGRID_VALUE_FLOAT + ':6,2',
|
||||
self.dataTypes = [gridlib.GRID_VALUE_NUMBER,
|
||||
gridlib.GRID_VALUE_STRING,
|
||||
gridlib.GRID_VALUE_CHOICE + ':only in a million years!,wish list,minor,normal,major,critical',
|
||||
gridlib.GRID_VALUE_NUMBER + ':1,5',
|
||||
gridlib.GRID_VALUE_CHOICE + ':all,MSW,GTK,other',
|
||||
gridlib.GRID_VALUE_BOOL,
|
||||
gridlib.GRID_VALUE_BOOL,
|
||||
gridlib.GRID_VALUE_BOOL,
|
||||
gridlib.GRID_VALUE_FLOAT + ':6,2',
|
||||
]
|
||||
|
||||
self.data = [
|
||||
@@ -67,9 +71,10 @@ class CustomDataTable(wxPyGridTableBase):
|
||||
self.SetValue(row, col, value)
|
||||
|
||||
# tell the grid we've added a row
|
||||
msg = wxGridTableMessage(self, # The table
|
||||
wxGRIDTABLE_NOTIFY_ROWS_APPENDED, # what we did to it
|
||||
1) # how many
|
||||
msg = gridlib.GridTableMessage(self, # The table
|
||||
gridlib.GRIDTABLE_NOTIFY_ROWS_APPENDED, # what we did to it
|
||||
1 # how many
|
||||
)
|
||||
|
||||
self.GetView().ProcessTableMessage(msg)
|
||||
|
||||
@@ -108,9 +113,9 @@ class CustomDataTable(wxPyGridTableBase):
|
||||
|
||||
|
||||
|
||||
class CustTableGrid(wxGrid):
|
||||
class CustTableGrid(gridlib.Grid):
|
||||
def __init__(self, parent, log):
|
||||
wxGrid.__init__(self, parent, -1)
|
||||
gridlib.Grid.__init__(self, parent, -1)
|
||||
|
||||
table = CustomDataTable(log)
|
||||
|
||||
@@ -123,8 +128,7 @@ class CustTableGrid(wxGrid):
|
||||
self.SetMargins(0,0)
|
||||
self.AutoSizeColumns(False)
|
||||
|
||||
EVT_GRID_CELL_LEFT_DCLICK(self, self.OnLeftDClick)
|
||||
|
||||
gridlib.EVT_GRID_CELL_LEFT_DCLICK(self, self.OnLeftDClick)
|
||||
|
||||
|
||||
# I do this because I don't like the default behaviour of not starting the
|
||||
@@ -136,17 +140,21 @@ class CustTableGrid(wxGrid):
|
||||
|
||||
#---------------------------------------------------------------------------
|
||||
|
||||
class TestFrame(wxFrame):
|
||||
class TestFrame(wx.Frame):
|
||||
def __init__(self, parent, log):
|
||||
wxFrame.__init__(self, parent, -1, "Custom Table, data driven Grid Demo", size=(640,480))
|
||||
p = wxPanel(self, -1, style=0)
|
||||
|
||||
wx.Frame.__init__(
|
||||
self, parent, -1, "Custom Table, data driven Grid Demo", size=(640,480)
|
||||
)
|
||||
|
||||
p = wx.Panel(self, -1, style=0)
|
||||
grid = CustTableGrid(p, log)
|
||||
b = wxButton(p, -1, "Another Control...")
|
||||
b = wx.Button(p, -1, "Another Control...")
|
||||
b.SetDefault()
|
||||
EVT_BUTTON(self, b.GetId(), self.OnButton)
|
||||
EVT_SET_FOCUS(b, self.OnButtonFocus)
|
||||
bs = wxBoxSizer(wxVERTICAL)
|
||||
bs.Add(grid, 1, wxGROW|wxALL, 5)
|
||||
self.Bind(wx.EVT_BUTTON, self.OnButton, b)
|
||||
b.Bind(wx.EVT_SET_FOCUS, self.OnButtonFocus)
|
||||
bs = wx.BoxSizer(wx.VERTICAL)
|
||||
bs.Add(grid, 1, wx.GROW|wx.ALL, 5)
|
||||
bs.Add(b)
|
||||
p.SetSizer(bs)
|
||||
|
||||
@@ -161,7 +169,7 @@ class TestFrame(wxFrame):
|
||||
|
||||
if __name__ == '__main__':
|
||||
import sys
|
||||
app = wxPySimpleApp()
|
||||
app = wx.PySimpleApp()
|
||||
frame = TestFrame(None, sys.stdout)
|
||||
frame.Show(True)
|
||||
app.MainLoop()
|
||||
|
Reference in New Issue
Block a user