微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

触摸时会出现SVG转换抖动,而不是鼠标

如何解决触摸时会出现SVG转换抖动,而不是鼠标

我正在创建一个使用svg以及CSS转换和matrix3d的React应用。 在应用程序中,我能够拖动对象的角以进行变形/扭曲。这在鼠标上很好用,但是一旦我使用evt.touches[0].clientX ,它就会在拖动过程中开始在看似随机的坐标之间跳跃。我保持触摸的时间越长,拐角就越接近触摸点。

示例: https://confident-shirley-bf53ab.netlify.app/ 按下相机,上传随机图像,然后单击一扇门。

Illustration image,draggable corners

这是主要功能

const handletouchMove = (evt) => {  
    if (evt.target.localName === 'circle') {
      const offset = evt.target.getBoundingClientRect();
      const x = evt.touches[0].clientX - offset.left;
      const y = evt.touches[0].clientY - offset.top;
      if (mouseState.targetCircle >= 0) {
        if (mouseState === 4) {
          console.log('Moving door');
        } else {
          setCorners({
            ...corners,[mouseState.targetCircle]: {x,y}  //todo touch
          });
          const doorCorners = [
            [0,0],[doorWidth,doorHeight],[0,doorHeight]
          ]
    
          const circleCorners = Object.values(corners)
            .map(({x,y}) => [x,y]);
          setTransformationMatrix(
            getMatrix(doorCorners,circleCorners)
          );
        }
      }
      
    }  
  }

这是可拖动的圈子之一:

<circle
    className="handle"
    onMouseDown={() => handleCirleChoice(0)}
    onTouchStart={() => handleCirleChoice(0)}
    transform={`translate(${corners[0].x},${corners[0].y})`} 
    r="7"
/>

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 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”。这是什么意思?