本文实例为大家分享了小程序实现图片移动缩放效果的具体代码,供大家参考,具体内容如下
git地址 , 如果对您有帮助给个start呗
尝试了movable-view标签是很方便, 但是我想有个拉伸按钮去缩放图片, 于是尝试自己写了.
思想利用catchtouchmove属性计算偏移量, 实时更新坐标
以下是完整代码
js
/** * All right by NieYinlong */ Page({ /** * 页面的初始数据 */ data: { bgBoxHeight: 400, // 背景的高度 bgBoxWidth: 320, // 背景的宽度 moveImgLeft: 40, moveImgTop: 80, moveImgH: 100, moveImgW: 100, scaleIconFixWidth: 30, scaleLeft: 0, // 拉伸按钮默认x坐标 (拉伸按钮默认宽高30) scaleTop: 0, // 拉伸按钮默认y坐标 }, /** * 生命周期函数--监听页面加载 */ onLoad: function (options) { const halfWidth = this.data.scaleIconFixWidth / 2 this.setData({ scaleLeft: this.data.moveImgLeft + this.data.moveImgW - halfWidth, scaleTop: this.data.moveImgTop + this.data.moveImgH - halfWidth }) }, // 图片移动 moveImgTouchmove: function(e) { console.log(e) let pageX = e.changedTouches[0].pageX let pageY = e.changedTouches[0].pageY // (this.data.moveImgW / 2)是因为触摸放到中间位置 let toLeft = pageX - this.data.moveImgW / 2; let toTop = pageY - this.data.moveImgH / 2; const halfWidth = this.data.scaleIconFixWidth / 2 // 限制x左边不能出边框 if (pageX - (this.data.moveImgW / 2) <= 0) { return; } // 限制右边不能出超过边框 if ((pageX + (this.data.moveImgW / 2)) >= (this.data.bgBoxWidth)) { return; } // 限制top if (pageY - (this.data.moveImgH / 2) <= 1) { return; } // 限制bottom if ((pageY + (this.data.moveImgH / 2)) >= this.data.bgBoxHeight) { return; } this.setData({ moveImgLeft: toLeft, moveImgTop: toTop, scaleLeft: toLeft + this.data.moveImgW - halfWidth, scaleTop: toTop + this.data.moveImgH - halfWidth }) }, // 拉伸按钮移动 scaleTouchmove: function (e) { console.log(e) let pageX = e.changedTouches[0].pageX let pageY = e.changedTouches[0].pageY const halfWidth = this.data.scaleIconFixWidth / 2 let toLeft = pageX - halfWidth // 减去halfWidth是拉伸按钮宽度的一半 let toTop = pageY - halfWidth let changedW = pageX - this.data.moveImgLeft let changedH = pageY - this.data.moveImgTop // 限制最moveImg小尺寸 if (toLeft <= (this.data.moveImgLeft + halfWidth)) { return; } if (toTop <= (this.data.moveImgTop + halfWidth)) { return; } // 限制moveImg最大尺寸 if(pageX - this.data.moveImgLeft > 250) { // 宽度达到最大值 return; } if (pageY - this.data.moveImgTop > 250) { // 高度达到最大值 return; } // 限制拉伸按钮的right if(this.data.scaleLeft + this.data.scaleIconFixWidth >= this.data.bgBoxWidth) { return; } // 限制拉伸按钮的bottom if (this.data.scaleTop + this.data.scaleIconFixWidth >= this.data.bgBoxHeight) { return; } this.setData({ scaleLeft: toLeft, scaleTop: toTop, moveImgW: pageX - this.data.moveImgLeft, moveImgH: pageY - this.data.moveImgTop, }) }, })
wxml
<view class='bgBox' style="height:{{bgBoxHeight}}px; width:{{bgBoxWidth}}px" > <image class='movedImg' src='../../image/moveImg.png' catchtouchmove='moveImgTouchmove' style="width:{{moveImgW}}px;height:{{moveImgH}}px; left:{{moveImgLeft}}px;top:{{moveImgTop}}px" /> <image src='../../image/spreadIcon.png' class='scaleIcon' catchtouchmove='scaleTouchmove' style="width:{{scaleIconFixWidth}}px;height:{{scaleIconFixWidth}}px; left:{{scaleLeft}}px; top:{{scaleTop}}px" /> </view>
wxss
.bgBox { border: 2px solid green; height: 400px; width: 99vw; } .movedImg { position: absolute; border: 3px dotted rgb(255, 166, 0); } .scaleIcon { position: absolute; }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月16日
2024年11月16日
- 陈思安.1990-国语钢琴酒吧5CD【欣代唱片】【WAV+CUE】
- 莫文蔚《莫后年代20周年世纪典藏》3CD[WAV+CUE][2G]
- 张惠妹《我要快乐》华纳[WAV+CUE][1G]
- 罗大佑1982《之乎者也》无法盗版的青春套装版 [WAV+CUE][1G]
- 曾庆瑜1989-款款柔情[日本东芝版][WAV+CUE]
- Scelsi-IntegraledesquatuorsacordesetTrioacordes-QuatuorMolinari(2024)[24bit-WAV]
- 房东的猫2017-房东的猫[科文音像][WAV+CUE]
- 杨乃文.2016-离心力(引进版)【亚神音乐】【WAV+CUE】
- 群星.2024-珠帘玉幕影视原声带【TME】【FLAC分轨】
- 芝麻龙眼.2008-光阴隧道民歌记录3CD【乡城】【WAV+CUE】
- 谭艳《再度重相逢HQII》头版限量[低速原抓WAV+CUE][549M]
- ABC唱片《蔡琴三十周年纪念版》6N纯银镀膜 [WAV+CUE][1.1G]
- 海来阿木《西楼情歌》开盘母带[WAV+CUE][1.1G]
- TheGesualdoSix-QueenofHeartsLamentsandSongsofRegretforQueensTerrestrialandCele
- 王建杰2011-荣华富贵[喜玛拉雅][WAV+CUE]