X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/c8ace611be19b19219865cae0d513e08e488dd63..9fd9e47a93dfcdd99c2722e288a0f28a51ce6f5f:/wxPython/demo/ColourDB.py?ds=sidebyside diff --git a/wxPython/demo/ColourDB.py b/wxPython/demo/ColourDB.py index f23e294fe5..8e00407dba 100644 --- a/wxPython/demo/ColourDB.py +++ b/wxPython/demo/ColourDB.py @@ -17,6 +17,7 @@ class TestWindow(wxScrolledWindow): wxScrolledWindow.__init__(self, parent, -1) self.clrList = colourdb.getColourList() + #self.clrList.sort() self.bg_bmp = images.getGridBGBitmap() EVT_PAINT(self, self.OnPaint) @@ -60,6 +61,8 @@ class TestWindow(wxScrolledWindow): dc = evt.GetDC() if not dc: dc = wxClientDC(self) + rect = self.GetUpdateRegion().GetBox() + dc.SetClippingRegion(rect.x, rect.y, rect.width, rect.height) self.TileBackground(dc) @@ -78,7 +81,7 @@ class TestWindow(wxScrolledWindow): numColours = len(colours) if rgn: - # determine the subset that have been exposed and needs drawn + # determine the subset that has been exposed and needs drawn rect = rgn.GetBox() pixStart = vs[1]*self.lineHeight + rect.y pixStop = pixStart + rect.height @@ -86,7 +89,7 @@ class TestWindow(wxScrolledWindow): stop = pixStop / self.lineHeight else: start = 0 - stop = len(numColours) + stop = numColours for line in range(max(0,start), min(stop,numColours)): clr = colours[line] @@ -100,12 +103,24 @@ class TestWindow(wxScrolledWindow): dc.EndDrawing() +# On wxGTK there needs to be a panel under wxScrolledWindows if they are +# going to be in a wxNotebook... +class TestPanel(wxPanel): + def __init__(self, parent): + wxPanel.__init__(self, parent, -1) + self.win = TestWindow(self) + EVT_SIZE(self, self.OnSize) + + def OnSize(self, evt): + self.win.SetSize(evt.GetSize()) + + #---------------------------------------------------------------------- def runTest(frame, nb, log): - win = TestWindow(nb) + win = TestPanel(nb) return win #----------------------------------------------------------------------