Test case for matching GetInsertionPoint and etc. with actual text positions
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/branches/WX_2_4_BRANCH@17362 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
		@@ -20,26 +20,26 @@ class TestPanel(wxPanel):
 | 
			
		||||
        self.log = log
 | 
			
		||||
 | 
			
		||||
        l1 = wxStaticText(self, -1, "wxTextCtrl")
 | 
			
		||||
        t1 = wxTextCtrl(self, 10, "Test it out and see", size=(125, -1))
 | 
			
		||||
        t1 = wxTextCtrl(self, -1, "Test it out and see", size=(125, -1))
 | 
			
		||||
        t1.SetInsertionPoint(0)
 | 
			
		||||
        self.tc1 = t1
 | 
			
		||||
        EVT_TEXT(self, 10, self.EvtText)
 | 
			
		||||
        EVT_TEXT(self, t1.GetId(), self.EvtText)
 | 
			
		||||
        EVT_CHAR(t1, self.EvtChar)
 | 
			
		||||
        EVT_SET_FOCUS(t1, self.OnSetFocus)
 | 
			
		||||
        EVT_KILL_FOCUS(t1, self.OnKillFocus)
 | 
			
		||||
        EVT_WINDOW_DESTROY(t1, self.OnWindowDestroy)
 | 
			
		||||
 | 
			
		||||
        l2 = wxStaticText(self, -1, "Passsword")
 | 
			
		||||
        t2 = wxTextCtrl(self, 20, "", size=(125, -1), style=wxTE_PASSWORD)
 | 
			
		||||
        EVT_TEXT(self, 20, self.EvtText)
 | 
			
		||||
        t2 = wxTextCtrl(self, -1, "", size=(125, -1), style=wxTE_PASSWORD)
 | 
			
		||||
        EVT_TEXT(self, t2.GetId(), self.EvtText)
 | 
			
		||||
 | 
			
		||||
        l3 = wxStaticText(self, -1, "Multi-line")
 | 
			
		||||
        t3 = wxTextCtrl(self, 30,
 | 
			
		||||
        t3 = wxTextCtrl(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=wxTE_MULTILINE)
 | 
			
		||||
        t3.SetInsertionPoint(0)
 | 
			
		||||
        EVT_TEXT(self, 30, self.EvtText)
 | 
			
		||||
        EVT_TEXT(self, t3.GetId(), self.EvtText)
 | 
			
		||||
        b = wxButton(self, -1, "Test Replace")
 | 
			
		||||
        EVT_BUTTON(self, b.GetId(), self.OnTestReplace)
 | 
			
		||||
        b2 = wxButton(self, -1, "Test GetSelection")
 | 
			
		||||
@@ -49,15 +49,24 @@ class TestPanel(wxPanel):
 | 
			
		||||
        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.",
 | 
			
		||||
        t4 = wxTextCtrl(self, -1, "If supported by the native control, this is red, and this is a different font.",
 | 
			
		||||
                        size=(200, 100), style=wxTE_MULTILINE|wxTE_RICH2)
 | 
			
		||||
        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)
 | 
			
		||||
        t4.SetStyle(63, 77, wxTextAttr("BLUE", wxNullColour, f))
 | 
			
		||||
 | 
			
		||||
        l5 = wxStaticText(self, -1, "Test Positions")
 | 
			
		||||
        t5 = wxTextCtrl(self, -1, "0123456789\n" * 5, size=(200, 100),
 | 
			
		||||
                        style = wxTE_MULTILINE
 | 
			
		||||
                        #| wxTE_RICH
 | 
			
		||||
                        | wxTE_RICH2
 | 
			
		||||
                        )
 | 
			
		||||
        EVT_LEFT_DOWN(t5, self.OnT5LeftDown)
 | 
			
		||||
        self.t5 = t5
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        bsizer = wxBoxSizer(wxVERTICAL)
 | 
			
		||||
        bsizer.Add(b, 0, wxGROW)
 | 
			
		||||
        bsizer.Add(b2, 0, wxGROW)
 | 
			
		||||
@@ -68,6 +77,7 @@ class TestPanel(wxPanel):
 | 
			
		||||
                        l2, t2, (0,0),
 | 
			
		||||
                        l3, t3, bsizer,
 | 
			
		||||
                        l4, t4, (0,0),
 | 
			
		||||
                        l5, t5, (0,0),
 | 
			
		||||
                        ])
 | 
			
		||||
        border = wxBoxSizer(wxVERTICAL)
 | 
			
		||||
        border.Add(sizer, 0, wxALL, 25)
 | 
			
		||||
@@ -103,6 +113,22 @@ class TestPanel(wxPanel):
 | 
			
		||||
                        self.tc.GetStringSelection(),
 | 
			
		||||
                        repr(text[start:end])))
 | 
			
		||||
 | 
			
		||||
    def OnT5LeftDown(self, evt):
 | 
			
		||||
        evt.Skip()
 | 
			
		||||
        wxCallAfter(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)))
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#---------------------------------------------------------------------------
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user