Platforms to show: All Mac Windows Linux Cross-Platform

/Win/Mouse Filter


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.


The biggest plugin in space...