MouseMove - 反向事件是什么?

问题描述 投票:2回答:3
Private Sub framePDF_MouseMove(ByVal... )
framePDF.BackColor = &H80000012&  

因此,框架的颜色正在发生变化。 当光标离开框架时,我找不到事件返回颜色?

excel vba
3个回答
2
投票

在vba和VB6中没有MouseLeave事件。

实现此目的的最佳方法是在鼠标进入框架时启动计时器。

然后在定时器代码中检查鼠标指针是否仍然在帧​​的范围内。如果不改变颜色并停止计时器

将此代码放在一个模块中:

Public Declare Function GetCursorPos Lib "user32" (lpPoint As _
   POINTAPI) As Long

Public Type POINTAPI
        x As Long
        y As Long
End Type

在表单上创建一个计时器,设置interval =10 Enbaled = False

然后代码看起来像这样:

Private Sub frameTest_MouseMove(Button As Integer, Shift As Integer, x As Single, y As Single)
    frameTest.BackColor = vbRed
    tmrMouseLeave.Enabled = True
End Sub

Private Sub tmrMouseLeave_Timer()
    Dim pt As POINTAPI
    Call GetCursorPos(pt)
    Dim xValue As Long, yValue As Long
    xValue = pt.x * Screen.TwipsPerPixelX
    yValue = pt.y * Screen.TwipsPerPixelY

    If (xValue > (Me.Left + frameTest.Left)) And _
       (xValue < (Me.Left + frameTest.Left + frameTest.width)) And _
       (yValue > (Me.Top + frameTest.Top)) And _
       (yValue < (Me.Top + frameTest.Top + frameTest.height)) Then
        'we are still inside the frame
    Else
        'mouse is outside the frame
        frameTest.BackColor = vbBlue
        tmrMouseLeave.Enabled = False
    End If
End Sub

3
投票

在Userform上? Userform还有一个MouseMove事件,当你在Frame中时它不会触发。

Private Sub Frame1_MouseMove(ByVal ...)

    Me.Frame1.BackColor = vbRed

End Sub

Private Sub UserForm_MouseMove(ByVal ...)

    Me.Frame1.BackColor = vbWhite

End Sub

当你翻过它时会把画面变成红色而你不翻画时会变成白色。这些事件不断发生,所以明智地使用它们。


0
投票

更简单的方法:在你的MouseMove事件中,根据控件的宽度和高度测试X和Y参数(减去一个边距,比如5) - 如果鼠标位于边距内,则将其视为“鼠标移出”并相应地更改控件的颜色。无需并发按钮,z顺序操作,框架等。

© www.soinside.com 2019 - 2024. All rights reserved.