JavaScript移动端 缩放 位移 touch 事件

爬过不少坑 , 总结下 基于 原生 JavaScript touch 事件 实现 移动端 缩放 位移

下面 有 在 Vue 项目中的实现方法 仅供参考

闲话少叙 看代码:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title>gesture</title>
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <style>
        #app {
	    position: absolute;
	    bottom: 0px;
	    left: 0px;
            border: 2px solid red;
            width: 700px;
            height: 500px;
            overflow: hidden;
	}

        .box {
            touch-action: none;
            position: absolute;
            background: green;
            border: 1px solid black;
            width: 300px;
            height: 200px;
	}
    </style>
</head>

<body>
    <div id="app">
     <!--下面 class="box" 的元素 可以替换为 pdf 文件 或者 图片...>
     <!-- <embed src="pdf地址" type="application/pdf" internalinstanceid="4" class="box"> -->
    <div class="box"></div>
     <!-- <img src="1.png" alt="" class="box"> -->
    </div>
    <script>
        var pageX, pageY, initX, initY, isTouch = false;
        var start = [];
	document.addEventListener("touchstart", function (e) {
	    //手指按下时的手指所在的X,Y坐标  
	    pageX = e.targetTouches[0].pageX;
	    pageY = e.targetTouches[0].pageY;
	    //初始位置的X,Y 坐标  
	    initX = e.target.offsetLeft;
	    initY = e.target.offsetTop;
	    //记录初始 一组数据 作为缩放使用
	    if (e.touches.length >= 2) { //判断是否有两个点在屏幕上
		start = e.touches; //得到第一组两个点
	    };
	    //表示手指已按下  
	    isTouch = true;
	}, false);

	//监听 touchmove 事件 手指 移动时 做的事情
	document.addEventListener("touchmove", function (e) {
	    e.preventDefault();
	    // 一根 手指 执行 目标元素移动 操作
	    if (e.touches.length == 1 && isTouch) {
	        //移动目标的 X Y 坐标
	        var touchMoveX = e.targetTouches[0].pageX,
	        touchMoveY = e.targetTouches[0].pageY;
	        //设置当前点击元素的 top left 定位值
	        e.target.style.left = parseInt(touchMoveX) - parseInt(pageX) + parseInt(initX) + "px";
	        e.target.style.top = parseInt(touchMoveY) - parseInt(pageY) + parseInt(initY) + "px";
	    };

	    // 2 根 手指执行 目标元素放大操作
	    if (e.touches.length >= 2 && isTouch && e.scale < 2.5) {
		//得到第二组两个点
		var now = e.touches;
		//得到缩放比例, getDistance 是勾股定理的一个方法
		var scale = (getDistance(now[0], now[1]) / getDistance(start[0], start[1]));
		// 对缩放 比例 取整
		e.scale = scale.toFixed(2);
		// 执行目标元素的缩放操作
		e.target.style.transform = "scale(" + scale + ")";
	    };
        }, false);

	//监听 手指离开屏幕时 
	document.addEventListener("touchend", function (e) {
	    //将 isTouch 修改为false  表示 手指已经离开屏幕
	    if (isTouch) {isTouch = false;}
	}, false);

	//缩放 勾股定理方法
	function getDistance(p1, p2) {
	    var x = p2.pageX - p1.pageX,
	    y = p2.pageY - p1.pageY;
	    return Math.sqrt((x * x) + (y * y));
	};
    </script>
</body>
</html>

到 ipad,  安卓, 苹果 上试试效果吧 

注释已经写的很全面了 如果想要添加其他的操作 可以在 相应的监听事件里做....

如何 集成到 vue 中 可以查看 Vue 中实现 移动端 缩放位移 

以上内容 仅供参考 

如有错误请指正 Email:

---------> bianliuzhu@gmail.com <----------

  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
实现移动端touch事件的横向滑动列表效果可以使用原生的JavaScript和CSS3来实现。 首先,我们需要在HTML中创建一个容器元素,用来包含列表项。容器元素需要设置overflow-x属性为scroll,使得内容超出容器范围时可以滚动。 ```html <div class="container"> <ul class="list"> <li>项1</li> <li>项2</li> <li>项3</li> <li>项4</li> <li>项5</li> </ul> </div> ``` 然后,在CSS中,我们需要设置容器元素和列表项的样式,以及使用CSS3的transition属性来实现平滑的过渡效果。 ```css .container { width: 100%; overflow-x: scroll; -webkit-overflow-scrolling: touch; /* 添加iOS滚动效果 */ } .list { display: flex; flex-wrap: nowrap; /* 设置列表项不换行 */ transition: transform 0.3s ease; /* 添加平滑的过渡效果 */ } .list li { width: 100px; height: 100px; margin-right: 10px; background-color: #ccc; } ``` 最后,在JavaScript中,我们需要监听容器元素的touchstart、touchmove和touchend事件,计算滑动距离并通过改变列表项的transform属性来实现横向滑动效果。 ```javascript const container = document.querySelector('.container'); const list = document.querySelector('.list'); let isDragging = false; let startPosition = 0; let currentTranslate = 0; let prevTranslate = 0; let animationId = 0; container.addEventListener('touchstart', touchStart); container.addEventListener('touchmove', touchMove); container.addEventListener('touchend', touchEnd); container.addEventListener('touchcancel', touchEnd); function touchStart(event) { if (event.target.classList.contains('list')) { isDragging = true; startPosition = event.touches[0].clientX; animationId = requestAnimationFrame(updateAnimation); container.classList.add('grabbing'); } } function touchMove(event) { if (isDragging) { const currentPosition = event.touches[0].clientX; currentTranslate = prevTranslate + currentPosition - startPosition; } } function touchEnd() { isDragging = false; cancelAnimationFrame(animationId); prevTranslate = currentTranslate; container.classList.remove('grabbing'); } function updateAnimation() { list.style.transform = `translateX(${currentTranslate}px)`; animationId = requestAnimationFrame(updateAnimation); } ``` 通过以上代码,我们就成功地实现了移动端touch事件的横向滑动列表效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Gleason.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值