這篇文章主要介紹了微信小程序實現通過雙向滑動縮放圖片大小的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

本文實例講述了微信小程序實現通過雙向滑動縮放圖片大小的方法。分享給大家供大家參考,具體如下:
在做小程序開發的過程中,后端傳來一張圖片地圖,需要實現雙手指滑動,使圖片縮放,最終得出了一下代碼:
js :
Page({
data: {
touch: {
distance: 0,
scale: 1,
baseWidth: null,
baseHeight: null,
scaleWidth: null,
scaleHeight: null
}
},
touchStartHandle(e) {
// 單手指縮放開始,也不做任何處理
if (e.touches.length == 1) {
console.log("單滑了")
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,
})
},
touchMoveHandle(e) {
let touch = this.data.touch
// 單手指縮放我們不做任何操作
if (e.touches.length == 1) {
console.log("單滑了");
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
})
},
load: function (e) {
// bindload 這個api是<image>組件的api類似<img>的onload屬性
this.setData({
'touch.baseWidth': e.detail.width,
'touch.baseHeight': e.detail.height,
'touch.scaleWidth': e.detail.width,
'touch.scaleHeight': e.detail.height
});
}
})然后將新獲得的圖片寬度和高度賦值給圖片即可實現滑動縮放
wxml:
<image mode='scaleToFill' src='../../../images/01.jpg'
bindtouchstart='touchStartHandle'
bindtouchmove='touchMoveHandle'
bindload='load'
style="width: {{ touch.scaleWidth }}px;
height: {{ touch.scaleHeight }}px"></image>最后,通過手機預覽,就會發現已達到預想的效果!
感謝你能夠認真閱讀完這篇文章,希望小編分享的“微信小程序實現通過雙向滑動縮放圖片大小的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持創新互聯成都網站設計公司,關注創新互聯成都網站設計公司行業資訊頻道,更多相關知識等著你來學習!
另外有需要云服務器可以了解下創新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
網站名稱:微信小程序實現通過雙向滑動縮放圖片大小的示例分析-創新互聯
網站地址:http://www.yijiale78.com/article36/cspipg.html
成都網站建設公司_創新互聯,為您提供網站制作、云服務器、自適應網站、微信小程序、網站設計公司、標簽優化
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯