]> git.saurik.com Git - wxWidgets.git/blobdiff - wxPython/demo/wxTextCtrl.py
added missing destructor for Darwin/Mac OS X (wxGtk, wxMotif, wxMac)
[wxWidgets.git] / wxPython / demo / wxTextCtrl.py
index 8936d34de491f1e46baade6e388927941abc8182..16bcbe1c789c2891d67e1c7bc12240a3cbbd1833 100644 (file)
@@ -1,29 +1,65 @@
-
+import sys
 from wxPython.wx import *
 
 #---------------------------------------------------------------------------
 
 class TestPanel(wxPanel):
+    def OnSetFocus(self, evt):
+        print "OnSetFocus"
+        evt.Skip()
+    def OnKillFocus(self, evt):
+        print "OnKillFocus"
+        evt.Skip()
+
     def __init__(self, parent, log):
         wxPanel.__init__(self, parent, -1)
         self.log = log
 
-        wxStaticText(self, -1, "wxTextCtrl", wxPoint(5, 25), wxSize(75, 20))
-        t = wxTextCtrl(self, 10, "Test it out and see", wxPoint(80, 25), wxSize(150, 20))
-        t.SetInsertionPoint(0)
+        l1 = wxStaticText(self, -1, "wxTextCtrl")
+        t1 = wxTextCtrl(self, 10, "Test it out and see", size=(125, -1))
+        t1.SetInsertionPoint(0)
         EVT_TEXT(self, 10, self.EvtText)
-        EVT_CHAR(t, self.EvtChar)
-
+        EVT_CHAR(t1, self.EvtChar)
+        EVT_SET_FOCUS(t1, self.OnSetFocus)
+        EVT_KILL_FOCUS(t1, self.OnKillFocus)
 
-        wxStaticText(self, -1, "Passsword", wxPoint(5, 50), wxSize(75, 20))
-        wxTextCtrl(self, 20, "", wxPoint(80, 50), wxSize(150, 20), wxTE_PASSWORD)
+        l2 = wxStaticText(self, -1, "Passsword")
+        t2 = wxTextCtrl(self, 20, "", size=(125, -1), style=wxTE_PASSWORD)
         EVT_TEXT(self, 20, self.EvtText)
 
-        wxStaticText(self, -1, "Multi-line", wxPoint(5, 75), wxSize(75, 20))
-        t = wxTextCtrl(self, 30, "How does it work with a long line of text set in the control",
-                       wxPoint(80, 75), wxSize(200, 150), wxTE_MULTILINE)
-        t.SetInsertionPoint(0)
+        l3 = wxStaticText(self, -1, "Multi-line")
+        t3 = wxTextCtrl(self, 30, "How does it work with a long line of text set in the control",
+                       size=(200, 100), style=wxTE_MULTILINE)
+        t3.SetInsertionPoint(0)
         EVT_TEXT(self, 30, self.EvtText)
+        b = wxButton(self, -1, "Test Replace")
+        EVT_BUTTON(self, b.GetId(), self.OnTestReplace)
+        self.tc = t3
+
+        l4 = wxStaticText(self, -1, "Rich Text")
+        t4 = wxTextCtrl(self, 40, "If supported by the native control, this is red, and this is a different font.",
+                        size=(200, 100), style=wxTE_MULTILINE|wxTE_RICH)
+        t4.SetInsertionPoint(0)
+        t4.SetStyle(44, 47, wxTextAttr("RED", "YELLOW"))
+
+        points = t4.GetFont().GetPointSize()  # get the current size
+        f = wxFont(points+3, wxROMAN, wxITALIC, wxBOLD, true)
+##         print 'a1', sys.getrefcount(f)
+##         t4.SetStyle(63, 77, wxTextAttr("BLUE", font=f))
+        t4.SetStyle(63, 77, wxTextAttr("BLUE", wxNullColour, f))
+##         print 'a2', sys.getrefcount(f)
+
+        sizer = wxFlexGridSizer(cols=3, hgap=6, vgap=6)
+        sizer.AddMany([ l1, t1, (0,0),
+                        l2, t2, (0,0),
+                        l3, t3, b,
+                        l4, t4, (0,0),
+                        ])
+        border = wxBoxSizer(wxVERTICAL)
+        border.Add(sizer, 0, wxALL, 25)
+        self.SetSizer(border)
+        self.SetAutoLayout(true)
+
 
     def EvtText(self, event):
         self.log.WriteText('EvtText: %s\n' % event.GetString())
@@ -34,6 +70,11 @@ class TestPanel(wxPanel):
         event.Skip()
 
 
+    def OnTestReplace(self, evt):
+        self.tc.Replace(4, 8, "DOES")
+        #self.tc.Remove(4, 8)
+
+
 #---------------------------------------------------------------------------
 
 def runTest(frame, nb, log):