]> git.saurik.com Git - wxWidgets.git/blobdiff - wxPython/demo/Frame.py
Renamed demo modules to be wx-less.
[wxWidgets.git] / wxPython / demo / Frame.py
diff --git a/wxPython/demo/Frame.py b/wxPython/demo/Frame.py
new file mode 100644 (file)
index 0000000..b2028e6
--- /dev/null
@@ -0,0 +1,71 @@
+# 11/18/2003 - Jeff Grimmett (grimmtooth@softhome.net)
+#
+# o Updated for wx namespace
+# 
+
+import  wx
+
+#---------------------------------------------------------------------------
+
+class MyFrame(wx.Frame):
+    def __init__(
+            self, parent, ID, title, pos=wx.DefaultPosition,
+            size=wx.DefaultSize, style=wx.DEFAULT_FRAME_STYLE
+            ):
+
+        wx.Frame.__init__(self, parent, ID, title, pos, size, style)
+        panel = wx.Panel(self, -1)
+
+        button = wx.Button(panel, 1003, "Close Me")
+        button.SetPosition((15, 15))
+        self.Bind(wx.EVT_BUTTON, self.OnCloseMe, button)
+        self.Bind(wx.EVT_CLOSE, self.OnCloseWindow)
+
+
+    def OnCloseMe(self, event):
+        self.Close(True)
+
+    def OnCloseWindow(self, event):
+        self.Destroy()
+
+#---------------------------------------------------------------------------
+
+def runTest(frame, nb, log):
+    win = MyFrame(frame, -1, "This is a wxFrame", size=(350, 200),
+                  style = wx.DEFAULT_FRAME_STYLE)# |  wx.FRAME_TOOL_WINDOW )
+    frame.otherWin = win
+    win.Show(True)
+
+
+#---------------------------------------------------------------------------
+
+
+overview = """\
+A Frame is a window whose size and position can (usually) be changed by 
+the user. It usually has thick borders and a title bar, and can optionally 
+contain a menu bar, toolbar and status bar. A frame can contain any window 
+that is not a Frame or Dialog. It is one of the most fundamental of the 
+wxWindows components. 
+
+A Frame that has a status bar and toolbar created via the 
+<code>CreateStatusBar</code> / <code>CreateToolBar</code> functions manages 
+these windows, and adjusts the value returned by <code>GetClientSize</code>
+to reflect the remaining size available to application windows.
+
+By itself, a Frame is not too useful, but with the addition of Panels and
+other child objects, it encompasses the framework around which most user
+interfaces are constructed.
+
+If you plan on using Sizers and auto-layout features, be aware that the Frame
+class lacks the ability to handle these features unless it contains a Panel.
+The Panel has all the necessary functionality to both control the size of
+child components, and also communicate that information in a useful way to
+the Frame itself.
+"""
+
+
+if __name__ == '__main__':
+    import sys,os
+    import run
+    run.main(['', os.path.basename(sys.argv[0])])
+