- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在开发一个 HTML5 Canvas 项目,在为移动设备添加多点触控支持时,我似乎在 iOS 7.1 中的 Mobile Safari 上遇到了问题。
用户与我的应用程序交互的主要方式是通过单击和拖动。在桌面上,我将适当的鼠标事件监听器添加到我的 Canvas 中...
c.addEventListener('mousedown', mouseDown, false);
c.addEventListener('mousemove', mouseMoved, false);
c.addEventListener('mouseup', mouseUp, false);
...让这些事件处理程序计算鼠标位置并调用一个更通用的函数,该函数仅接受事件的 X 和 Y 位置...
function mouseDown(evt)
{
var pos = getMousePos(evt);
inputDown(pos);
}
function mouseUp(evt)
{
var pos = getMousePos(evt);
inputUp(pos);
}
function mouseMoved(evt)
{
var pos = getMousePos(evt);
inputMoved(pos);
}
function getMousePos(evt)
{
var rect = c.getBoundingClientRect();
return { 'x': evt.clientX - rect.left, 'y': evt.clientY - rect.top }
}
...一切都很好。我设计这种抽象级别是为了方便扩展到其他输入方法。所以现在我尝试使用 Touch API 来扩展它。首先,我将处理程序添加到 Canvas 上鼠标处理程序旁边...
c.addEventListener("touchstart", touchDown, false);
c.addEventListener("touchmove", touchMoved, false);
c.addEventListener("touchend", touchUp, false);
c.addEventListener("touchcancel", touchUp, false);
...然后添加我的瘦事件处理程序来抽象触摸事件...
function touchDown(evt)
{
evt.preventDefault();
// Ignore touches after the first.
if (activeTouch != null)
return;
if (evt.changedTouches.length > 0)
{
activeTouch = evt.changedTouches[0].identifier;
var pos = getTouchPos(evt);
inputDown(pos);
}
}
function touchUp(evt)
{
var pos = getTouchPos(evt);
activeTouch = null;
inputUp(pos);
}
function touchMoved(evt)
{
var pos = getTouchPos(evt);
inputMoved(pos);
}
function getTouchPos(evt)
{
var canX = 0;
var canY = 0;
for( var i = 0; i < evt.touches.length; i++ )
{
if (evt.touches[i].identifier == activeTouch)
{
canX = evt.touches[i].pageX - c.offsetLeft;
canY = evt.touches[i].pageY - c.offsetTop;
break;
}
}
return { 'x': canX, 'y': canY }
}
...这就是我遇到麻烦的地方!你可以看到事情变得有点棘手,但撇开效率低下不谈,我认为我正确地使用了一切。问题是 getTouchPos(evt)
似乎无法获取 touchstart
上触摸的正确 X、Y 位置。第一次触摸时,我得到的位置是 0,0。如果我拖动手指,touchmove
会触发多次,并且报告的 X、Y 坐标看起来不错。如果我抬起手指,touchend
就会触发,我也会得到正确的位置。但是,如果我再次触摸,touchstart
会触发,而不是我正在触摸的位置,我会得到上次触摸结束位置的 X,Y 坐标!
我已经使用调试器进行了调试,果然,陈旧/未初始化的值就在我在事件数据中获得的 Touch 对象中。我做错了什么吗?我不明白为什么我似乎从 touchstart
事件中获得了错误的坐标。我可以做什么来解决这个问题?我可以使用其他来源来获得正确的位置吗?对事件顺序进行微妙的调整?
Here's a link to an online demo of the full code if you'd like to run some in-browser debug.
提前感谢您的帮助。
最佳答案
我不确定这是否显而易见,但这是一个调试起来很有趣的问题。所以基本上,困惑归结于这个人:
function mouseMoved(evt) {
var pos = getMousePos(evt);
inputMoved(pos);
}
对于您的鼠标事件,一切都很好,因为您必须绑定(bind)到 mousemove
。
c.addEventListener('mousemove', mouseMoved, false);
哪个调用
function mouseMoved(evt) {
var pos = getMousePos(evt);
inputMoved(pos);
}
因此,当您移动鼠标时,您的 posX/posY
值会不断更新。 (希望您现在就看到这个问题了:)
对于 TouchEvents,当用户触摸(但不移动)时,您只会触发 touchstart
和 touchend
。直到用户拖动时,touchmove
才会被调用,进而调用函数 touchMoved
(调用 inputMoved
- 更新您的posX/posY
值)。
在您的页面上解决此问题的最简单方法就是在 touchstart
和 touchmove
中调用 inputMoved
,以便您的 MassHaver
实例具有最新状态。
关于javascript - 触摸事件 "touchstart"在 Mobile Safari 上返回错误位置。解决方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23586944/
我该怎么做 touch R 中的文件(即更新其修改时间而不更改其内容)?我正在寻找一个跨平台的内置(或打包)等效于: system2("touch", file_name) 最佳答案 我找到了 an
我想在 android 中实现 body 部位选择。我的要求是,当我点击特定部分时,图像应用程序应该能够识别 body 部位并且所选部分的颜色应该改变。附上示例图像以供引用。 如有任何想法或建议,我们
我需要将3D模型加载到我的应用程序中(不是游戏,它没有任何区别),并检测用户何时触摸此模型的特定部分以采取不同的操作。 我怎样才能做到这一点?可能吗? 最佳答案 我不熟悉Rajawali,但GitHu
似乎连续触摸总是被它起源的控件捕获。是否有标准方法将触摸/手势传递给当前触摸结束的控件? 最佳答案 控件显示在 UIView 对象内部的屏幕上。 iOS 使用第一响应者的概念来处理 UIView 对象
我有一个 UIScrollView 实例,允许用户放大/缩小。我已经根据文档实现了一个委托(delegate)来处理这个问题。但是,我想知道用户触摸 ScrollView 的位置(相对于 Scroll
我正在创建一款射击游戏,您可以触摸屏幕,玩家可以射击。我遇到的问题是,当你触摸屏幕并按住它并拖动它时,它会快速射击。处理这个问题的最佳方法是什么? 我希望玩家能够按住手指并以稳定的速度射击,而手指向上
- (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typ
这是我从触摸事件中获得的返回数据。明显缺少任何有用的触摸 X/Y 坐标 ( https://developer.mozilla.org/en-US/docs/Web/API/TouchEvent/ch
因此,我有一个屏幕,其中包含 0 到 6 个通过 XML 包含的相同用户界面组件。类似这样的东西: ...等等 每个包含的 UI 都是我重复使用的几个小部件和自定义组件的集
我希望能够更改文件的修改日期以便在 Web 应用程序中使用。目前我直接在命令行上测试这个。在我的 Mac 上工作正常,但是当我在 Linux 服务器上执行此操作时出现错误。 命令:/bin/touch
概念问题: 我在使用 touches 时遇到了一个非常简单的问题属性,自动更新依赖模型的时间戳;它正确地这样做了,但也应用了全局范围。 有什么办法可以关闭这个功能吗?或专门询问自动 touches忽略
我很难在一个简单的等距 Sprite Kit 游戏中实现点击处理。 我有一个包含多个 Tile 对象(SKSpriteNode)的 map (SKNode)的游戏场景(SKScene)。 这是 map
有没有办法在触摸事件后恢复 Flexslider 幻灯片的自动播放?现在看来,一旦我滑动导航,幻灯片就会停止...... 最佳答案 FLEXISLIDER 2 更新 resume()事件不再存在,正确
有些游戏有一些小图片作为 Sprite ,可以通过触摸来移动。如果 Sprite 是较大的图片,触摸是很正常的。我们可以使用函数CGRectContainsPoint检查 Sprite 。但是当 Sp
我有一个 View 覆盖到 iPhone 的相机 View 上。在此 View 中,我有一些 uibuttons,它们显示的位置取决于加速度计/指南针的值。当用户在 View 内触摸但没有在 uibu
我有一个 UIView 和一个 UIWebView。 UIWebView 是 UIView 的 subview 。 UIWebView 包含 YouTube 视频,并设置为让视频适合 UIWebVie
我是通过 XCode 使用 SDK 版本 5.0 进行 iOS 开发的新手。在我的应用程序中,我需要在按下按钮时更改按钮的标题。 假设在正常状态下它是“未推送”的。我所需要的是,当我按下按钮时,按钮标
我需要防止我的网络应用程序中的水平滚动。我尝试在 touchmove 事件上使用 PreventDefault(),但它也阻止垂直滚动。 有什么想法吗?^^ 我的尝试: $(document)
对于完全适合动画组方法的动画效果,如Brad Larson's answer here所示,我需要动画根据输入进行。特别是触摸和检测到的触摸的位置。处理 TouchMoved: 并为每次触摸设置元素的
我在屏幕上散布了一系列硬币。我想在触摸硬币时添加声音。 private Music coinSound; 在 show() 中: coinSound=assetManager.get(Assets.c
我是一名优秀的程序员,十分优秀!