我为一个基金会工作,该基金会旨在提高人们对互联网无障碍的认识。为了演示,我们想提供一个小型研讨会,模拟不同的残疾/缺陷。这是通过一个专门为这次演示创建的网站来完成的。
其中一个被证实的缺陷是有震颤,这意味着经历颤抖,难以控制的手部运动。由于这种缺陷,当鼠标在链接上时,很难准确地移动鼠标光标并按下鼠标按钮。一些老年人和有疾病的人,如帕金森氏症患者,都可能患有震颤。
现在我想以一种不可预测的方式移动鼠标光标,这样人们就很难点击一个小按钮。因为JavaScript不允许直接移动鼠标光标,所以我正在寻找其他方法来实现这一点。我有以下想法:
使用模拟鼠标晃动的鼠标驱动程序/实用程序。
通过CSS隐藏鼠标光标,在原始光标的位置放置一个晃动的鼠标光标的GIF动画(使用JavaScript),然后让目标链接每隔几秒就可以点击一次,持续一秒钟左右。这至少会给人一种感觉,好像总是在错误的时刻点击。
虽然第一个想法很酷,但我找不到这样的工具,无论是Mac还是Windows。我自己也没有任何编程技能。
第二个想法似乎有点笨拙,但我认为它会达到预期的效果。
有人有别的想法吗?
我曾经在Puppy Linux论坛上开玩笑,得到这样的评论:
患有帕金森症的人不会觉得这很有趣!!
幸运的是,这里的治愈方法就是cntrl-C。
下面是需要xdotool的shell脚本
#!/bin/sh
while :; do
xdotool mousemove_relative -- -$(($RANDOM % 10)) $(($RANDOM % 10))
xdotool mousemove_relative -- $(($RANDOM % 10)) -$(($RANDOM % 10))
sleep ${1:-.1} #adjust this as necessary for effect
done
命名为parkinson_sim,并使用可选参数运行两次震动之间的时间,可以是0.001到999.0。
Parkinson_sim [time_between_tremors_in_seconds] #默认值为0.1
我犯了一个错误,我自己点击了它,而不是从命令行运行它,很快就发现这是多么令人沮丧。我试了几次才打开一个终端窗口来杀死它。
这是我的xdotool脚本使用AutoIt的windows版本。这是我的第一个AutoIt脚本,只花了几分钟就写好了,所以我相信它可以改进。只需保存扩展名。au3并使用AutoIt (run Script x86)运行它。
HotKeySet("{HOME}", "GStart")
HotKeySet("{PAUSE}", "Gpause")
HotKeySet("{ESC}", "Gexit")
While 1
Sleep(100)
WEnd
Func Gstart()
While 1
sleep(100)
$pos = MouseGetPos()
$x = $pos[0] + 10 - Random(0, 20, 1)
$y = $pos[1] + 10 - Random(0, 20, 1)
MouseMove($x,$y)
Wend
Endfunc
Func Gpause()
While 1
sleep(100)
Wend
Endfunc
Func Gexit()
MsgBox(0, "exit box", "Script exited")
Exit 0
EndFunc
控制
Home:开始模拟。
pause:暂停模拟。
Esc:退出模拟。
或者使用我在这里编译的版本。
我曾经在Puppy Linux论坛上开玩笑,得到这样的评论:
患有帕金森症的人不会觉得这很有趣!!
幸运的是,这里的治愈方法就是cntrl-C。
下面是需要xdotool的shell脚本
#!/bin/sh
while :; do
xdotool mousemove_relative -- -$(($RANDOM % 10)) $(($RANDOM % 10))
xdotool mousemove_relative -- $(($RANDOM % 10)) -$(($RANDOM % 10))
sleep ${1:-.1} #adjust this as necessary for effect
done
命名为parkinson_sim,并使用可选参数运行两次震动之间的时间,可以是0.001到999.0。
Parkinson_sim [time_between_tremors_in_seconds] #默认值为0.1
我犯了一个错误,我自己点击了它,而不是从命令行运行它,很快就发现这是多么令人沮丧。我试了几次才打开一个终端窗口来杀死它。
而不是试图移动指针,你可以移动应用程序(网页)。我写了一个简单的html表单,其中有一些输入字段。当您将鼠标移动到表单上时,表单也会移动。
您可以在jsfiddle上看到移动表单的演示。尝试单击其中一个输入字段来查看效果。
我使用jquery的抖动效果来实现这一点。javascript的震动效果看起来像这样,只是导致表单上下移动,每当鼠标移动到它:
<script type="text/javascript">
$(document).ready(function() {
$("#toggle").hover(function () {
$(this).effect("shake", { direction: "up", times: 1, distance: 40}, 1000);
});
});
</script>
虽然形式只是上下移动,但我认为它达到了预期的效果。你可以使用参数(方向、时间、距离,以及上面未命名的“1000”)来调整形式移动。