newAddHandler
像这样使用:
do (addHandler, fire) <- newAddHandler
...
addHandler
是要传递给的 AddHandler reactive-banana
,并且fire
是触发事件的类型函数a -> IO ()
(其中a是您的事件类型)。
例如,您可能会安装fire
为 GLFW 鼠标按钮事件的回调,如下所示:
registerMouseButton :: IO (Event MouseButton)
registerMouseButton = do
(addHandler, fire) <- newAddHandler
setMouseButtonCallback $ \button _ -> fire button
fromAddHandler addHandler
(我没有使用 GLFW 的经验,所以我不确定setMouseButtonCallback
's 回调的第二个参数是什么——如果它很重要,你需要适当地修改这个实现。)
AnAddHandler
只是一个接受回调的函数a -> IO ()
——并为相关事件注册它;然后它(从内部)返回一个用于取消注册此处理程序的操作,使 read 的完整定义如下:IO
IO ()
AddHandler
type AddHandler a = (a -> IO ()) -> IO (IO ())
那么从哪里newAddHandler
进来呢?简单:newAddHandler
维护一个事件的处理程序列表,并在fire x
执行时激活它们。
newAddHandler
如果像 GTK+ 和许多其他常用工具包一样,您的工具包已经具有注册和注销多个事件处理程序的功能,则您不需要;如果是这样,您应该编写自己的AddHandler
. 但是如果它只支持一个回调,你应该使用newAddHandler
.
请注意,您永远不需要将AddHandler
s 暴露给使用 FRP 的代码本身;它们只是用于Event
从外部输入创建 s 的内部粘合剂。