vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
Schützen Sie Ihre Software vor Software-Piraterie - mit sevLock 1.0 DLL!  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2024
 
zurück
Rubrik: Controls · TextBox & RichTextBox   |   VB-Versionen: VB4, VB5, VB611.11.03
Beep im RTF-Control unterbinden

Wie man den Beep beim Navigieren innerhalb der RTF-TextBox unterbinden kann, das zeigt Ihnen dieser Tipp.

Autor:   Dieter OtterBewertung:     [ Jetzt bewerten ]Views:  13.204 
www.tools4vb.deSystem:  Win9x, WinNT, Win2k, WinXP, Win7, Win8, Win10, Win11 Beispielprojekt auf CD 

Für größere Texteingaben verwendet man gerne das RTF-Control (RichTextBox-Control) - oder auch dann, wenn man einzelne Wörter oder Textpassagen farbig bzw. anders formatiert darstellen muss.

Beim Navigieren innerhalb der RTF-TextBox mit den Cursortasten (nach oben bzw. nach unten) ertönt autom. ein Beepton, wenn sich der Cursor hierbei in der ersten bzw. letzten Zeile des Textes befindet.

Wie man dieses "Beepsen" ausschalten kann, das verraten wir Ihnen heute.
Hierzu fragen wir im KeyDown-Ereignis des RTF-Controls gezielt die beiden Cursortasten ab, ermitteln die aktuelle Zeilenposition und prüfen, ob sich der Cursor bereits in der ersten bzw. letzten Zeile befindet. Ist dies der Fall, setzen wir KeyCode einfach auf den Wert 0 - und schon erstummt das RTF-Control

Option Explicit
 
' zunächst die benötigten API-Deklarationen
Private Declare Function SendMessage Lib "user32" _
  Alias "SendMessageA" ( _
  ByVal hWnd As Long, _
  ByVal wMsg As Long, _
  ByVal wParam As Long, _
  lParam As Any) As Long
 
Private Const EM_LINEFROMCHAR = &HC9
Private Const EM_LINEINDEX = &HBB
Private Const EM_GETLINECOUNT = &HBA
' Zeilennummer der aktuellen Eingabeposition ermitteln
Public Function GetCurrentLine(hWnd As Long) As Long
  GetCurrentLine = SendMessage(hWnd, EM_LINEFROMCHAR, _
    -1, ByVal 0&) + 1
End Function
' Anzahl der Zeilen der TextBox ermitteln
Private Function GetLineCount(ByVal hWnd As Long) As Long
  GetLineCount = SendMessage(hWnd, EM_GETLINECOUNT, -1, 0&)
End Function
' Tastatur-Ereignisse abfragen
Private Sub RichTextBox1_KeyDown(KeyCode As Integer, Shift As Integer)
  With RichTextBox1
    Select Case KeyCode
      Case vbKeyUp
        ' nach oben
        If GetCurrentLine(.hWnd) < 2 Then
          KeyCode = 0
        End If
 
      Case vbKeyDown
        ' nach unten
        If GetCurrentLine(.hWnd) = GetLineCount(.hWnd) Then
          KeyCode = 0
        End If
    End Select
  End With
End Sub