小程序?qū)崿F(xiàn)圖片移動(dòng)縮放效果
本文實(shí)例為大家分享了小程序?qū)崿F(xiàn)圖片移動(dòng)縮放效果的具體代碼,供大家參考,具體內(nèi)容如下
git地址 , 如果對(duì)您有幫助給個(gè)start唄
嘗試了movable-view標(biāo)簽是很方便, 但是我想有個(gè)拉伸按鈕去縮放圖片, 于是嘗試自己寫(xiě)了.
思想利用catchtouchmove屬性計(jì)算偏移量, 實(shí)時(shí)更新坐標(biāo)
以下是完整代碼
js
/** * All right by NieYinlong */ Page({ /** * 頁(yè)面的初始數(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)聽(tīng)頁(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 }) }, // 圖片移動(dòng) moveImgTouchmove: function(e) { console.log(e) let pageX = e.changedTouches[0].pageX let pageY = e.changedTouches[0].pageY // (this.data.moveImgW / 2)是因?yàn)橛|摸放到中間位置 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; } // 限制右邊不能出超過(guò)邊框 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 }) }, // 拉伸按鈕移動(dòng) 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; }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
微信小程序?qū)崿F(xiàn)根據(jù)字母選擇城市功能
這篇文章主要為大家詳細(xì)介紹了微信小程序中根據(jù)字母選擇城市的相關(guān)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08JavaScript正則表達(dá)式和級(jí)聯(lián)效果
正則表達(dá)式(regular expression)是一種字符串匹配的模式,用來(lái)檢查一個(gè)字符串中是否包含指定模式的字符串。下面通過(guò)本文給大家分享JavaScript_正則表達(dá)式和級(jí)聯(lián)效果,感興趣的朋友一起看看吧2017-09-09JavaScript解決浮點(diǎn)數(shù)計(jì)算不準(zhǔn)確問(wèn)題的方法分析
這篇文章主要介紹了JavaScript解決浮點(diǎn)數(shù)計(jì)算不準(zhǔn)確問(wèn)題的方法,結(jié)合實(shí)例形式分析了javascript浮點(diǎn)數(shù)運(yùn)算精度誤差的原因以及相關(guān)的解決方法與具體操作技巧,需要的朋友可以參考下2018-07-07微信小程序云開(kāi)發(fā)如何實(shí)現(xiàn)數(shù)據(jù)庫(kù)自動(dòng)備份實(shí)現(xiàn)
這篇文章主要介紹了小程序云開(kāi)發(fā) 數(shù)據(jù)庫(kù)自動(dòng)備份實(shí)現(xiàn)過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08JavaScript判斷密碼強(qiáng)度(自寫(xiě)代碼)
網(wǎng)站注冊(cè)的時(shí)候經(jīng)常可以看到密碼強(qiáng)度提示,今天自己做了一個(gè)JS密碼強(qiáng)度判斷,具體實(shí)現(xiàn)如下,喜歡的朋友可以學(xué)習(xí)下2013-09-09用JavaScript實(shí)現(xiàn)PHP的urlencode與urldecode函數(shù)
這篇文章主要介紹了用JavaScript實(shí)現(xiàn)PHP的urlencode與urldecode函數(shù),很多情況下我們用了出來(lái)php urlencode出來(lái)的網(wǎng)址,需要的朋友可以參考下2015-08-08JS實(shí)現(xiàn)點(diǎn)擊文本框改變背景顏色
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)點(diǎn)擊文本框改變背景顏色,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08