X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/00b6c4e33bdb2fcc1b56d429653963182608674b..7a0a63aeee7a95b65bf133c8fa7a47538710f12c:/wxPython/demo/wxTextCtrl.py?ds=sidebyside diff --git a/wxPython/demo/wxTextCtrl.py b/wxPython/demo/wxTextCtrl.py index 16bcbe1c78..8c954a43b1 100644 --- a/wxPython/demo/wxTextCtrl.py +++ b/wxPython/demo/wxTextCtrl.py @@ -1,64 +1,95 @@ -import sys -from wxPython.wx import * +# 11/21/2003 - Jeff Grimmett (grimmtooth@softhome.net) +# +# o Updated for wx namespace +# + +import sys +import wx #--------------------------------------------------------------------------- -class TestPanel(wxPanel): +class TestPanel(wx.Panel): def OnSetFocus(self, evt): print "OnSetFocus" evt.Skip() def OnKillFocus(self, evt): print "OnKillFocus" evt.Skip() + def OnWindowDestroy(self, evt): + print "OnWindowDestroy" + evt.Skip() + def __init__(self, parent, log): - wxPanel.__init__(self, parent, -1) + wx.Panel.__init__(self, parent, -1) self.log = log - l1 = wxStaticText(self, -1, "wxTextCtrl") - t1 = wxTextCtrl(self, 10, "Test it out and see", size=(125, -1)) + l1 = wx.StaticText(self, -1, "wx.TextCtrl") + t1 = wx.TextCtrl(self, -1, "Test it out and see", size=(125, -1)) t1.SetInsertionPoint(0) - EVT_TEXT(self, 10, self.EvtText) - EVT_CHAR(t1, self.EvtChar) - EVT_SET_FOCUS(t1, self.OnSetFocus) - EVT_KILL_FOCUS(t1, self.OnKillFocus) - - l2 = wxStaticText(self, -1, "Passsword") - t2 = wxTextCtrl(self, 20, "", size=(125, -1), style=wxTE_PASSWORD) - EVT_TEXT(self, 20, self.EvtText) - - 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) + self.tc1 = t1 + + self.Bind(wx.EVT_TEXT, self.EvtText, t1) + t1.Bind(wx.EVT_CHAR, self.EvtChar) + t1.Bind(wx.EVT_SET_FOCUS, self.OnSetFocus) + t1.Bind(wx.EVT_KILL_FOCUS, self.OnKillFocus) + t1.Bind(wx.EVT_WINDOW_DESTROY, self.OnWindowDestroy) + + l2 = wx.StaticText(self, -1, "Password") + t2 = wx.TextCtrl(self, -1, "", size=(125, -1), style=wx.TE_PASSWORD) + self.Bind(wx.EVT_TEXT, self.EvtText, t2) + + l3 = wx.StaticText(self, -1, "Multi-line") + t3 = wx.TextCtrl(self, -1, + "Here is a looooooooooooooong line of text set in the control.\n\n" + "The quick brown fox jumped over the lazy dog...", + size=(200, 100), style=wx.TE_MULTILINE) + t3.SetInsertionPoint(0) - EVT_TEXT(self, 30, self.EvtText) - b = wxButton(self, -1, "Test Replace") - EVT_BUTTON(self, b.GetId(), self.OnTestReplace) + self.Bind(wx.EVT_TEXT, self.EvtText, t3) + b = wx.Button(self, -1, "Test Replace") + self.Bind(wx.EVT_BUTTON, self.OnTestReplace, b) + b2 = wx.Button(self, -1, "Test GetSelection") + self.Bind(wx.EVT_BUTTON, self.OnTestGetSelection, b2) + b3 = wx.Button(self, -1, "Test WriteText") + self.Bind(wx.EVT_BUTTON, self.OnTestWriteText, b3) 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")) + l4 = wx.StaticText(self, -1, "Rich Text") + t4 = wx.TextCtrl(self, -1, "If supported by the native control, this is red, and this is a different font.", + size=(200, 100), style=wx.TE_MULTILINE|wx.TE_RICH2) + t4.SetInsertionPoint(0) + t4.SetStyle(44, 47, wx.TextAttr("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) + f = wx.Font(points+3, wx.ROMAN, wx.ITALIC, wx.BOLD, True) + t4.SetStyle(63, 77, wx.TextAttr("BLUE", wx.NullColour, f)) + + l5 = wx.StaticText(self, -1, "Test Positions") + t5 = wx.TextCtrl(self, -1, "0123456789\n" * 5, size=(200, 100), + style = wx.TE_MULTILINE + #| wx.TE_RICH + | wx.TE_RICH2 + ) + t5.Bind(wx.EVT_LEFT_DOWN, self.OnT5LeftDown) + self.t5 = t5 + + bsizer = wx.BoxSizer(wx.VERTICAL) + bsizer.Add(b, 0, wx.GROW|wx.ALL, 4) + bsizer.Add(b2, 0, wx.GROW|wx.ALL, 4) + bsizer.Add(b3, 0, wx.GROW|wx.ALL, 4) + + sizer = wx.FlexGridSizer(cols=3, hgap=6, vgap=6) sizer.AddMany([ l1, t1, (0,0), l2, t2, (0,0), - l3, t3, b, + l3, t3, bsizer, l4, t4, (0,0), + l5, t5, (0,0), ]) - border = wxBoxSizer(wxVERTICAL) - border.Add(sizer, 0, wxALL, 25) + border = wx.BoxSizer(wx.VERTICAL) + border.Add(sizer, 0, wx.ALL, 25) self.SetSizer(border) - self.SetAutoLayout(true) + self.SetAutoLayout(True) def EvtText(self, event): @@ -71,8 +102,53 @@ class TestPanel(wxPanel): def OnTestReplace(self, evt): - self.tc.Replace(4, 8, "DOES") - #self.tc.Remove(4, 8) + self.tc.Replace(5, 9, "IS A") + #self.tc.Remove(5, 9) + + def OnTestWriteText(self, evt): + self.tc.WriteText("TEXT") + + def OnTestGetSelection(self, evt): + start, end = self.tc.GetSelection() + text = self.tc.GetValue() + if wx.Platform == "__WXMSW__": # This is why GetStringSelection was added + text = text.replace('\n', '\r\n') + + self.log.write("multi-line GetSelection(): (%d, %d)\n" + "\tGetStringSelection(): %s\n" + "\tSelectedText: %s\n" % + (start, end, + self.tc.GetStringSelection(), + repr(text[start:end]))) + + start, end = self.tc1.GetSelection() + text = self.tc1.GetValue() + + if wx.Platform == "__WXMSW__": # This is why GetStringSelection was added + text = text.replace('\n', '\r\n') + + self.log.write("single-line GetSelection(): (%d, %d)\n" + "\tGetStringSelection(): %s\n" + "\tSelectedText: %s\n" % + (start, end, + self.tc1.GetStringSelection(), + repr(text[start:end]))) + + + def OnT5LeftDown(self, evt): + evt.Skip() + wx.CallAfter(self.LogT5Position, evt) + + def LogT5Position(self, evt): + text = self.t5.GetValue() + ip = self.t5.GetInsertionPoint() + lp = self.t5.GetLastPosition() + self.log.write("LogT5Position:\n" + "\tGetInsertionPoint:\t%d\n" + "\ttext[insertionpoint]:\t%s\n" + "\tGetLastPosition:\t%d\n" + "\tlen(text):\t\t%d\n" + % (ip, text[ip], lp, len(text))) #--------------------------------------------------------------------------- @@ -84,7 +160,17 @@ def runTest(frame, nb, log): #--------------------------------------------------------------------------- +overview = """\ +A text control allows text to be displayed and (possibly) edited. It may be single +line or multi-line, support styles or not, be read-only or not, and even supports +text masking for such things as passwords. -overview = """\ """ + + +if __name__ == '__main__': + import sys,os + import run + run.main(['', os.path.basename(sys.argv[0])]) +