我有一个RichTextBox。
假设我想在文本中绘制每个单词“test”。 我的问题不是在文本中找到“测试”,我的问题是当我为单词着色时我可以看到RichTextBox选择过程。
我的色彩功能:
Private Sub DrawSubPart(ByVal StartIndex As Integer, ByVal EndIndex As Integer, ByVal col As Color)
Dim save As Integer = TextScreen.SelectionStart
TextScreen.SelectionStart = StartIndex 'Here I can see the selection, And I dont want to see it.
TextScreen.SelectionLength = EndIndex - EndIndex + 1
TextScreen.SelectionColor = col
TextScreen.SelectionLength = 0
TextScreen.SelectionStart = save
End Sub
我试图捕捉选择过程,看起来像这样:
一毫秒之后看起来还不错:
那么如何才能停止选择“闪烁”?
答案 0 :(得分:1)
尝试使用自定义RichTextBox控件,在重新格式化内容时关闭绘图和滚动事件:
Public Class RichTextBoxEx
Inherits RichTextBox
<DllImport("user32.dll")> _
Private Shared Function SendMessage(hWnd As IntPtr, wMsg As Int32, wParam As Int32, ByRef lParam As Point) As IntPtr
End Function
<DllImport("user32.dll")> _
Private Shared Function SendMessage(hWnd As IntPtr, wMsg As Int32, wParam As Int32, lParam As IntPtr) As IntPtr
End Function
Const WM_USER As Integer = &H400
Const WM_SETREDRAW As Integer = &HB
Const EM_GETEVENTMASK As Integer = WM_USER + 59
Const EM_SETEVENTMASK As Integer = WM_USER + 69
Const EM_GETSCROLLPOS As Integer = WM_USER + 221
Const EM_SETSCROLLPOS As Integer = WM_USER + 222
Private _ScrollPoint As Point
Private _Painting As Boolean = True
Private _EventMask As IntPtr
Private _SuspendIndex As Integer = 0
Private _SuspendLength As Integer = 0
Public Sub SuspendPainting()
If _Painting Then
_SuspendIndex = Me.SelectionStart
_SuspendLength = Me.SelectionLength
SendMessage(Me.Handle, EM_GETSCROLLPOS, 0, _ScrollPoint)
SendMessage(Me.Handle, WM_SETREDRAW, 0, IntPtr.Zero)
_EventMask = SendMessage(Me.Handle, EM_GETEVENTMASK, 0, IntPtr.Zero)
_Painting = False
End If
End Sub
Public Sub ResumePainting()
If Not _Painting Then
Me.Select(_SuspendIndex, _SuspendLength)
SendMessage(Me.Handle, EM_SETSCROLLPOS, 0, _ScrollPoint)
SendMessage(Me.Handle, EM_SETEVENTMASK, 0, _EventMask)
SendMessage(Me.Handle, WM_SETREDRAW, 1, IntPtr.Zero)
_Painting = True
Me.Invalidate()
End If
End Sub
End Class
然后你的用法是:
RichTextBoxEx1.SuspendPainting()
Dim save As Integer = RichTextBoxEx1.SelectionStart
RichTextBoxEx1.SelectionStart = StartIndex
RichTextBoxEx1.SelectionLength = EndIndex - StartIndex + 1
RichTextBoxEx1.SelectionColor = Color.Green
RichTextBoxEx1.SelectionLength = 0
RichTextBoxEx1.SelectionStart = save
RichTextBoxEx1.ResumePainting()