[觀點]微信小程序組件默認樣式優(yōu)先級bug解析

在小程序中声诸,image 組件的 mode 有 12 種款咖,其中只有三種是縮放模式。而在這三種之中唤衫,只有 aspectFit 模式可以等比例縮放圖片婆赠,并顯示完整的圖片。此模式是保證圖片長邊完整地顯示出來,而手機屏幕寬度都較小休里,以 iphone 6 為例蛆挫,僅有 375 px。因此在小程序中瀏覽橫向的圖片或尺寸較大的圖片時妙黍,圖片細節(jié)就難以查看清楚(如下圖)悴侵。



因此能動態(tài)的通過手勢縮放圖片,就很有必要拭嫁。大眾比較熟悉的手勢是類似 app 中的雙指縮放可免,我們的目標也是在小程序中實現(xiàn)此效果。
愛范兒工程師在仔細研究微信小程序的所有事件后發(fā)現(xiàn)做粤,可以通過 touchmove 事件來實現(xiàn)雙指縮放圖片浇借。此技術(shù)的核心思想是根據(jù)兩只手指相對距離的變化來對圖片進行放大或縮小。因此只要能知道兩只手指相對距離的變化怕品,并能做到對圖片的動態(tài)縮放妇垢,就能實現(xiàn)我們想要的功能。
在手指接觸到屏幕并開始移動后肉康,對應(yīng)的組件上就會以約為 16ms(屏幕渲染頻率) 一次的速度不斷觸發(fā) touchmove
事件闯估,最后手指離開屏幕后,則會觸發(fā) touchend
事件迎罗。
touchmove
事件所包含的事件對象中有一個 touches
屬性睬愤,此屬性為當前停留在屏幕中的觸摸點信息的數(shù)組片仿。觸摸點的信息包括identifier
(觸摸點的標志符)纹安、pageX / pageY
(距離文檔左上角的距離)、clientX / clientY
(距離屏幕可顯示區(qū)域左上角距離)砂豌。通過 clientX / clientY
可確定手指在屏幕上的位置厢岂。
xMove = e.touches[1].clientX - e.touches[0].clientX;yMove = e.touches[1].clientY - e.touches[0].clientY;distance = Math.sqrt(xMove * xMove + yMove * yMove);

distance
即為兩只手指之間的距離。將此距離儲存下來阳距,下一次 touchmove
被觸發(fā)的時候塔粒,再計算一次 distance
。distanceDiff(newDistance - oldDistance)
即為兩次 touchmove 觸發(fā)的間隔間兩個手指相對距離的變化值筐摘。此值為正數(shù)時卒茬,表示兩指間距離在變大,即需要放大圖片咖熟,反之則為需要縮小圖片圃酵。
下面則需要確定一個規(guī)則,將 distance
的變化值與圖片放大或縮小的變化率關(guān)聯(lián)起來馍管。我們將圖片正常顯示時的尺寸定為基準值郭赐,即 baseWidth 和 baseHeight,圖片需要放大的倍數(shù)為 scale确沸,scale 的初始值和最小值為 1捌锭,最大值可根據(jù)需要來設(shè)置俘陷。
愛范兒工程師經(jīng)過多次試驗,確定了一個公式:
newScale = oldScale + 0.005 * distanceDiff

此公式中的 0.005 為圖片的縮放比例观谦。在實測中拉盾,使用 0.005 這個值可獲得比較良好的縮放體驗。
通過上面的步驟豁状,圖片上綁定 touchmove
事件后盾剩,每次 touchmove
被觸發(fā)后,我們都可以計算出新的圖片需要被放大的倍數(shù) scale替蔬。即每次 touchmove
被觸發(fā)后告私,都可以得到一組圖片被放大后的高寬值:scaleWidth(scale * baseWidth)、scaleHeight(scale * baseHeight)
承桥。
通過下面的方式就可以實現(xiàn)動態(tài)的更改圖片的高寬
<image class="image" style="width:{{ scaleWidth }}px; height:{{ scaleHeight }}px">


實現(xiàn)了圖片的縮放之后驻粟,還需要一個容器存放圖片,用 view
組件包裹 image
凶异,并設(shè)置 overflow:scroll
蜀撑,即可以做到自由的縮放和瀏覽圖片。但是微信小程序中有一個更合適的組件:scroll-view
剩彬,設(shè)置 scroll-x
和 scroll-y
為 true
酷麦,在放大圖片后,滑動瀏覽圖片時擁有比較良好的瀏覽體驗喉恋。
但是沃饶,目前版本(0.10.102800)中的 scroll-view
組件還存在一個渲染上的 bug,偶爾會出現(xiàn)界面閃動的現(xiàn)象轻黑。而在雙指縮放存在于scroll-view
中的圖片糊肤,極易觸發(fā)此 bug。此問題氓鄙,暫時只能等待微信進行修復馆揉,或者放棄 scroll-view
,即放棄更好的滑動瀏覽效果抖拦,而使用 view 組件升酣。

Hello小程序將與您共同成長。微信號:130870319 QQ群:40726600

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末态罪,一起剝皮案震驚了整個濱河市噩茄,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌向臀,老刑警劉巖巢墅,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡君纫,警方通過查閱死者的電腦和手機驯遇,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來蓄髓,“玉大人叉庐,你說我怎么就攤上這事』岷龋” “怎么了陡叠?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長肢执。 經(jīng)常有香客問我枉阵,道長,這世上最難降的妖魔是什么预茄? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任兴溜,我火速辦了婚禮,結(jié)果婚禮上耻陕,老公的妹妹穿的比我還像新娘拙徽。我一直安慰自己,他們只是感情好诗宣,可當我...
    茶點故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布膘怕。 她就那樣靜靜地躺著,像睡著了一般召庞。 火紅的嫁衣襯著肌膚如雪岛心。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天裁眯,我揣著相機與錄音鹉梨,去河邊找鬼讳癌。 笑死穿稳,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的晌坤。 我是一名探鬼主播逢艘,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼骤菠!你這毒婦竟也來了它改?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤商乎,失蹤者是張志新(化名)和其女友劉穎央拖,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡鲜戒,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年专控,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片遏餐。...
    茶點故事閱讀 39,690評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡伦腐,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出失都,到底是詐尸還是另有隱情柏蘑,我是刑警寧澤,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布粹庞,位于F島的核電站咳焚,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏庞溜。R本人自食惡果不足惜黔攒,卻給世界環(huán)境...
    茶點故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望强缘。 院中可真熱鬧督惰,春花似錦、人聲如沸旅掂。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽商虐。三九已至觉阅,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間秘车,已是汗流浹背典勇。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留叮趴,地道東北人割笙。 一個月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像眯亦,于是被迫代替她去往敵國和親伤溉。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,577評論 2 353

推薦閱讀更多精彩內(nèi)容