Compress mouse scroll and motion events #4

Merged
sashakoshka merged 3 commits from compress-scroll into main 2022-11-17 18:32:35 -07:00
4 changed files with 27 additions and 5 deletions
Showing only changes of commit c57c8acba7 - Show all commits

View File

@ -63,6 +63,12 @@ func (application *Application) OnMouseMove (
application.callbackManager.onMouseMove = onMouseMove application.callbackManager.onMouseMove = onMouseMove
} }
func (application *Application) OnScroll (
onScroll func (x, y int),
) {
application.callbackManager.onScroll = onScroll
}
func (application *Application) OnStart ( func (application *Application) OnStart (
onStart func (), onStart func (),
) { ) {

View File

@ -68,7 +68,20 @@ func (backend *Backend) handleButtonPress (
event xevent.ButtonPressEvent, event xevent.ButtonPressEvent,
) { ) {
buttonEvent := *event.ButtonPressEvent buttonEvent := *event.ButtonPressEvent
if buttonEvent.Detail >= 4 && buttonEvent.Detail <= 7 {
switch buttonEvent.Detail {
case 4:
backend.callbackManager.RunScroll(0, -1)
case 5:
backend.callbackManager.RunScroll(0, 1)
case 6:
backend.callbackManager.RunScroll(-1, 0)
case 7:
backend.callbackManager.RunScroll(1, 0)
}
} else {
backend.callbackManager.RunPress(stone.Button(buttonEvent.Detail + 127)) backend.callbackManager.RunPress(stone.Button(buttonEvent.Detail + 127))
}
} }
func (backend *Backend) handleButtonRelease ( func (backend *Backend) handleButtonRelease (
@ -76,6 +89,7 @@ func (backend *Backend) handleButtonRelease (
event xevent.ButtonReleaseEvent, event xevent.ButtonReleaseEvent,
) { ) {
buttonEvent := *event.ButtonReleaseEvent buttonEvent := *event.ButtonReleaseEvent
if buttonEvent.Detail >= 4 && buttonEvent.Detail <= 7 { return }
backend.callbackManager.RunRelease(stone.Button(buttonEvent.Detail + 127)) backend.callbackManager.RunRelease(stone.Button(buttonEvent.Detail + 127))
} }

View File

@ -6,6 +6,7 @@ type CallbackManager struct {
onRelease func (button Button) onRelease func (button Button)
onResize func () onResize func ()
onMouseMove func (x, y int) onMouseMove func (x, y int)
onScroll func (x, y int)
onStart func () onStart func ()
} }
@ -34,6 +35,11 @@ func (manager *CallbackManager) RunMouseMove (x, y int) {
manager.onMouseMove(x, y) manager.onMouseMove(x, y)
} }
func (manager *CallbackManager) RunScroll (x, y int) {
if manager.onScroll == nil { return }
manager.onScroll(x, y)
}
func (manager *CallbackManager) RunStart () { func (manager *CallbackManager) RunStart () {
if manager.onStart == nil { return } if manager.onStart == nil { return }
manager.onStart() manager.onStart()

View File

@ -52,10 +52,6 @@ const (
MouseButtonLeft Button = MouseButton1 MouseButtonLeft Button = MouseButton1
MouseButtonMiddle Button = MouseButton2 MouseButtonMiddle Button = MouseButton2
MouseButtonRight Button = MouseButton3 MouseButtonRight Button = MouseButton3
MouseButtonScrollUp Button = MouseButton4
MouseButtonScrollDown Button = MouseButton5
MouseButtonScrollLeft Button = MouseButton6
MouseButtonScrollRight Button = MouseButton7
MouseButtonBack Button = MouseButton8 MouseButtonBack Button = MouseButton8
MouseButtonForward Button = MouseButton9 MouseButtonForward Button = MouseButton9