小程序?qū)崿F(xiàn)圖片移動縮放效果
本文實例為大家分享了小程序?qū)崿F(xiàn)圖片移動縮放效果的具體代碼,供大家參考,具體內(nèi)容如下
git地址 , 如果對您有幫助給個start唄
嘗試了movable-view標(biāo)簽是很方便, 但是我想有個拉伸按鈕去縮放圖片, 于是嘗試自己寫了.
思想利用catchtouchmove屬性計算偏移量, 實時更新坐標(biāo)

以下是完整代碼
js
/**
* All right by NieYinlong
*/
Page({
/**
* 頁面的初始數(shù)據(jù)
*/
data: {
bgBoxHeight: 400, // 背景的高度
bgBoxWidth: 320, // 背景的寬度
moveImgLeft: 40,
moveImgTop: 80,
moveImgH: 100,
moveImgW: 100,
scaleIconFixWidth: 30,
scaleLeft: 0, // 拉伸按鈕默認(rèn)x坐標(biāo) (拉伸按鈕默認(rèn)寬高30)
scaleTop: 0, // 拉伸按鈕默認(rèn)y坐標(biāo)
},
/**
* 生命周期函數(shù)--監(jiān)聽頁面加載
*/
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) {
// 寬度達(dá)到最大值
return;
}
if (pageY - this.data.moveImgTop > 250) {
// 高度達(dá)到最大值
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;
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
微信小程序?qū)崿F(xiàn)根據(jù)字母選擇城市功能
這篇文章主要為大家詳細(xì)介紹了微信小程序中根據(jù)字母選擇城市的相關(guān)方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-08-08
JavaScript正則表達(dá)式和級聯(lián)效果
正則表達(dá)式(regular expression)是一種字符串匹配的模式,用來檢查一個字符串中是否包含指定模式的字符串。下面通過本文給大家分享JavaScript_正則表達(dá)式和級聯(lián)效果,感興趣的朋友一起看看吧2017-09-09
JavaScript解決浮點(diǎn)數(shù)計算不準(zhǔn)確問題的方法分析
這篇文章主要介紹了JavaScript解決浮點(diǎn)數(shù)計算不準(zhǔn)確問題的方法,結(jié)合實例形式分析了javascript浮點(diǎn)數(shù)運(yùn)算精度誤差的原因以及相關(guān)的解決方法與具體操作技巧,需要的朋友可以參考下2018-07-07
微信小程序云開發(fā)如何實現(xiàn)數(shù)據(jù)庫自動備份實現(xiàn)
這篇文章主要介紹了小程序云開發(fā) 數(shù)據(jù)庫自動備份實現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-08-08
用JavaScript實現(xiàn)PHP的urlencode與urldecode函數(shù)
這篇文章主要介紹了用JavaScript實現(xiàn)PHP的urlencode與urldecode函數(shù),很多情況下我們用了出來php urlencode出來的網(wǎng)址,需要的朋友可以參考下2015-08-08

