如何用js实现手指缩放图片功能
发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,这篇"如何用js实现手指缩放图片功能"文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇"如
千家信息网最后更新 2025年02月03日如何用js实现手指缩放图片功能
这篇"如何用js实现手指缩放图片功能"文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇"如何用js实现手指缩放图片功能"文章吧。
需求:
用手指缩放图片。其实在实现这个需求以前,并不知道,微信公众号以及微信小程序里面有一个原生的api就自带这个特效,而且微信朋友圈也是用的这个api。wx.previewImage,就是它。预览图片。除了不能预览开发环境的本地电脑的图片外,你手机真机的图片,以及http服务器上的图片都是可以预览的,而且缩放功能做得很流畅。
先上源码,然后在逐步剖析:
Page({ data: { touch: { distance: 0, scale: 1, baseWidth: null, baseHeight: null, scaleWidth: null, scaleHeight: null } }, touchstartCallback: function(e) { // 单手指缩放开始,也不做任何处理 if(e.touches.length == 1) return console.log('双手指触发开始') // 注意touchstartCallback 真正代码的开始 // 一开始我并没有这个回调函数,会出现缩小的时候有瞬间被放大过程的bug // 当两根手指放上去的时候,就将distance 初始化。 let xMove = e.touches[1].clientX - e.touches[0].clientX; let yMove = e.touches[1].clientY - e.touches[0].clientY; let distance = Math.sqrt(xMove * xMove + yMove * yMove); this.setData({ 'touch.distance': distance, }) }, touchmoveCallback: function(e) { let touch = this.data.touch // 单手指缩放我们不做任何操作 if(e.touches.length == 1) return console.log('双手指运动') let xMove = e.touches[1].clientX - e.touches[0].clientX; let yMove = e.touches[1].clientY - e.touches[0].clientY; // 新的 ditance let distance = Math.sqrt(xMove * xMove + yMove * yMove); let distanceDiff = distance - touch.distance; let newScale = touch.scale + 0.005 * distanceDiff // 为了防止缩放得太大,所以scale需要限制,同理最小值也是 if(newScale >= 2) { newScale = 2 } if(newScale <= 0.6) { newScale = 0.6 } let scaleWidth = newScale * touch.baseWidth let scaleHeight = newScale * touch.baseHeight // 赋值 新的 => 旧的 this.setData({ 'touch.distance': distance, 'touch.scale': newScale, 'touch.scaleWidth': scaleWidth, 'touch.scaleHeight': scaleHeight, 'touch.diff': distanceDiff }) }, bindload: function(e) { // bindload 这个api是组件的api类似的onload属性 this.setData({ 'touch.baseWidth': e.detail.width, 'touch.baseHeight': e.detail.height, 'touch.scaleWidth': e.detail.width, 'touch.scaleHeight': e.detail.height }) }})
wxml文件对应如下,就不做解释了:
<view class="container"> <view bindtouchmove="touchmoveCallback" bindtouchstart="touchstartCallback"> <image src="../../resources/pic/cat.jpg" style="width: {{ touch.scaleWidth }}px;height: {{ touch.scaleHeight }}px" bindload="bindload">image> view> view>
以上就是关于"如何用js实现手指缩放图片功能"这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注行业资讯频道。
图片
手指
内容
功能
双手
就是
文章
时候
知识
篇文章
需求
最小
流畅
代码
价值
公众
函数
大部分
属性
手机
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
单位网络安全保密责任书
湖北交友软件开发哪家好
倩女服务器一览表
河北省软件开发费用测算
能入职京东软件开发岗算优秀吗
福建高职网络技术
出境游软件开发机构
好用的域名服务器
如何通过仿真获得数据库
网络安全知识右下角
南京学习网络技术
保护网络安全教案
什么服务器不能用
闵行区库存网络技术批发价
浙江农信服务器请求异常
在服务器怎么屏蔽一个人
专科软件开发要学高数吗
管理员怎么登陆电脑服务器
成立软件开发公司财务预算
xp系统与激活服务器连接失败
软件开发项目中的阀值
网络安全泄密快板
第一届检察院网络安全竞赛
电脑方舟mod服务器推荐
网络安全优秀人才评选
信息技术数据库应用总结
海关统计数据库
浙江飞猪网络技术有限公司法人
龙岗软件开发哪家效益快
关于防范网络安全的总结