通过 dispatchEvent

如何解决通过 dispatchEvent

我目前正在开发一个系统,该系统应该在带有触摸屏的桌面系统上打开的网络浏览器中运行。该系统应该检测放置在屏幕上的物体(有形物体)和其他触摸。该窗口在背景中包含一个画布,在该画布上检测到有形物体以及覆盖的 iframe 和其他按钮(它们仅占据窗口的一部分,仍然有足够的空间来放置和检测有形物体)。根据有形的 iframe 的地址 url 包含不同的参数。

我目前面临的问题是,当有形物体放置在画布上时,我在导航 iframe 时遇到问题。 当没有放置有形物体时,我可以很好地导航 iframe(在 touchend 之后没有刷新测试)。我猜,它有问题,因为它仍然有触摸由于有形,因此将其检测为多点触控。对于按钮,我可以通过侦听事件 touchstart 而不是单击来解决它。但是对于 iframe 这不是一个选项,因为我无法更改嵌入文档的代码

所以我的想法是,当在 iframe(或者 iframe 的 div 父级)上检测到 touchstart 时,它应该将画布的当前活动触摸保存在一个数组中,然后删除这些触摸。然而,touches 和 TouchList 是只读的,因此我寻找了一个解决方案。 Here I found a possible solution. 我尝试为画布上与它匹配的每个触摸创建一个触摸,并在触摸上调度事件 touchEnd 以结束并因此将其删除,但是之后它仍然在窗口中得到了触摸。

var subSystem = document.getElementById("hideBody");
subSystem.addEventListener("touchstart",(event) => {
  console.log("Touch in Subsystem");
  console.log(window.event.touches);
  for (var i = 0; i < newTouchPoints.length; i++) {
    if (Touch.length < 1 || TouchEvent.length < 1)
      throw "TouchEvent constructors not supported";

    var touch = new Touch({
      identifier: newTouchPoints[i].identifier,target: canvas,clientX: newTouchPoints[i].clientX,clientY: newTouchPoints[i].clientY,screenX: newTouchPoints[i].clientX,screenY: newTouchPoints[i].clientY,pageX: newTouchPoints[i].clientX,pageY: newTouchPoints[i].clientY,radiusX: newTouchPoints[i].radiusX,radiusY: newTouchPoints[i].radiusY,rotationAngle: 0,force: 0.5
    })
    var touchEvent = new TouchEvent("touchend",{
      cancelable: true,bubbles: true,composed: true,touches: [touch],targettouches: [touch],changedtouches: [touch]
    })
    console.log(touch);
    document.body.dispatchEvent(touchEvent);
  }
  console.log(window.event.touches);
});

touches 只使用 clientX 和 clientY。 screen 和 page 始终与客户端具有相同的值(clientX = screenX = pageX)。 Here is the console log. 如图所示,创建的 Touch 和 window.event.touches 上的 touch 应该是一样的。有人知道错误可能在哪里以及如何解决吗?

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?