fix and simplify input handling in Window
This commit is contained in:
parent
3a14aae310
commit
b15c10298e
|
@ -327,9 +327,9 @@ func (w *Window) initInput() {
|
||||||
w.window.SetMouseButtonCallback(func(_ *glfw.Window, button glfw.MouseButton, action glfw.Action, mod glfw.ModifierKey) {
|
w.window.SetMouseButtonCallback(func(_ *glfw.Window, button glfw.MouseButton, action glfw.Action, mod glfw.ModifierKey) {
|
||||||
switch action {
|
switch action {
|
||||||
case glfw.Press:
|
case glfw.Press:
|
||||||
w.currInp.buttons[Button(button)] = true
|
w.tempInp.buttons[Button(button)] = true
|
||||||
case glfw.Release:
|
case glfw.Release:
|
||||||
w.currInp.buttons[Button(button)] = false
|
w.tempInp.buttons[Button(button)] = false
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -339,47 +339,37 @@ func (w *Window) initInput() {
|
||||||
}
|
}
|
||||||
switch action {
|
switch action {
|
||||||
case glfw.Press:
|
case glfw.Press:
|
||||||
w.currInp.buttons[Button(key)] = true
|
w.tempInp.buttons[Button(key)] = true
|
||||||
case glfw.Release:
|
case glfw.Release:
|
||||||
w.currInp.buttons[Button(key)] = false
|
w.tempInp.buttons[Button(key)] = false
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
w.window.SetCursorPosCallback(func(_ *glfw.Window, x, y float64) {
|
w.window.SetCursorPosCallback(func(_ *glfw.Window, x, y float64) {
|
||||||
w.currInp.mouse = pixel.V(
|
w.tempInp.mouse = pixel.V(
|
||||||
x+w.bounds.Min.X(),
|
x+w.bounds.Min.X(),
|
||||||
(w.bounds.H()-y)+w.bounds.Min.Y(),
|
(w.bounds.H()-y)+w.bounds.Min.Y(),
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
|
|
||||||
w.window.SetScrollCallback(func(_ *glfw.Window, xoff, yoff float64) {
|
w.window.SetScrollCallback(func(_ *glfw.Window, xoff, yoff float64) {
|
||||||
w.currInp.scroll += pixel.V(xoff, yoff)
|
w.tempInp.scroll += pixel.V(xoff, yoff)
|
||||||
})
|
})
|
||||||
|
|
||||||
w.window.SetCharCallback(func(_ *glfw.Window, r rune) {
|
w.window.SetCharCallback(func(_ *glfw.Window, r rune) {
|
||||||
w.currInp.typed += string(r)
|
w.tempInp.typed += string(r)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
func (w *Window) updateInput() {
|
func (w *Window) updateInput() {
|
||||||
//FIXME: rething this, currInp can be changed outside this function, which may lead to inconsistencies
|
|
||||||
|
|
||||||
// copy temp to prev
|
|
||||||
w.prevInp = w.tempInp
|
|
||||||
|
|
||||||
// zero current scroll (but keep what was added in callbacks outside of this function)
|
|
||||||
w.currInp.scroll -= w.tempInp.scroll
|
|
||||||
|
|
||||||
// erase typed string
|
|
||||||
w.currInp.typed = ""
|
|
||||||
|
|
||||||
// get events (usually calls callbacks, but callbacks can be called outside too)
|
|
||||||
mainthread.Call(func() {
|
mainthread.Call(func() {
|
||||||
glfw.PollEvents()
|
glfw.PollEvents()
|
||||||
})
|
})
|
||||||
|
|
||||||
// cache current state to temp (so that if there are callbacks outside this function,
|
w.prevInp = w.currInp
|
||||||
// everything works)
|
w.currInp = w.tempInp
|
||||||
w.tempInp = w.currInp
|
|
||||||
|
w.tempInp.scroll = 0
|
||||||
|
w.tempInp.typed = ""
|
||||||
}
|
}
|
||||||
|
|
|
@ -65,7 +65,7 @@ type Window struct {
|
||||||
xpos, ypos, width, height int
|
xpos, ypos, width, height int
|
||||||
}
|
}
|
||||||
|
|
||||||
prevInp, tempInp, currInp struct {
|
prevInp, currInp, tempInp struct {
|
||||||
mouse pixel.Vec
|
mouse pixel.Vec
|
||||||
buttons [KeyLast + 1]bool
|
buttons [KeyLast + 1]bool
|
||||||
scroll pixel.Vec
|
scroll pixel.Vec
|
||||||
|
|
Loading…
Reference in New Issue