当前位置: 首页 > article >正文

实现自定义的移动端双指缩放

原理:

DOM上绑定双指触控相关的事件,当双指触控时,保存初始距离,当双指移动时,计算两触控点的距离,根据移动中的距离与初始距离调节缩放比例,再根据缩放比例改变元素样式即可实现缩放

效果演示:

在这里插入图片描述

vue3 + ts代码如下:

<script setup lang="ts">
import {ref, onMounted} from 'vue';

const scale = ref(1)
let startScale = scale.value

// 缩放灵敏度
const sensitivity = 0.5

// 触控开始的距离
let startDistance: number = 0

/**
 * 计算距离
 * @param touch1
 * @param touch2
 */
function getDistance(touch1: Touch, touch2: Touch): number {
  return Math.sqrt((touch1.clientX - touch2.clientX) ** 2 + (touch1.clientY - touch2.clientY) ** 2)
}

onMounted(() => {
  document.addEventListener('touchstart', onTouchstart, {
    passive: false
  })

  // 触控开始
  function onTouchstart(e: TouchEvent) {
    e.preventDefault()
    const touches = e.touches
    if (touches.length !== 2) {
      return
    }
    startDistance = getDistance(touches[0], touches[1]);
    startScale = scale.value
    document.addEventListener('touchmove', onTouchmove)
    document.addEventListener('touchend', onTouchend)
  }

  // 触控移动
  function onTouchmove(e: TouchEvent) {
    const touches = e.touches
    if (touches.length !== 2) {
      return
    }
    let movingDistance: number = getDistance(touches[0], touches[1]);
    scale.value = Number((startScale * (1 + (movingDistance - startDistance) / startDistance * sensitivity)).toFixed(2))
  }

  // 触控结束
  function onTouchend(e: TouchEvent) {
    document.removeEventListener('touchmove', onTouchmove)
    document.removeEventListener('touchend', onTouchend)
  }
})
</script>

<template>
  <div class="HomeView" :style="{fontSize: `${14 * scale}px`}">
    <div>尝试双指缩放</div>
    <div class="box" :style="{width: `${100 * scale}px`, height: `${100 * scale}px`,}"></div>
    <div>缩放比例:{{ scale }}</div>
  </div>
</template>

<style scoped>
.HomeView {
  transform-origin: left top;
}

.box {
  background-color: red;
}
</style>

http://www.kler.cn/a/291808.html

相关文章:

  • (一)- DRM架构
  • torch.stack 张量维度的变化
  • 使用WebSocket技术实现Web应用中的实时数据更新
  • 【Ubuntu24.04】使用服务器
  • 论文笔记(五十六)VIPose: Real-time Visual-Inertial 6D Object Pose Tracking
  • 从建立TRUST到实现FAIR:可持续海洋经济的数据管理
  • 重头开始嵌入式第三十三天(数据库)
  • jmeter 梯度测试 如何查看TPS、RT指标
  • [SWPUCTF 2021 新生赛]crypto解题思路
  • Redis主从复制原理,设计的很巧妙
  • IP/TCP/UDP协议的关键知识点
  • 2024年高教社杯全国大学生数学建模竞赛B题思路(2024数学建模国赛B题思路)
  • adb remount Now reboot your device for settings to take effect
  • DS18B20温度传感器详解(STM32)
  • 鸿蒙OS试题(2)
  • 【#第三期实战营闯关作业##LMDeploy 量化部署进阶实践 】
  • MySQL 字符串操作详解和案例示范
  • vue ts as断言处理
  • 自定义 ConsoleAppender 实现日志预处理
  • tcp如何保证可靠性传输
  • 数据资产入表元年,企业如何抓住数据资产增值的机遇?
  • 核心交换机的六个基础知识
  • 智慧体育馆如何区别于传统场馆?
  • 选择高性能服务器租用的优势有哪些?
  • vulhub xxe靶机通关教程
  • 编译FFmpeg动态库