Die Community zu .NET und Classic VB.
Menü

VB 5/6-Tipp 0259: Resize einer TextBox zur Laufzeit ermöglichen

 von 

Beschreibung 

Wenn durch Änderung des Fensterstils einer TextBox ein "ThickFrame" verpaßt wird ist sie durch den Anwender während der Laufzeit in ihren Abmaßen änderbar.

Schwierigkeitsgrad:

Schwierigkeitsgrad 1

Verwendete API-Aufrufe:

GetWindowLongA (GetWindowLong), SetWindowLongA (SetWindowLong), SetWindowPos

Download:

Download des Beispielprojektes [2,27 KB]

'Dieser Quellcode stammt von http://www.activevb.de
'und kann frei verwendet werden. Für eventuelle Schäden
'wird nicht gehaftet.

'Um Fehler oder Fragen zu klären, nutzen Sie bitte unser Forum.
'Ansonsten viel Spaß und Erfolg mit diesem Source!

'------------- Anfang Projektdatei Project1.vbp -------------
'--------- Anfang Formular "Form1" alias Form1.frm  ---------
' Steuerelement: Listen-Steuerelement "List1"
' Steuerelement: Kontrollkästchen-Steuerelement "Check1"
' Steuerelement: Textfeld "Text1"

Option Explicit

Private Declare Function GetWindowLong Lib "user32" Alias _
        "GetWindowLongA" (ByVal hwnd As Long, ByVal wIndx As _
        Long) As Long
   
Private Declare Function SetWindowLong Lib "user32" Alias _
        "SetWindowLongA" (ByVal hwnd As Long, ByVal nIndex _
        As Long, ByVal dwNewLong As Long) As Long

Private Declare Sub SetWindowPos Lib "user32" (ByVal hwnd _
        As Integer, ByVal hWndInsertAfter As Integer, ByVal X _
        As Integer, ByVal Y As Integer, ByVal CX As Integer, _
        ByVal CY As Integer, ByVal wFlags As Integer)
   
Const SWP_NOSIZE = &H1
Const SWP_NOZORDER = &H4
Const SWP_NOMOVE = &H2
Const SWP_DRAWFRAME = &H20
Const GWL_STYLE = (-16)
Const WS_THICKFRAME = &H40000

Private Sub Check1_Click()
   If Check1.Value = vbChecked Then
     Call FrameTextBox(Text1, False)
     Call FrameTextBox(List1, False)
   Else
     Call FrameTextBox(Text1, True)
     Call FrameTextBox(List1, True)
   End If
End Sub

Function FrameTextBox(Box As Control, State As Boolean)
  Dim Result&
  
    Result = GetWindowLong(Box.hwnd, GWL_STYLE) Or WS_THICKFRAME
    If State Then Result = Result - WS_THICKFRAME
    Call SetWindowLong(Box.hwnd, GWL_STYLE, Result)
    Call SetWindowPos(Box.hwnd, Me.hwnd, 0, 0, 0, 0, SWP_NOZORDER _
                      Or SWP_NOSIZE Or SWP_NOMOVE Or SWP_DRAWFRAME)
End Function

Private Sub Form_Load()
  Check1.Value = vbChecked
  List1.AddItem "Äpfel"
  List1.AddItem "Birnen"
  List1.AddItem "Bananen"
End Sub
'---------- Ende Formular "Form1" alias Form1.frm  ----------
'-------------- Ende Projektdatei Project1.vbp --------------

Tipp-Kompatibilität:

Windows/VB-VersionWin32sWin95Win98WinMEWinNT4Win2000WinXP
VB4
VB5
VB6

Hat dieser Tipp auf Ihrem Betriebsystem und mit Ihrer VB-Version funktioniert?

Ja, funktioniert!

Nein, funktioniert nicht bei mir!

VB-Version:

Windows-Version:

Ihre Meinung  

Falls Sie Fragen zu diesem Artikel haben oder Ihre Erfahrung mit anderen Nutzern austauschen möchten, dann teilen Sie uns diese bitte in einem der unten vorhandenen Themen oder über einen neuen Beitrag mit. Hierzu können sie einfach einen Beitrag in einem zum Thema passenden Forum anlegen, welcher automatisch mit dieser Seite verknüpft wird.

Archivierte Nutzerkommentare 

Klicken Sie diesen Text an, wenn Sie die 3 archivierten Kommentare ansehen möchten.
Diese stammen noch von der Zeit, als es noch keine direkte Forenunterstützung für Fragen und Kommentare zu einzelnen Artikeln gab.
Aus Gründen der Vollständigkeit können Sie sich die ausgeblendeten Kommentare zu diesem Artikel aber gerne weiterhin ansehen.

Kommentar von TiKu am 15.08.2008 um 01:33

Wie bereits angemerkt wurde, ist die Deklaration von SetWindowPos völlig falsch (es müssen Longs statt Integers sein und es muss eine Function sein, keine Sub).

Davon abgesehen ist diese Zeile unsauber:

If State Then Result = Result - WS_THICKFRAME

Besser:
If State Then Result = Result And Not WS_THICKFRAME

Kommentar von Michael Eger am 01.10.2002 um 14:56

Function FrameTextBox(Box As Control, State As Boolean)
Dim Result&

Result = GetWindowLong(Box.hwnd, GWL_STYLE) Or WS_THICKFRAME
If State Then Result = Result - WS_THICKFRAME
Call SetWindowLong(Box.hwnd, GWL_STYLE, Result)
'Call SetWindowPos(Box.hwnd, Me.hwnd, 0, 0, 0, 0, SWP_NOZORDER _
Or SWP_NOSIZE Or SWP_NOMOVE Or SWP_DRAWFRAME)
End Function

nach dieser Änderung und dem Ändern von Sub in Function funktioniert es auch unter W2k & VB6

mfg
Michael

Kommentar von Yelve Yakut am 01.05.2002 um 21:18

Dieser Tip ist Fehlerhaft!!!
Die dritte API deklaration ist keine Prozedur sondern eine Funktion!
Richtig:
Private Declare Function SetWindowPos Lib "user32" (ByVal hwnd As Long, ByVal hWndInsertAfter As Long, ByVal x As Long, ByVal y As Long, ByVal cx As Long, ByVal cy As Long, ByVal wFlags As Long) As Long