Wie kann man Steuerelemente zur Laufzeit verschieben? Diese Frage tauchteauch schon ein paar Mal auf. Mal sollten die Steuerelemente nur waagrecht odersenkrecht verschoben werden können, mal sollten sie frei positionierbar sein. Hier ein Beispiel mit CommandButtons. Sie benötigen eine Form, auf der sichdrei CommandButtons befinden: Command1, Command2 und Command3. Command1 solltefrei positionierbar sein, Command2 sollte nur auf einer waagrechten Linie undCommand3 auf einer senkrechten Linie verschiebbar sein. Und hier der Code: Option Explicit Private XPos As Single Private YPos As Single ' Command1 frei positionierbar Private Sub Command1_MouseDown(Button As Integer, Shift As Integer, _ X As Single, Y As Single) ' Ausgangskoordinaten der Maus speichern XPos = X YPos = Y End Sub Private Sub Command1_MouseMove(Button As Integer, Shift As Integer, _ X As Single, Y As Single) ' Button verschieben, wenn Maustaste gedrückt If Button = vbLeftButton Then Command1.Move Command1.Left + X - XPos, Command1.Top + Y - YPos End If End Sub ' Command2 nur waagrecht verschiebbar Private Sub Command2_MouseDown(Button As Integer, Shift As Integer, _ X As Single, Y As Single) ' Ausgangskoordinaten der Maus speichern XPos = X End Sub Private Sub Command2_MouseMove(Button As Integer, Shift As Integer, _ X As Single, Y As Single) ' Button verschieben, wenn Maustaste gedrückt If Button = vbLeftButton Then Command2.Left = Command2.Left + X - XPos End If End Sub ' Command3 nur senkrecht verschiebbar Private Sub Command3_MouseDown(Button As Integer, Shift As Integer, _ X As Single, Y As Single) ' Ausgangskoordinaten der Maus speichern YPos = Y End Sub Private Sub Command3_MouseMove(Button As Integer, Shift As Integer, _ X As Single, Y As Single) ' Button verschieben, wenn Maustaste gedrückt If Button = vbLeftButton Then Command3.Top = Command3.Top + Y - YPos End If End Sub Geht natürlich auch mit anderen Steuerelementen. Probieren Sie es einfach mal aus. Diese Seite wurde bereits 13.265 mal aufgerufen. |
vb@rchiv CD Vol.6 Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! Online-Update-Funktion Entwickler-Vollversionen u.v.m. Buchempfehlung Tipp des Monats Mai 2024 Hermann Röttger Wochentage eines Datumsbereichs ermitteln Wochentage eines Datumsbereichs ermitteln, optional mit Feiertagsberechnung sevZIP40 Pro DLL Zippen und Unzippen wie die Profis! Mit nur wenigen Zeilen Code statten Sie Ihre Anwendungen ab sofort mit schnellen Zip- und Unzip-Funktionen aus. Hierbei lassen sich entweder einzelnen Dateien oder auch gesamte Ordner zippen bzw. entpacken. |
||||||||||
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein. |