git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/branches/WX_2_8_BRANCH@44519 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
		
			
				
	
	
		
			258 lines
		
	
	
		
			9.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			258 lines
		
	
	
		
			9.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| 
 | |
| import  wx
 | |
| import  wx.grid             as  gridlib
 | |
| #import  wx.lib.mixins.grid  as  mixins
 | |
| 
 | |
| #---------------------------------------------------------------------------
 | |
| 
 | |
| class SimpleGrid(gridlib.Grid): ##, mixins.GridAutoEditMixin):
 | |
|     def __init__(self, parent, log):
 | |
|         gridlib.Grid.__init__(self, parent, -1)
 | |
|         ##mixins.GridAutoEditMixin.__init__(self)
 | |
|         self.log = log
 | |
|         self.moveTo = None
 | |
| 
 | |
|         self.Bind(wx.EVT_IDLE, self.OnIdle)
 | |
| 
 | |
|         self.CreateGrid(25, 25)#, gridlib.Grid.SelectRows)
 | |
|         ##self.EnableEditing(False)
 | |
| 
 | |
|         # simple cell formatting
 | |
|         self.SetColSize(3, 200)
 | |
|         self.SetRowSize(4, 45)
 | |
|         self.SetCellValue(0, 0, "First cell")
 | |
|         self.SetCellValue(1, 1, "Another cell")
 | |
|         self.SetCellValue(2, 2, "Yet another cell")
 | |
|         self.SetCellValue(3, 3, "This cell is read-only")
 | |
|         self.SetCellFont(0, 0, wx.Font(12, wx.ROMAN, wx.ITALIC, wx.NORMAL))
 | |
|         self.SetCellTextColour(1, 1, wx.RED)
 | |
|         self.SetCellBackgroundColour(2, 2, wx.CYAN)
 | |
|         self.SetReadOnly(3, 3, True)
 | |
| 
 | |
|         self.SetCellEditor(5, 0, gridlib.GridCellNumberEditor(1,1000))
 | |
|         self.SetCellValue(5, 0, "123")
 | |
|         self.SetCellEditor(6, 0, gridlib.GridCellFloatEditor())
 | |
|         self.SetCellValue(6, 0, "123.34")
 | |
|         self.SetCellEditor(7, 0, gridlib.GridCellNumberEditor())
 | |
| 
 | |
|         self.SetCellValue(6, 3, "You can veto editing this cell")
 | |
| 
 | |
|         #self.SetRowLabelSize(0)
 | |
|         #self.SetColLabelSize(0)
 | |
| 
 | |
|         # attribute objects let you keep a set of formatting values
 | |
|         # in one spot, and reuse them if needed
 | |
|         attr = gridlib.GridCellAttr()
 | |
|         attr.SetTextColour(wx.BLACK)
 | |
|         attr.SetBackgroundColour(wx.RED)
 | |
|         attr.SetFont(wx.Font(10, wx.SWISS, wx.NORMAL, wx.BOLD))
 | |
| 
 | |
|         # you can set cell attributes for the whole row (or column)
 | |
|         self.SetRowAttr(5, attr)
 | |
| 
 | |
|         self.SetColLabelValue(0, "Custom")
 | |
|         self.SetColLabelValue(1, "column")
 | |
|         self.SetColLabelValue(2, "labels")
 | |
| 
 | |
|         self.SetColLabelAlignment(wx.ALIGN_LEFT, wx.ALIGN_BOTTOM)
 | |
| 
 | |
|         #self.SetDefaultCellOverflow(False)
 | |
|         #r = gridlib.GridCellAutoWrapStringRenderer()
 | |
|         #self.SetCellRenderer(9, 1, r)
 | |
| 
 | |
|         # overflow cells
 | |
|         self.SetCellValue( 9, 1, "This default cell will overflow into neighboring cells, but not if you turn overflow off.");
 | |
|         self.SetCellSize(11, 1, 3, 3);
 | |
|         self.SetCellAlignment(11, 1, wx.ALIGN_CENTRE, wx.ALIGN_CENTRE);
 | |
|         self.SetCellValue(11, 1, "This cell is set to span 3 rows and 3 columns");
 | |
| 
 | |
| 
 | |
|         editor = gridlib.GridCellTextEditor()
 | |
|         editor.SetParameters('10')
 | |
|         self.SetCellEditor(0, 4, editor)
 | |
|         self.SetCellValue(0, 4, "Limited text")
 | |
| 
 | |
|         renderer = gridlib.GridCellAutoWrapStringRenderer()
 | |
|         self.SetCellRenderer(15,0, renderer)
 | |
|         self.SetCellValue(15,0, "The text in this cell will be rendered with word-wrapping")
 | |
| 
 | |
|         
 | |
|         # test all the events
 | |
|         self.Bind(gridlib.EVT_GRID_CELL_LEFT_CLICK, self.OnCellLeftClick)
 | |
|         self.Bind(gridlib.EVT_GRID_CELL_RIGHT_CLICK, self.OnCellRightClick)
 | |
|         self.Bind(gridlib.EVT_GRID_CELL_LEFT_DCLICK, self.OnCellLeftDClick)
 | |
|         self.Bind(gridlib.EVT_GRID_CELL_RIGHT_DCLICK, self.OnCellRightDClick)
 | |
| 
 | |
|         self.Bind(gridlib.EVT_GRID_LABEL_LEFT_CLICK, self.OnLabelLeftClick)
 | |
|         self.Bind(gridlib.EVT_GRID_LABEL_RIGHT_CLICK, self.OnLabelRightClick)
 | |
|         self.Bind(gridlib.EVT_GRID_LABEL_LEFT_DCLICK, self.OnLabelLeftDClick)
 | |
|         self.Bind(gridlib.EVT_GRID_LABEL_RIGHT_DCLICK, self.OnLabelRightDClick)
 | |
| 
 | |
|         self.Bind(gridlib.EVT_GRID_ROW_SIZE, self.OnRowSize)
 | |
|         self.Bind(gridlib.EVT_GRID_COL_SIZE, self.OnColSize)
 | |
| 
 | |
|         self.Bind(gridlib.EVT_GRID_RANGE_SELECT, self.OnRangeSelect)
 | |
|         self.Bind(gridlib.EVT_GRID_CELL_CHANGE, self.OnCellChange)
 | |
|         self.Bind(gridlib.EVT_GRID_SELECT_CELL, self.OnSelectCell)
 | |
| 
 | |
|         self.Bind(gridlib.EVT_GRID_EDITOR_SHOWN, self.OnEditorShown)
 | |
|         self.Bind(gridlib.EVT_GRID_EDITOR_HIDDEN, self.OnEditorHidden)
 | |
|         self.Bind(gridlib.EVT_GRID_EDITOR_CREATED, self.OnEditorCreated)
 | |
| 
 | |
| 
 | |
|     def OnCellLeftClick(self, evt):
 | |
|         self.log.write("OnCellLeftClick: (%d,%d) %s\n" %
 | |
|                        (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
 | |
|         evt.Skip()
 | |
| 
 | |
|     def OnCellRightClick(self, evt):
 | |
|         self.log.write("OnCellRightClick: (%d,%d) %s\n" %
 | |
|                        (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
 | |
|         evt.Skip()
 | |
| 
 | |
|     def OnCellLeftDClick(self, evt):
 | |
|         self.log.write("OnCellLeftDClick: (%d,%d) %s\n" %
 | |
|                        (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
 | |
|         evt.Skip()
 | |
| 
 | |
|     def OnCellRightDClick(self, evt):
 | |
|         self.log.write("OnCellRightDClick: (%d,%d) %s\n" %
 | |
|                        (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
 | |
|         evt.Skip()
 | |
| 
 | |
|     def OnLabelLeftClick(self, evt):
 | |
|         self.log.write("OnLabelLeftClick: (%d,%d) %s\n" %
 | |
|                        (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
 | |
|         evt.Skip()
 | |
| 
 | |
|     def OnLabelRightClick(self, evt):
 | |
|         self.log.write("OnLabelRightClick: (%d,%d) %s\n" %
 | |
|                        (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
 | |
|         evt.Skip()
 | |
| 
 | |
|     def OnLabelLeftDClick(self, evt):
 | |
|         self.log.write("OnLabelLeftDClick: (%d,%d) %s\n" %
 | |
|                        (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
 | |
|         evt.Skip()
 | |
| 
 | |
|     def OnLabelRightDClick(self, evt):
 | |
|         self.log.write("OnLabelRightDClick: (%d,%d) %s\n" %
 | |
|                        (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
 | |
|         evt.Skip()
 | |
| 
 | |
|     def OnRowSize(self, evt):
 | |
|         self.log.write("OnRowSize: row %d, %s\n" %
 | |
|                        (evt.GetRowOrCol(), evt.GetPosition()))
 | |
|         evt.Skip()
 | |
| 
 | |
|     def OnColSize(self, evt):
 | |
|         self.log.write("OnColSize: col %d, %s\n" %
 | |
|                        (evt.GetRowOrCol(), evt.GetPosition()))
 | |
|         evt.Skip()
 | |
| 
 | |
|     def OnRangeSelect(self, evt):
 | |
|         if evt.Selecting():
 | |
|             self.log.write("OnRangeSelect: top-left %s, bottom-right %s\n" %
 | |
|                            (evt.GetTopLeftCoords(), evt.GetBottomRightCoords()))
 | |
|         evt.Skip()
 | |
| 
 | |
| 
 | |
|     def OnCellChange(self, evt):
 | |
|         self.log.write("OnCellChange: (%d,%d) %s\n" %
 | |
|                        (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
 | |
| 
 | |
|         # Show how to stay in a cell that has bad data.  We can't just
 | |
|         # call SetGridCursor here since we are nested inside one so it
 | |
|         # won't have any effect.  Instead, set coordinates to move to in
 | |
|         # idle time.
 | |
|         value = self.GetCellValue(evt.GetRow(), evt.GetCol())
 | |
| 
 | |
|         if value == 'no good':
 | |
|             self.moveTo = evt.GetRow(), evt.GetCol()
 | |
| 
 | |
| 
 | |
|     def OnIdle(self, evt):
 | |
|         if self.moveTo != None:
 | |
|             self.SetGridCursor(self.moveTo[0], self.moveTo[1])
 | |
|             self.moveTo = None
 | |
| 
 | |
|         evt.Skip()
 | |
| 
 | |
| 
 | |
|     def OnSelectCell(self, evt):
 | |
|         self.log.write("OnSelectCell: (%d,%d) %s\n" %
 | |
|                        (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
 | |
| 
 | |
|         # Another way to stay in a cell that has a bad value...
 | |
|         row = self.GetGridCursorRow()
 | |
|         col = self.GetGridCursorCol()
 | |
| 
 | |
|         if self.IsCellEditControlEnabled():
 | |
|             self.HideCellEditControl()
 | |
|             self.DisableCellEditControl()
 | |
| 
 | |
|         value = self.GetCellValue(row, col)
 | |
| 
 | |
|         if value == 'no good 2':
 | |
|             return  # cancels the cell selection
 | |
| 
 | |
|         evt.Skip()
 | |
| 
 | |
| 
 | |
|     def OnEditorShown(self, evt):
 | |
|         if evt.GetRow() == 6 and evt.GetCol() == 3 and \
 | |
|            wx.MessageBox("Are you sure you wish to edit this cell?",
 | |
|                         "Checking", wx.YES_NO) == wx.NO:
 | |
|             evt.Veto()
 | |
|             return
 | |
| 
 | |
|         self.log.write("OnEditorShown: (%d,%d) %s\n" %
 | |
|                        (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
 | |
|         evt.Skip()
 | |
| 
 | |
| 
 | |
|     def OnEditorHidden(self, evt):
 | |
|         if evt.GetRow() == 6 and evt.GetCol() == 3 and \
 | |
|            wx.MessageBox("Are you sure you wish to  finish editing this cell?",
 | |
|                         "Checking", wx.YES_NO) == wx.NO:
 | |
|             evt.Veto()
 | |
|             return
 | |
| 
 | |
|         self.log.write("OnEditorHidden: (%d,%d) %s\n" %
 | |
|                        (evt.GetRow(), evt.GetCol(), evt.GetPosition()))
 | |
|         evt.Skip()
 | |
| 
 | |
| 
 | |
|     def OnEditorCreated(self, evt):
 | |
|         self.log.write("OnEditorCreated: (%d, %d) %s\n" %
 | |
|                        (evt.GetRow(), evt.GetCol(), evt.GetControl()))
 | |
| 
 | |
| 
 | |
| 
 | |
| #---------------------------------------------------------------------------
 | |
| 
 | |
| class TestFrame(wx.Frame):
 | |
|     def __init__(self, parent, log):
 | |
|         wx.Frame.__init__(self, parent, -1, "Simple Grid Demo", size=(640,480))
 | |
|         self.grid = SimpleGrid(self, log)
 | |
| 
 | |
| 
 | |
| 
 | |
| #---------------------------------------------------------------------------
 | |
| 
 | |
| if __name__ == '__main__':
 | |
|     import sys
 | |
|     from wx.lib.mixins.inspect import InspectableApp
 | |
|     app = InspectableApp(False)
 | |
|     frame = TestFrame(None, sys.stdout)
 | |
|     frame.Show(True)
 | |
|     #import wx.py
 | |
|     #shell = wx.py.shell.ShellFrame(frame, locals={'wx':wx, 'frame':frame})
 | |
|     #shell.Show()
 | |
|     app.MainLoop()
 | |
| 
 | |
| 
 | |
| #---------------------------------------------------------------------------
 | |
| 
 | |
| 
 |