JS实现移动端双指缩放和旋转方法


Posted in Javascript onDecember 13, 2019

js实现移动端双指缩放和旋转,具体代码如下所示:

var initHeading = 0;
  var rotation = 0;
  var lastTime;
  function setGesture(el){
    var obj={}; 
    var istouch=false;
    var start=[];
    el.addEventListener("touchstart",function(e){
      if(e.touches.length>=2){ //判断是否有两个点在屏幕上
        istouch=true;
        start=e.touches; //得到第一组两个点
        obj.gesturestart&&obj.gesturestart.call(el); //执行gesturestart方法
      };
    },false);
    document.addEventListener("touchmove",function(e){
      e.preventDefault();
      if(e.touches.length>=2&&istouch){
        var now=e.touches; //得到第二组两个点
        var scale=getDistance(now[0],now[1])/getDistance(start[0],start[1]); //得到缩放比例,getDistance是勾股定理的一个方法
        var rotation=getAngle(now[0],now[1])-getAngle(start[0],start[1]); //得到旋转角度,getAngle是得到夹角的一个方法
        e.scale=scale.toFixed(2);
        e.rotation=rotation.toFixed(2);
        obj.gesturemove&&obj.gesturemove.call(el,e); //执行gesturemove方法
      };
    },false);
    document.addEventListener("touchend",function(e){
      if(istouch){
        istouch=false;
        obj.gestureend&&obj.gestureend.call(el); //执行gestureend方法
      };
    },false);
    return obj;
  };
  function getDistance(p1, p2) {
    var x = p2.pageX - p1.pageX,
      y = p2.pageY - p1.pageY;
    return Math.sqrt((x * x) + (y * y));
  };
  function getAngle(p1, p2) {
    var x = p1.pageX - p2.pageX,
      y = p1.pageY- p2.pageY;
    return Math.atan2(y, x) * 180 / Math.PI;
  };
  var box=document.querySelector("#map3d");
  var boxGesture=setGesture(box); //得到一个对象
  boxGesture.gesturestart=function(){ //双指开始
    /*box.style.backgroundColor="yellow";*/
    initHeading = map25D._coreMap.map.position.heading;
  };

  boxGesture.gesturemove=function(e){ //双指移动
    rotation = parseInt(e.rotation);
    var time = new Date().getTime();
    var realRotation = changeAngle(rotation,time);
    if(realRotation){
    //TODO 得到旋转角度后想实现的功能
map25D._coreMap.map.position.setHeading(realRotation);
      map25D._coreMap.map.renderer.update();
    }
  };
  boxGesture.gestureend=function(){ //双指结束

  };
  //通过时间判断解决叠加初始方向
  var changeAngle = function (heading,newTime) {
    if((newTime - lastTime) < 2){
      return false;
    }
    lastTime = newTime;
    return (initHeading + heading)
  }

ps:下面看下js缩放网页比例

将当前网页缩放比变为200%

document.getElementsByTagName('body')[0].style.zoom=2

总结

以上所述是小编给大家介绍的JS实现移动端双指缩放和旋转方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
javascript 日期常用的方法
Nov 11 Javascript
解决IE6的PNG透明JS插件使用介绍
Apr 17 Javascript
javascript实现微信分享
Dec 23 Javascript
JS实现浏览器状态栏文字从右向左弹出效果代码
Oct 27 Javascript
js省市联动效果完整实例代码
Dec 09 Javascript
基于javascript实现listbox左右移动
Jan 29 Javascript
Vue.js常用指令汇总(v-if、v-for等)
Nov 03 Javascript
原生js实现图片放大缩小计时器效果
Jan 20 Javascript
微信小程序 支付功能(前端)的实现
May 24 Javascript
简化vuex的状态管理方案的方法
Jun 02 Javascript
使用jQuery实现掷骰子游戏
Oct 24 jQuery
JS实现数组去重的11种方法总结
Apr 04 Javascript
微信小程序返回上一页传参并刷新过程解析
Dec 13 #Javascript
Vue分页效果与购物车功能
Dec 13 #Javascript
如何在微信小程序中存setStorage
Dec 13 #Javascript
在微信小程序中使用mqtt服务的方法
Dec 13 #Javascript
微信小程序之左右布局的实现代码
Dec 13 #Javascript
vue实现输入一位数字转汉字功能
Dec 13 #Javascript
小程序登录之支付宝授权的实现示例
Dec 13 #Javascript
You might like
php Smarty初体验二 获取配置信息
2011/08/08 PHP
Symfony2安装第三方Bundles实例详解
2016/02/04 PHP
多个js与css文件的合并方法详细说明
2012/12/26 Javascript
node.js中的fs.openSync方法使用说明
2014/12/17 Javascript
学习JavaScript编程语言的8张思维导图分享
2015/03/27 Javascript
javascript实现五星评价代码(源码下载)
2015/08/11 Javascript
详解iframe与frame的区别
2016/01/13 Javascript
Bootstrap3学习笔记(二)之排版
2016/05/20 Javascript
Bootstrap基本组件学习笔记之分页(12)
2016/12/08 Javascript
微信小程序遇到修改数据后页面不渲染的问题解决
2017/03/09 Javascript
bootstrap table动态加载数据示例代码
2017/03/25 Javascript
Angular.js中下拉框实现渲染html的方法
2017/06/18 Javascript
JS解析url查询参数的简单代码
2017/08/06 Javascript
Vue组件化开发思考
2018/02/02 Javascript
vue.js 双层嵌套for遍历的方法详解, 类似php foreach()
2018/09/07 Javascript
node.JS二进制操作模块buffer对象使用方法详解
2020/02/06 Javascript
Vue快速实现通用表单验证的方法
2020/02/24 Javascript
vant 时间选择器--开始时间和结束时间实例
2020/11/04 Javascript
python开发之list操作实例分析
2016/02/22 Python
Django restframework 源码分析之认证详解
2019/02/22 Python
使用python 对验证码图片进行降噪处理
2019/12/18 Python
关于ZeroMQ 三种模式python3实现方式
2019/12/23 Python
解决pytorch-yolov3 train 报错的问题
2020/02/18 Python
浅谈Python中的异常和JSON读写数据的实现
2020/02/27 Python
python爬虫开发之urllib模块详细使用方法与实例全解
2020/03/09 Python
python实现二分类和多分类的ROC曲线教程
2020/06/15 Python
香港交友网站:be2香港
2018/07/22 全球购物
Notino芬兰:购买香水和化妆品
2019/04/15 全球购物
为女性购买传统的印度服装和婚纱:Kalkifashion
2019/07/22 全球购物
餐厅总经理岗位职责
2013/12/31 职场文书
三关爱志愿服务活动方案
2014/08/17 职场文书
公司自我介绍演讲稿
2014/08/21 职场文书
四风对照检查剖析材料
2014/10/07 职场文书
大学运动会通讯稿
2015/07/18 职场文书
初中信息技术教学反思
2016/02/16 职场文书
pytorch中的model.eval()和BN层的使用
2021/05/22 Python