Added demo of using a sizer in a wxScrolledWindow
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@15965 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
		@@ -124,13 +124,16 @@ DoGetBestSize and AcceptsFocus.
 | 
				
			|||||||
Added wxArtProvider.
 | 
					Added wxArtProvider.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Added wxCallAfter which is a helper function that registers a function
 | 
					Added wxCallAfter which is a helper function that registers a function
 | 
				
			||||||
(or any callable Python object) to be called one time the next time
 | 
					(or any callable Python object) to be called once the next time there
 | 
				
			||||||
there are no pending events.  This is useful for when you need to do
 | 
					are no pending events.  This is useful for when you need to do
 | 
				
			||||||
something but it can't be done during the current event handler.  The
 | 
					something but it can't be done during the current event handler.  The
 | 
				
			||||||
implementation is very simple, see wxPython/wx.py.
 | 
					implementation is very simple, see wxPython/wx.py.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Fixed a boatload of reference leaks.
 | 
					Fixed a boatload of reference leaks.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Added a demo of using a sizer in a wxScrolledWindow, in effect
 | 
				
			||||||
 | 
					creating a ScrolledPanel.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -31,6 +31,7 @@ _treeList = [
 | 
				
			|||||||
        'wxGenericDirCtrl',
 | 
					        'wxGenericDirCtrl',
 | 
				
			||||||
        'wxImageFromStream',
 | 
					        'wxImageFromStream',
 | 
				
			||||||
        'wxArtProvider',
 | 
					        'wxArtProvider',
 | 
				
			||||||
 | 
					        'ScrolledPanel',
 | 
				
			||||||
        ]),
 | 
					        ]),
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    # managed windows == things with a caption you can close
 | 
					    # managed windows == things with a caption you can close
 | 
				
			||||||
@@ -127,6 +128,7 @@ _treeList = [
 | 
				
			|||||||
        'LayoutAnchors',
 | 
					        'LayoutAnchors',
 | 
				
			||||||
        'Layoutf',
 | 
					        'Layoutf',
 | 
				
			||||||
        'RowColSizer',
 | 
					        'RowColSizer',
 | 
				
			||||||
 | 
					        'ScrolledPanel',
 | 
				
			||||||
        'Sizers',
 | 
					        'Sizers',
 | 
				
			||||||
        'wxLayoutConstraints',
 | 
					        'wxLayoutConstraints',
 | 
				
			||||||
        'XML_Resource',
 | 
					        'XML_Resource',
 | 
				
			||||||
@@ -356,10 +358,13 @@ class wxPythonDemo(wxFrame):
 | 
				
			|||||||
        # But instead of the above we want to show how to use our own wxLog class
 | 
					        # But instead of the above we want to show how to use our own wxLog class
 | 
				
			||||||
        wxLog_SetActiveTarget(MyLog(self.log))
 | 
					        wxLog_SetActiveTarget(MyLog(self.log))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        # for serious debugging
 | 
				
			||||||
 | 
					        #wxLog_SetActiveTarget(wxLogStderr())
 | 
				
			||||||
 | 
					        #wxLog_SetTraceMask(wxTraceMessages)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        self.Show(true)
 | 
					        self.Show(true)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        # add the windows to the splitter and split it.
 | 
					        # add the windows to the splitter and split it.
 | 
				
			||||||
        splitter2.SplitHorizontally(self.nb, self.log)
 | 
					        splitter2.SplitHorizontally(self.nb, self.log)
 | 
				
			||||||
        splitter.SplitVertically(self.tree, splitter2)
 | 
					        splitter.SplitVertically(self.tree, splitter2)
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										101
									
								
								wxPython/demo/ScrolledPanel.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										101
									
								
								wxPython/demo/ScrolledPanel.py
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,101 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 | 
					from wxPython.wx import *
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#----------------------------------------------------------------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					text = "one two buckle my shoe three four shut the door five six pick up sticks seven eight lay them straight nine ten big fat hen"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class ScrolledPanel(wxScrolledWindow):
 | 
				
			||||||
 | 
					    def __init__(self, parent, log):
 | 
				
			||||||
 | 
					        self.log = log
 | 
				
			||||||
 | 
					        wxScrolledWindow.__init__(self, parent, -1,
 | 
				
			||||||
 | 
					                                  style = wxTAB_TRAVERSAL|wxHSCROLL|wxVSCROLL)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        box = wxBoxSizer(wxVERTICAL)
 | 
				
			||||||
 | 
					        box.Add(wxStaticText(self, -1,
 | 
				
			||||||
 | 
					                             "This sample shows how to make a scrollable data entry \n"
 | 
				
			||||||
 | 
					                             "form by using a wxSizer in a wxScrolledWindow."),
 | 
				
			||||||
 | 
					                0, wxCENTER|wxALL, 5)
 | 
				
			||||||
 | 
					        box.Add(wxStaticLine(self, -1), 0, wxEXPAND|wxALL, 5)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        fgs = wxFlexGridSizer(cols=2, vgap=4, hgap=4)
 | 
				
			||||||
 | 
					        fgs.AddGrowableCol(1)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        # Add some spacers
 | 
				
			||||||
 | 
					        fgs.Add(75, 10)
 | 
				
			||||||
 | 
					        fgs.Add(150, 10)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        for word in text.split():
 | 
				
			||||||
 | 
					            label = wxStaticText(self, -1, word+":")
 | 
				
			||||||
 | 
					            tc = wxTextCtrl(self, -1, word)
 | 
				
			||||||
 | 
					            fgs.Add(label, flag=wxALIGN_RIGHT | wxALIGN_CENTER_VERTICAL)
 | 
				
			||||||
 | 
					            fgs.Add(tc, flag=wxEXPAND)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        box.Add(fgs, 1)
 | 
				
			||||||
 | 
					        box.Add(10, 40)  # some more empty space at the bottom
 | 
				
			||||||
 | 
					        self.SetSizer(box)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        # The following is all that is needed to integrate the sizer and the
 | 
				
			||||||
 | 
					        # scrolled window.  In this case we will only support vertical scrolling.
 | 
				
			||||||
 | 
					        self.EnableScrolling(false, true)
 | 
				
			||||||
 | 
					        self.SetScrollRate(0, 20)
 | 
				
			||||||
 | 
					        box.SetVirtualSizeHints(self)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        EVT_CHILD_FOCUS(self, self.OnChildFocus)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    def OnChildFocus(self, evt):
 | 
				
			||||||
 | 
					        # If the child window that gets the focus is not visible,
 | 
				
			||||||
 | 
					        # this handler will try to scroll enough to see it.  If you
 | 
				
			||||||
 | 
					        # need to handle horizontal auto-scrolling too then this will
 | 
				
			||||||
 | 
					        # need adapted.
 | 
				
			||||||
 | 
					        evt.Skip()
 | 
				
			||||||
 | 
					        child = evt.GetWindow()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        sppu_y = self.GetScrollPixelsPerUnit()[1]
 | 
				
			||||||
 | 
					        vs_y   = self.GetViewStart()[1]
 | 
				
			||||||
 | 
					        cpos = child.GetPosition()
 | 
				
			||||||
 | 
					        csz  = child.GetSize()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        # is it above the top?
 | 
				
			||||||
 | 
					        if cpos.y < 0:
 | 
				
			||||||
 | 
					            new_vs = cpos.y / sppu_y
 | 
				
			||||||
 | 
					            self.Scroll(-1, new_vs)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        # is it below the bottom ?
 | 
				
			||||||
 | 
					        if cpos.y + csz.height > self.GetClientSize().height:
 | 
				
			||||||
 | 
					            diff = (cpos.y + csz.height - self.GetClientSize().height) / sppu_y
 | 
				
			||||||
 | 
					            self.Scroll(-1, vs_y + diff + 1)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#----------------------------------------------------------------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## class ScrollToHandler(wxEvtHandler):
 | 
				
			||||||
 | 
					##     """This class helps to scroll the panel
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#----------------------------------------------------------------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					def runTest(frame, nb, log):
 | 
				
			||||||
 | 
					    win = ScrolledPanel(nb, log)
 | 
				
			||||||
 | 
					    return win
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#----------------------------------------------------------------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					overview = """<html><body>
 | 
				
			||||||
 | 
					This sample shows how to make a scrollable data entry form by
 | 
				
			||||||
 | 
					using a wxSizer in a wxScrolledWindow.
 | 
				
			||||||
 | 
					</body></html>
 | 
				
			||||||
 | 
					"""
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					if __name__ == '__main__':
 | 
				
			||||||
 | 
					    import sys,os
 | 
				
			||||||
 | 
					    import run
 | 
				
			||||||
 | 
					    run.main(['', os.path.basename(sys.argv[0])])
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -72,6 +72,8 @@ class RunDemoApp(wxApp):
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
        self.SetTopWindow(frame)
 | 
					        self.SetTopWindow(frame)
 | 
				
			||||||
        self.frame = frame
 | 
					        self.frame = frame
 | 
				
			||||||
 | 
					        #wxLog_SetActiveTarget(wxLogStderr())
 | 
				
			||||||
 | 
					        #wxLog_SetTraceMask(wxTraceMessages)
 | 
				
			||||||
        return true
 | 
					        return true
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -158,6 +158,7 @@ class TestHtmlPanel(wxPanel):
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
def runTest(frame, nb, log):
 | 
					def runTest(frame, nb, log):
 | 
				
			||||||
    win = TestHtmlPanel(nb, frame, log)
 | 
					    win = TestHtmlPanel(nb, frame, log)
 | 
				
			||||||
 | 
					    print wxWindow_FindFocus()
 | 
				
			||||||
    return win
 | 
					    return win
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -211,13 +211,14 @@ def runTest(frame, nb, log):
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
overview = """\
 | 
					overview = """\
 | 
				
			||||||
"""
 | 
					"""
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					if __name__ == '__main__':
 | 
				
			||||||
 | 
					    import sys,os
 | 
				
			||||||
 | 
					    import run
 | 
				
			||||||
 | 
					    run.main(['', os.path.basename(sys.argv[0])])
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user