亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

前端實現彈幕效果的方法總結(包含css3和canvas的實現方式)

2024-08-26 00:20:50
字體:
來源:轉載
供稿:網友

之前在一個移動端的抽獎頁面中,在抽獎結果的展示窗口需要彈幕輪播顯示,之前踩過一些小坑,現在總結一下前端彈幕效果的實現方式。

  • css3實現乞丐版的彈幕
  • css3彈幕性能優化
  • canvas實現彈幕
  • canva彈幕的擴展功能

1. css3實現乞丐版的彈幕

(1)如何通過css3實現彈幕

首先來看如何通過css的方法實現一個最簡單的彈幕:

首先在html中定義一條彈幕的dom結構:

<div class="block">我是彈幕</div>

彈幕的移動可以通過移動這個block來實現,以從右向左移動的彈幕為例,彈幕的初始位置在容器的最左側且貼邊隱藏(彈幕的最左邊與容器的最右貼合),可以通過絕對定位加transform來實現:

.block{   position:absolute;}

初始位置:

from{    left:100%;    transform:translateX(0)}

移動到最左邊的結束位置為(彈幕的最右邊與容器的最左邊貼合):

to{   left:0;   transform:translateX(-100%)}

起始位置和結束位置的具體圖示如下所示:

 

 
前端,彈幕,css3,canvas

 

根據起始位置和結束位置可以定義完整的兩幀彈幕動畫:

@keyframes barrage{   from{     left:100%;     transform:translateX(0);   }   to{     left:0;     transform:translateX(-100%);   }}

給彈幕元素引入這個動畫:

.block{  position:absolute;  /* other decorate style */  animation:barrage 5s linear 0s;}

這樣就可以實現一個乞丐版的彈幕效果:

 

 
前端,彈幕,css3,canvas 

 

(2)通過絕對定位和left實現彈幕的缺陷

首先明確一下css的渲染過程

I)根據HTML的結構生成DOM樹(DOM樹中包含了display:none的節點) II)在DOM樹的基礎上,根據節點的幾何屬性(margin/padding/width/height/left等)生成render樹 III)在render樹的基礎上繼續渲染color,font等屬性

其中如果I)中和II)中的屬性發生變化會發生reflow(回流),如果僅僅III)中的屬性發生改變,只會發生repaint(重繪)。顯然從css的渲染過程我們也可以看出來:reflow(回流)必伴隨著重繪。

reflow(回流):當render樹中的一部分或者全部因為大小邊距等問題發生改變而需要重建的過程叫做回流 repaint(重繪):當元素的一部分屬性發生變化,如外觀背景色不會引起布局變化而需要重新渲染的過程叫做重繪

reflow(回流)會影響瀏覽器css的渲染速度,因此在做網頁性能優化的時候要減少回流的發生。

在第一節,我們通過left屬性,實現了彈幕的效果,left會改變元素的布局,因此會發生reflow(回流),表現在移動端頁面上會造成彈幕動畫的卡頓。

2. css3彈幕性能優化

我們直到了第一節中的彈幕動畫存在卡頓的問題,下面我們看看如何解決動畫的卡頓。

(1)CSS開啟硬件加速

在瀏覽器中用css開啟硬件加速,使用GPU(Graphics Processing Unit)可以提升網頁性能。鑒于此,我們可以發揮GPU的力量,從而使我們的網站或應用表現的更為流暢。

CSS animations, transforms 以及 transitions 不會自動開啟GPU加速,而是由瀏覽器的緩慢的軟件渲染引擎來執行。那我們怎樣才可以切換到GPU模式呢,很多瀏覽器提供了某些觸發的CSS規則。

比較常見的方式是,我們可以通過3d變化(translate3d屬性)來開啟硬件加速,鑒于此,我們修改動畫為:

@keyframes barrage{   from{     left:100%;     transform:translate3d(0,0,0);   }   to{     left:0;     transform:translate3d(-100%,0,0);   }}

這樣就可以通過開啟硬件加速的方式,優化網頁性能。但是這種方式沒有從根本上解決問題,同時使用GPU增加了內存的使用,會減少移動設備的電池壽命等等。

(2)不改變left屬性

第二種方法,就是想辦法在彈幕動畫的前后不改變left屬性的值,這樣就不會發生reflow。

我們想僅僅通過translateX來確定彈幕節點的初始位置,但是translateX(-100%)是相對于彈幕節點本身的,而不是相對于父元素,因此我們耦合js和css,在js中獲取彈幕節點所在的父元素的寬度,接著根據寬度來定義彈幕節點的初始位置。

以父元素為body時為例:

//css .block{  position:absolute;  left:0;  visibility:hidden;  /* other decorate style */  animation:barrage 5s linear 0s;}//jslet style = document.createElement('style');document.head.appendChild(style);let width = window.innerWidth;let from = `from { visibility: visible; -webkit-transform: translateX(${width}px); }`;let to = `to { visibility: visible; -webkit-transform: translateX(-100%); }`;style.sheet.insertRule(`@-webkit-keyframes barrage { ${from} ${to} }`, 0);

除了耦合js計算了父元素的寬度,從而確定彈幕節點的初始位置之外,這里在彈幕節點中我們為了防止初始位置就有顯示,增加了visibility:hidden屬性。防止彈幕節點在未確定初始位置時就顯示在父容器內。只有彈幕開始從初始位置滾動,才會變得可見。

但是這種css的實現方式,在實現彈幕的擴展功能方面比較麻煩,比如如何控制彈幕暫停等等。

3. canvas實現彈幕

除了通過css實現彈幕的方法之外,通過canvas也可以實現彈幕。

通過canvas實現彈幕的原理就是時時的重繪文字,下面來一步步的實現。

獲取畫布

let canvas = document.getElementById('canvas');    let ctx = canvas.getContext('2d');

繪制文字

ctx.font = '20px Microsoft YaHei';              ctx.fillStyle = '#000000';                    ctx.fillText('canvas 繪制文字', x, y);

上面的fillText就是實現彈幕效果的主要api,其中x表示橫方向的坐標,y表示縱方向的坐標,只要時時的改變x,y進行重繪,就可以實現動態的彈幕效果。復制代碼

清除繪制內容

ctx.clearRect(0, 0, width, height);

具體實現

通過定時器,定時改變x,y,每次改變之前先進性清屏,然后根據改變后的x,y進行重繪。當存在多條彈幕的情況下,定義:

let colorArr=_this.getColor(color);  彈幕數組多對應的顏色數組    let numArrL=_this.getLeft();  彈幕數組所對應的x坐標位置數組    let numArrT=_this.getTop();  彈幕數組所對應的y坐標位置數組    let speedArr=_this.getSpeed(); 彈幕數組所對應的彈幕移動速度數組

定時的重繪彈幕函數為:

_this.timer=setInterval(function(){    ctx.clearRect(0,0,canvas.width,canvas.height);    ctx.save();    for(let j=0;j<barrageList.length;j++){      numArrL[j]-=speedArr[j];      ctx.fillStyle = colorArr[j]      ctx.fillText(barrageList[j],numArrL[j],numArrT[j]);      ctx.restore(); },16.7);

實現的效果為:

 

 
前端,彈幕,css3,canvas 

 

4. canva彈幕的擴展功能

通過canvas實現彈幕的方式,很方便做比如暫停彈幕滾動等擴展功能,此外,也可以給彈幕增加頭像,給每條彈幕增加邊框等等功能,以后再補充。

最后給一個簡單的react彈幕組件;https://github.com/forthealllight/react-barrage

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品黄色影片导航在线观看| 国产精品三级在线| 欧美激情中文字幕乱码免费| 精品性高朝久久久久久久| 亚洲天堂精品在线| 久久久久久久亚洲精品| 日韩精品视频免费在线观看| 97国产精品久久| 粗暴蹂躏中文一区二区三区| 国产精品高潮呻吟久久av黑人| 国产精品天天狠天天看| 日韩中文字幕国产精品| 成人久久一区二区| 亚洲va国产va天堂va久久| 国产视频在线观看一区二区| 伊人伊人伊人久久| 久久精品成人欧美大片古装| 久久亚洲成人精品| 九九热最新视频//这里只有精品| 精品国产一区二区三区四区在线观看| 亚洲欧美日韩高清| 日韩网站在线观看| 久久久国产一区二区| 97视频com| 亚洲精品免费在线视频| 久久福利网址导航| 日韩中文字幕视频| 精品国产乱码久久久久酒店| 色悠悠久久88| 国内揄拍国内精品| 最近免费中文字幕视频2019| 国产裸体写真av一区二区| 日韩小视频在线观看| 欧美最顶级的aⅴ艳星| 美女av一区二区三区| 欧美日韩一区二区在线| 国产精品视频网| 国产精品白嫩美女在线观看| 国产精品久久久久免费a∨大胸| 亚洲天堂免费视频| 久久久久久久激情视频| 国产精品男女猛烈高潮激情| 国产亚洲欧洲在线| 欧美视频在线观看免费| 91精品久久久久久久久| 日韩美女视频免费看| 日韩免费在线观看视频| 成人激情在线播放| 欧美一级电影在线| 91黑丝高跟在线| 国产午夜精品视频| 91高潮精品免费porn| 亚洲自拍另类欧美丝袜| 黑人巨大精品欧美一区二区免费| 国产精品99久久久久久人| 亚洲无限乱码一二三四麻| 国产精品永久在线| 国产一区二区三区在线看| 国产成人av网| 国产日韩欧美另类| 国产成人91久久精品| 福利精品视频在线| 国产成人精品a视频一区www| 91理论片午午论夜理片久久| 国产精品偷伦一区二区| 亚洲国产日韩精品在线| 国产999精品| 69久久夜色精品国产69乱青草| 1769国内精品视频在线播放| 国产亚洲精品综合一区91| 国产欧美日韩专区发布| 日韩人体视频一二区| 97香蕉久久夜色精品国产| 中文字幕欧美专区| 精品中文字幕在线观看| 亚洲天堂av网| 国产欧美最新羞羞视频在线观看| 欧美日韩中文在线观看| 国产精品电影网站| 欧美午夜影院在线视频| 91精品国产高清久久久久久久久| 九九热这里只有精品免费看| 久久久国产一区二区| 亚洲综合第一页| 在线观看久久久久久| 中文字幕国产亚洲2019| 久久婷婷国产麻豆91天堂| 欧美中文在线字幕| 久久精品中文字幕| 国产精品mp4| 亚洲va电影大全| 亚洲综合中文字幕在线| 精品动漫一区二区三区| 欧美综合第一页| 欧美一区三区三区高中清蜜桃| 黑人狂躁日本妞一区二区三区| 欧美激情奇米色| 国产91精品久久久久| 国产精品免费电影| 少妇精69xxtheporn| 亚洲美女av在线| 国产免费一区二区三区香蕉精| 日韩av高清不卡| 日本伊人精品一区二区三区介绍| 亚洲国产91色在线| 欧美激情综合色| 精品中文字幕在线| 欧美亚洲日本黄色| 91在线观看免费网站| 国产精品亚洲美女av网站| 久久综合免费视频影院| 久久免费精品日本久久中文字幕| 日韩精品在线观看一区二区| 国产亚洲一级高清| 97成人精品区在线播放| 日韩av在线直播| 欧美多人乱p欧美4p久久| 欧美—级a级欧美特级ar全黄| 亚洲成人网久久久| 欧美亚洲国产日本| 久久影视电视剧免费网站清宫辞电视| 日韩欧美在线视频| 国产精品三级在线| 欧美成人h版在线观看| 欧美在线免费观看| 久久网福利资源网站| 岛国av午夜精品| 国产主播欧美精品| 不卡av电影在线观看| 不卡av日日日| 91免费国产视频| 国产精品久久久久久久天堂| 欧美性开放视频| 国产精品白嫩初高中害羞小美女| 亚洲欧洲一区二区三区久久| 成人午夜在线视频一区| 麻豆精品精华液| 91av在线国产| 中文字幕亚洲一区| 久久综合国产精品台湾中文娱乐网| 日韩在线免费观看视频| 欧美激情精品在线| 国产精品精品视频| 91精品久久久久久| 欧美成人免费播放| 欧美一区二区三区免费视| 国产又爽又黄的激情精品视频| 97超视频免费观看| 日本成人黄色片| 国产视频精品免费播放| 国产精品视频区1| 亚洲国产欧美在线成人app| 搡老女人一区二区三区视频tv| 欧美黑人巨大xxx极品| 亚洲一区美女视频在线观看免费| 国产精品久久久999| 国产精品美女www爽爽爽视频| 色婷婷综合成人| 国产69久久精品成人看| 久久亚洲精品毛片| 久久伊人免费视频| 国产精品国模在线| 亚洲国产欧美自拍| 日韩欧美第一页|