| |

Fortgeschrittene ProgrammierungRe: Entsteht eine Windows-Message, wenn man seine Form verlässt? | |  | Autor: unbekannt | Datum: 25.12.01 16:44 |
| Hi Niko,
lasse mal das Subclassing, ich habe noch etwas anderes für Dich - ist leichter nachvollziehbar.
Du benötigst dazu einen Timer. Dieses Konzept ermittelt ständig die aktuellen Mauskoordinaten - egal wo die Maus auch ist. Auf der Form, auf einem Control oder irgendwo auf dem Screen. Zuvor werden die absoluten Koordinaten des Controls ermittel - im Bezug desses Lage auf dem Screen. Schließlich wird geprüft, ob die Mauskoordinaten mit den Koordinaten des Controls identisch sind. Man braucht dazu nicht mehr die Ereignisse auszuwerten.
Das alles in ein Form (also nicht vergessen Button, Style = graphisch und ein Timer!)
Private Declare Function GetMessagePos Lib "user32" () As Long
Private Declare Function ClientToScreen Lib "user32" _
(ByVal hwnd As Long, lpPoint As POINTAPI) As Long
Private Declare Function PtInRect Lib "user32" (lpRect As RECT, ByVal x As _
Long, ByVal y As Long) As Long
Private Type RECT
Left As Long
Top As Long
Right As Long
Bottom As Long
End Type
Private Type POINTAPI
x As Long
y As Long
End Type
Private nPt As POINTAPI
Private nRect As RECT
Private Sub Form_Load()
Timer1.Interval = 50
ClientToScreen Command1.hwnd, nPt
With nRect
.Top = nPt.y
.Left = nPt.x
.Right = .Left + (Command1.Width) / Screen.TwipsPerPixelX
.Bottom = .Top + (Command1.Height) / Screen.TwipsPerPixelY
End With
End Sub
Private Sub Timer1_Timer()
Dim LongWert As Long, RVal As Long
Dim x As Integer, y As Integer
LongWert = GetMessagePos()
If (LongWert And &H8000&) = 0 Then
x = LongWert And &HFFFF&
y = LongWert / &H10000
Else
x = &H8000 Or (LongWert And &H7FFF&)
y = (LongWert And &H7FFF&) / &H10000
End If
RVal = PtInRect(nRect, x, y)
If RVal > 0 Then
Command1.BackColor = vbGreen
Else
Command1.BackColor = vbRed
End If
End Sub So, dass Proggi ist jetzt schneller als Niko
cu
Lordchen |  |
 | Sie sind nicht angemeldet! Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.
Einloggen | Neu registrieren |
  |
|
Neu! sevCoolbar 3.0 
Professionelle Toolbars im modernen Design!
Mit sevCoolbar erstellen Sie in wenigen Minuten ansprechende und moderne Toolbars und passen diese optimal an das Layout Ihrer Anwendung an (inkl. große Symbolbibliothek) - für VB und MS-Access Weitere InfosTipp des Monats Oktober 2025 Matthias KozlowskiUmlaute konvertierenErsetzt die Umlaute in einer Zeichenkette durch die entsprechenden Doppelbuchstaben (aus ä wird ae, usw.) 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
Nur 24,95 EURWeitere Infos
|
|
|
Copyright ©2000-2025 vb@rchiv Dieter Otter Alle Rechte vorbehalten.
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.
Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel
|
|