我为一个基金会工作,该基金会旨在提高人们对互联网无障碍的认识。为了演示,我们想提供一个小型研讨会,模拟不同的残疾/缺陷。这是通过一个专门为这次演示创建的网站来完成的。

其中一个被证实的缺陷是有震颤,这意味着经历颤抖,难以控制的手部运动。由于这种缺陷,当鼠标在链接上时,很难准确地移动鼠标光标并按下鼠标按钮。一些老年人和有疾病的人,如帕金森氏症患者,都可能患有震颤。

现在我想以一种不可预测的方式移动鼠标光标,这样人们就很难点击一个小按钮。因为JavaScript不允许直接移动鼠标光标,所以我正在寻找其他方法来实现这一点。我有以下想法:

使用模拟鼠标晃动的鼠标驱动程序/实用程序。 通过CSS隐藏鼠标光标,在原始光标的位置放置一个晃动的鼠标光标的GIF动画(使用JavaScript),然后让目标链接每隔几秒就可以点击一次,持续一秒钟左右。这至少会给人一种感觉,好像总是在错误的时刻点击。

虽然第一个想法很酷,但我找不到这样的工具,无论是Mac还是Windows。我自己也没有任何编程技能。

第二个想法似乎有点笨拙,但我认为它会达到预期的效果。

有人有别的想法吗?


当前回答

你的第二个想法(隐藏光标)是一个我认为可能很适合你的想法的一半:

如您所建议的,通过CSS隐藏鼠标光标。(光标:没有这个) 使用一些图像+ CSS绝对定位+ JS来模拟鼠标指针,而不是一个晃动光标的GIF;也就是说,沿着鼠标在页面上移动,并在鼠标光标所在的位置放置光标图像。

然后,在光标代码中添加一些颤动数学,以“摇动”光标。由你来决定什么是正确的曲线来正确地模拟震颤输入。

最后:对于你正在编程的任何控件(链接等):

捕获单击事件,根据震颤曲线的状态将它们推到当前的“震颤”位置,并检查元素,看看用户是否已经摆脱了预期的元素,或者可能进入了预期之外的元素。

这个实现的一个主要好处是:你的“晃动的光标”将显示在触控设备上,而触控设备本来就没有光标。


编辑:

基于评论中Michael Theriot(非常干净和有用!)的基本JSFiddle,这里有一个在当前光标位置附近以正态分布扫描不断抖动的JSFiddle: http://jsfiddle.net/benmosher/0x4mc64v/4/

(normal数组是在R控制台中调用rnorm(100)的结果。在JS中我能想到的最简单的方法是对正态分布随机整数进行抽样。)

其他回答

你的第二个想法(隐藏光标)是一个我认为可能很适合你的想法的一半:

如您所建议的,通过CSS隐藏鼠标光标。(光标:没有这个) 使用一些图像+ CSS绝对定位+ JS来模拟鼠标指针,而不是一个晃动光标的GIF;也就是说,沿着鼠标在页面上移动,并在鼠标光标所在的位置放置光标图像。

然后,在光标代码中添加一些颤动数学,以“摇动”光标。由你来决定什么是正确的曲线来正确地模拟震颤输入。

最后:对于你正在编程的任何控件(链接等):

捕获单击事件,根据震颤曲线的状态将它们推到当前的“震颤”位置,并检查元素,看看用户是否已经摆脱了预期的元素,或者可能进入了预期之外的元素。

这个实现的一个主要好处是:你的“晃动的光标”将显示在触控设备上,而触控设备本来就没有光标。


编辑:

基于评论中Michael Theriot(非常干净和有用!)的基本JSFiddle,这里有一个在当前光标位置附近以正态分布扫描不断抖动的JSFiddle: http://jsfiddle.net/benmosher/0x4mc64v/4/

(normal数组是在R控制台中调用rnorm(100)的结果。在JS中我能想到的最简单的方法是对正态分布随机整数进行抽样。)

你不能指望任何人都能把他们的手握得非常稳定,所以你可以考虑的一件事是,

向用户解释你在做什么, 让演示页面上的可点击元素比正常情况下要小得多。 将示例系统上的鼠标灵敏度提高到最大。

我的理由是(注意,我不是用户体验或医学专家)通过缩小可点击元素,你为大多数人创造了一个类似的问题,患有帕金森病的人每天都会面对一个网站。

这只是一个让震颤“正确”的想法,你可以记录一个真实病人的鼠标运动,这使它更真实,当你告诉人们数据来自哪里。

这里有一个脚本,让猫跟随你的鼠标光标,你可以调整一个,让第二个光标跟随(跳跃)你的光标。该页面正在计算第二个游标的位置,因此它还可以确定单击事件是否成功。

如果可以的话,请让它基于网络,这样你会接触到更多的人,而不是让他们安装一个程序或激活flash或其他任何东西。

你可以使用一套模拟老年人的服装,比如本文中描述的那种……我怀疑手颤抖的部分只是一个振动电机绑在手腕上,加上一些厚手套,使手通常笨拙。

模拟地震的低水平部分现在已经很好地解决了。我将添加一些专注于模拟的震颤类型的东西:

大多数答案实现了一个鼠标光标在X和Y方向上具有固定的最大步宽的随机路径上移动。

这应该可以很好地满足用例,使它难以点击一个特定的区域,如按钮。

对于模拟由帕金森病引起的震颤引起的UI问题的更普遍的问题,至少实际模拟这种震颤的手部运动是有趣的。 我怀疑随机游走可能不是一个很好的近似。

当然,可能很难获得真正的手部震颤运动的痕迹数据,但肯定有关于分析这种震颤的论文:

帕金森病患者手部运动的参数化表示是关于如何绘制手部运动的三维轨迹。 这篇论文是付费的,但右上方的预览图,在书的图片上标记为“看>”,展示了一些有趣的手迹数据的不同表示形式。