最近在項目中需要加一個功能,在小程序中將已有的短視頻功能,按照抖音的方式來瀏覽,整屏,可上下滑動切換視頻,并添加上滑下滑的動畫。
1.在video標(biāo)簽上添加時間監(jiān)聽。 2.如果1無法成功,就在video上面罩一層 cover-view,在cover-view上添加時間監(jiān)聽。 3.如果上面兩種方法都不行,用小程序的onPageScroll頁面處理函數(shù)來監(jiān)聽頁面的滾動。 4.上述三種方法都不行的話,用canvas在video上面罩一層,監(jiān)聽滾動事件。
現(xiàn)在video標(biāo)簽上添加了觸摸事件的監(jiān)聽,但是無法成功監(jiān)聽到觸摸事件。 因為video 是原生組件,層級較高,所以嘗試在上面罩一層cover-view,并監(jiān)聽滾動事件,但是同樣無法監(jiān)聽。
前面兩種方法不行,我就采用了onPageScroll來監(jiān)聽頁面是否發(fā)生滾動。這個方法會拿到當(dāng)前頁面在垂直方向已滾動的距離。scrollindex用來控制滾動,totalNum是滾動的總數(shù),部分代碼如下
在ios上可以滿足需求,能上下滾動,也能加上動畫,但是在安卓上卻不能動,嘗試著在頁面json文件中配置滾動相關(guān),但都沒辦法,所以這個方法也不行了。
最后只有canvas這一個辦法了,在video組件上面定位一個canvas,在上面添加時間監(jiān)聽,這是發(fā)現(xiàn)成功了,可以在控制臺看到打印出來的監(jiān)聽 console。
wxml:下面是wxml代碼,主要思路就是讓video寬高等于屏幕,點贊評論分享等功能,用cover-view定位到視頻上方,在將canvas定位到video上面滾動時滾動的是封面圖案,video標(biāo)簽只有一個,滾動更改video的src。
wxss:都是一些定位相關(guān)的樣式?jīng)]有特殊的樣式就不貼圖了。不過做的時候這里有個坑,產(chǎn)品希望添加無限的向下滑動視頻,可以無限加載,所以最開始我才用的是animation動畫,對每一屏根據(jù)手指向上或者向下添加動畫,這樣做的話就無法做到,后來發(fā)現(xiàn)可以使用小程序的api,wx.createAnimation()在js中實現(xiàn)。
js:onload的時候this.animation = wx.createAnimation();用于切換時創(chuàng)建動畫。
需要監(jiān)聽的滾動事件
js主要做的是判斷滾動方向,給wxml通過微信提供的animation方法來動態(tài)添加動畫,這樣就可以實現(xiàn)無限加載的需求了。scrollTop的作用是用來調(diào)整video標(biāo)簽位置,因為現(xiàn)在滾動的時候添加滾動的事視頻的封面圖不是視頻本身,需要隱藏視頻,假如用wx:if;哎控制的話,會導(dǎo)致視頻隱藏在展現(xiàn)之后無法監(jiān)聽之前添加的事件。
在真機上可以生效,在手機上錄了視頻不知道怎么傳上來,轉(zhuǎn)gif也沒找到在mac怎么轉(zhuǎn)。。。
弄了好久弄出來的,真機和模擬器的效果差異很大,最好在真機測試。目前也不知道有沒有更好的辦法,菜鳥前端一個~
工作日 8:30-12:00 14:30-18:00
周六及部分節(jié)假日提供值班服務(wù)