Platforms to show: All Mac Windows Linux Cross-Platform
Required plugins for this example: MBS Win Plugin
You find this example project in your Plugins Download as a Xojo project file within the examples folder: /Win/Mouse Filter
This example is the version from Wed, 13th Jul 2021.
Project "Mouse Filter.xojo_binary_project"
Class App Inherits Application
Const kEditClear = "&Delete"
Const kFileQuit = "&Quit"
Const kFileQuitShortcut = ""
End Class
Class MainWindow Inherits Window
Control CheckEnabled Inherits CheckBox
ControlInstance CheckEnabled Inherits CheckBox
EventHandler Sub Action()
WinMouseFilterMBS.Enabled = me.Value
End EventHandler
End Control
Control List Inherits Listbox
ControlInstance List Inherits Listbox
End Control
Control CheckMouseMove Inherits CheckBox
ControlInstance CheckMouseMove Inherits CheckBox
EventHandler Sub Action()
WinMouseFilterMBS.IncludeMouseMove = me.Value
End EventHandler
End Control
Control CheckMouseWheel Inherits CheckBox
ControlInstance CheckMouseWheel Inherits CheckBox
EventHandler Sub Action()
WinMouseFilterMBS.IncludeMouseWheel = me.Value
End EventHandler
End Control
Control CheckMouseOver Inherits CheckBox
ControlInstance CheckMouseOver Inherits CheckBox
EventHandler Sub Action()
WinMouseFilterMBS.IncludeMouseHOver = me.Value
End EventHandler
End Control
EventHandler Sub Close()
MouseFilter = nil
End EventHandler
EventHandler Sub Open()
CheckEnabled.Value = true
MouseFilter = new WinMouseFilterMBS
AddHandler MouseFilter.ReceivedEvent, WeakAddressOf ReceivedEvent
End EventHandler
Function IdentifyWindow(WindowHandle as integer) As String
if WindowHandle = self.Handle then
return "MainWindow"
end if
dim c as integer = me.ControlCount
for i as integer = 0 to c-1
dim r as Control = me.Control(i)
if r.Handle = WindowHandle then
return r.Name
end if
next
return str(windowHandle)
End Function
Sub Log(s as string)
List.AddRow s
list.ScrollPosition = List.ScrollPosition + 1
End Sub
Shared Function MessageName(Message as integer) As string
Select case Message
case WinMouseFilterMBS.kMouseMove
return "MouseMove"
case WinMouseFilterMBS.kLButtonDown
return "LButtonDown"
case WinMouseFilterMBS.kLButtonUp
return "LButtonUp"
case WinMouseFilterMBS.kLButtonDoubleClick
return "LButtonDoubleClick"
case WinMouseFilterMBS.kRButtonDown
return "RButtonDown"
case WinMouseFilterMBS.kRButtonUp
return "RButtonUp"
case WinMouseFilterMBS.kRButtonDoubleClick
return "RButtonDoubleClick"
case WinMouseFilterMBS.kMButtonDown
return "MButtonDown"
case WinMouseFilterMBS.kMButtonUp
return "MButtonUp"
case WinMouseFilterMBS.kMButtonDoubleClick
return "MButtonDoubleClick"
case WinMouseFilterMBS.kMouseWheel
return "MouseWheel"
case WinMouseFilterMBS.kXButtonDown
return "XButtonDown"
case WinMouseFilterMBS.kXButtonUp
return "XButtonUp"
case WinMouseFilterMBS.kXButtonDoubleClick
return "XButtonDoubleClick"
case WinMouseFilterMBS.kMouseHWheel
return "MouseHWheel"
case WinMouseFilterMBS.kMouseHOver
return "MouseHOver"
case WinMouseFilterMBS.kMouseLeave
return "MouseLeave"
else
return str(Message)
end Select
End Function
Function ReceivedEvent(MouseFilter as WinMouseFilterMBS, Message as Integer, mouseX as Integer, mouseY as Integer, windowHandle as Integer, HitTestCode as Integer, ExtraInfo as Integer) As Boolean
dim n as string = MessageName(message)
dim w as string = IdentifyWindow(windowHandle)
List.AddRow n, str(mousex), str(mousey), w, str(HitTestCode), str(ExtraInfo)
list.ScrollPosition = List.ScrollPosition + 1
End Function
Property MouseFilter As WinMouseFilterMBS
End Class
MenuBar MainMenuBar
MenuItem FileMenu = "&File"
MenuItem FileQuit = "#App.kFileQuit"
MenuItem EditMenu = "&Edit"
MenuItem EditUndo = "&Undo"
MenuItem EditSeparator1 = "-"
MenuItem EditCut = "Cu&t"
MenuItem EditCopy = "&Copy"
MenuItem EditPaste = "&Paste"
MenuItem EditClear = "#App.kEditClear"
MenuItem EditSeparator2 = "-"
MenuItem EditSelectAll = "Select &All"
End MenuBar
End Project
The items on this page are in the following plugins: MBS Win Plugin.