vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
Zippen wie die Profis!  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2024
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

Visual-Basic Einsteiger
Problem beim Abfragen der Mausposition 
Autor: TheEd
Datum: 24.12.09 00:31

Hallo,
ich habe ein Programm das herausfinden soll ob sich die Maus über einem bestimmten Label befindet oder nicht. (Ich habe nicht die Mouseover-Funktion benutzt da ich nicht weiß wie ich festellen kann ob sich die Maus nicht über dem Label befindet. Falls jemand weiß wie das geht wäre das auch ne Lösung.)
Hier nun der Codeausschnitt der Probleme bereitet:
Private Sub Timer1_Timer()
GetCursorPos p
 
If p.X * Screen.TwipsPerPixelX - Me.Left > LItem.Left And p.X * _
  Screen.TwipsPerPixelX - Me.Left < LItem.Left + LItem.Width _
And p.Y * Screen.TwipsPerPixelY - Me.Top > LItem.Top And p.Y * _
Screen.TwipsPerPixelY - Me.Top < LItem.Top + LItem.Height Then
MsgBox "Test"
End If
End Sub
Das Problem ist das der Bereich in dem die MsgBox erscheint ein Stück über dem Label liegt und jetzt ist die Frage wieso da er ja erscheinen soll wenn die Maus auf dem Label ist.
Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: Problem beim Abfragen der Mausposition 
Autor: ModeratorDieter (Moderator)
Datum: 24.12.09 08:24

Option Explicit
 
Private Declare Function GetCursorPos Lib "user32" ( _
  lpPoint As POINTAPI) As Long
 
Private Declare Function ScreenToClient Lib "user32" ( _
  ByVal hwnd As Long, _
  lpPoint As POINTAPI) As Long
 
Private Type POINTAPI
  x As Long
  y As Long
End Type
 
Private Sub Form_Load()
  Timer1.Interval = 50
  Timer1.Enabled = True
End Sub
 
Private Sub Timer1_Timer()
  Dim p As POINTAPI
  GetCursorPos p
  ScreenToClient Me.hwnd, p
 
  With Label1
    If p.x >= Me.ScaleX(.Left, Me.ScaleMode, vbPixels) And _
      p.y >= Me.ScaleY(.Top, Me.ScaleMode, vbPixels) And _
      p.x <= Me.ScaleX(.Left + .Width, Me.ScaleMode, vbPixels) And _
      p.y <= Me.ScaleY(.Top + .Height, Me.ScaleMode, vbPixels) Then
 
      Label1.BackColor = vbRed
    Else
      Label1.BackColor = vbButtonFace
    End If
  End With
End Sub

_________________________
Professionelle Entwicklerkomponenten
www.tools4vb.de

Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: Problem beim Abfragen der Mausposition 
Autor: TheEd
Datum: 24.12.09 11:40

Dankeschön funktioniert perfekt.
Kann vielleicht noch jemand sagen was genau
ScreenToClient Me.hwnd
macht?
Konnte nirgends eine Erklärung finden.

Gruß Ed
Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

Re: Problem beim Abfragen der Mausposition 
Autor: Manfred X
Datum: 25.12.09 22:27

Hallo!

Ich vermute die MFC setzt auf diese API direkt auf.

Vielleicht findest Du deshalb die Antwort hier:

http://msdn.microsoft.com/en-us/library/7e1e9a57(VS.80).aspx
Themenbaum einblendenGesamtübersicht  |  Zum Thema  |  Suchen

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

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

Copyright ©2000-2024 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