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.264 mal aufgerufen. |
Neu! sevEingabe 3.0 Einfach stark! Ein einziges Eingabe-Control für alle benötigten Eingabetypen und -formate, inkl. Kalender-, Taschenrechner und Floskelfunktion, mehrspaltige ComboBox mit DB-Anbindung, ImageComboBox u.v.m. Buchempfehlung Tipp des Monats Mai 2024 Hermann Röttger Wochentage eines Datumsbereichs ermitteln Wochentage eines Datumsbereichs ermitteln, optional mit Feiertagsberechnung Access-Tools Vol.1 Über 400 MByte Inhalt Mehr als 250 Access-Beispiele, 25 Add-Ins und ActiveX-Komponenten, 16 VB-Projekt inkl. Source, mehr als 320 Tipps & Tricks für Access und VB |
||||||||||
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. |