婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 前端實現彈幕效果的方法總結(包含css3和canvas的實現方式)

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

熱門標簽:鎮江智能外呼系統有效果嗎 成都智能外呼系統平臺 黃島區地圖標注 四川點撥外呼系統 江蘇智能電銷機器人哪家好 當涂高德地圖標注 南寧點撥外呼系統哪家公司做的好 云南大理400電話申請官方 電銷機器人電話用什么卡

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

  • 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%)
}

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

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

@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;
}

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

 

(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;
}
//js
let 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);

實現的效果為:

 

4. canva彈幕的擴展功能

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

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

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

標簽:十堰 酒泉 淮安 佳木斯 廣西 西寧 咸寧 南京

巨人網絡通訊聲明:本文標題《前端實現彈幕效果的方法總結(包含css3和canvas的實現方式)》,本文關鍵詞  前端,實現,彈幕,效果,的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《前端實現彈幕效果的方法總結(包含css3和canvas的實現方式)》相關的同類信息!
  • 本頁收集關于前端實現彈幕效果的方法總結(包含css3和canvas的實現方式)的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    免费在线观看一区二区三区| 水蜜桃久久夜色精品一区的特点| 91欧美一区二区| 午夜久久久久久| 欧美精彩视频一区二区三区| 欧美高清dvd| 成人精品高清在线| 免费成人av资源网| 亚洲综合色自拍一区| 国产亚洲精品bt天堂精选| 在线播放日韩导航| 北条麻妃国产九九精品视频| 美女mm1313爽爽久久久蜜臀| 亚洲九九爱视频| 久久精品欧美一区二区三区不卡| 欧美精品v日韩精品v韩国精品v| 成人精品在线视频观看| 老汉av免费一区二区三区| 一区二区三区美女视频| 久久精品国产99久久6| 亚洲美女电影在线| 中文字幕av在线一区二区三区| 欧美精品国产精品| 色偷偷88欧美精品久久久| 成人免费毛片片v| 卡一卡二国产精品| 日韩高清不卡一区二区三区| 一区二区三区在线免费播放| 国产精品麻豆一区二区| 久久久亚洲高清| 精品处破学生在线二十三| 在线观看91精品国产麻豆| 在线视频欧美精品| 91在线免费看| 99久久精品国产一区| 国产成人8x视频一区二区| 黄色日韩网站视频| 精品写真视频在线观看| 日韩av中文字幕一区二区 | 国产凹凸在线观看一区二区| 另类人妖一区二区av| 蜜臀a∨国产成人精品| 日韩av成人高清| 三级久久三级久久久| 午夜精品一区二区三区三上悠亚| 亚洲国产综合人成综合网站| 一区二区三区精密机械公司| 亚洲最色的网站| 日韩一区二区精品葵司在线| 91久久国产综合久久| 国产精品不卡在线观看| 国产精品三级电影| 国产精品久久网站| 成人免费一区二区三区在线观看| 中文字幕一区在线| 一区二区视频在线看| 亚洲精品亚洲人成人网在线播放| 亚洲在线视频网站| 日韩激情一区二区| 久久成人麻豆午夜电影| 国产盗摄一区二区| 99精品偷自拍| 欧美视频一二三区| 欧美一区二区三区四区在线观看| 欧美不卡一区二区三区| 国产校园另类小说区| 国产精品美女久久久久aⅴ国产馆| 国产精品第13页| 亚洲国产欧美一区二区三区丁香婷| 亚洲国产婷婷综合在线精品| 日本伊人精品一区二区三区观看方式| 美女视频黄 久久| 国产成人小视频| 欧洲在线/亚洲| 欧美一级黄色录像| 国产精品网站导航| 亚洲午夜精品一区二区三区他趣| 日本特黄久久久高潮| 久久这里只有精品6| 中文字幕一区av| 日本欧美一区二区| 成人免费视频网站在线观看| 欧美日韩精品一区二区三区 | 精品国产凹凸成av人导航| 日本一区二区三区在线观看| 亚洲综合清纯丝袜自拍| 狠狠色丁香久久婷婷综合_中| 91在线播放网址| 日韩欧美第一区| 日韩美女视频19| 美脚の诱脚舐め脚责91| 91免费版pro下载短视频| 日韩一区二区三区av| 亚洲三级久久久| 久久99精品国产.久久久久久| 91女神在线视频| 精品三级在线观看| 亚洲国产aⅴ天堂久久| 国产成+人+日韩+欧美+亚洲| 51午夜精品国产| 亚洲视频狠狠干| 激情综合色丁香一区二区| 欧美伊人久久大香线蕉综合69 | 欧美美女网站色| 国产精品系列在线| 蜜桃av一区二区| 欧美熟乱第一页| 国产精品欧美综合在线| 极品美女销魂一区二区三区 | 久久久三级国产网站| 五月婷婷欧美视频| 91在线观看美女| 国产精品嫩草影院av蜜臀| 久久精品国产精品青草| 欧美高清激情brazzers| 亚洲麻豆国产自偷在线| 丁香婷婷综合色啪| 久久蜜臀精品av| 久久99精品一区二区三区三区| 欧美在线播放高清精品| 国产精品不卡在线| 国产盗摄一区二区三区| 亚洲精品一区二区三区香蕉| 日韩av一级片| 欧美老年两性高潮| 亚洲综合色噜噜狠狠| 在线一区二区视频| 专区另类欧美日韩| av不卡免费电影| 国产精品理伦片| 成人动漫一区二区| 国产精品毛片久久久久久| 国产成人丝袜美腿| 国产欧美日韩中文久久| 国产91在线观看| 欧美激情艳妇裸体舞| 国产91露脸合集magnet | 一区二区在线观看免费| 97aⅴ精品视频一二三区| 中文字幕一区二区在线播放| 成人黄色a**站在线观看| 中文字幕不卡在线| 99精品欧美一区| 亚洲男人电影天堂| 在线免费不卡电影| 亚洲成人自拍网| 欧美日韩国产片| 五月天丁香久久| 欧美一区二区三区播放老司机| 青青草一区二区三区| 精品国产凹凸成av人导航| 久久国产婷婷国产香蕉| 久久综合久久99| 国产成人av资源| 日韩伦理av电影| 日本高清不卡一区| 日韩精品福利网| 日韩美女天天操| 国产精品一区二区在线观看不卡| 欧美激情一区二区| 色素色在线综合| 日韩成人av影视| 久久综合给合久久狠狠狠97色69| 国产成人综合网站| 亚洲精品久久嫩草网站秘色| 欧美日韩国产成人在线91| 精品一区二区三区在线播放视频| 国产丝袜欧美中文另类| 色噜噜狠狠色综合欧洲selulu| 丝袜美腿高跟呻吟高潮一区| 日韩一区二区电影在线| 成人激情免费网站| 午夜影院久久久| 久久久久成人黄色影片| 99国产精品国产精品久久| 亚洲va欧美va人人爽午夜| 精品av久久707| 91首页免费视频| 麻豆免费精品视频| 亚洲欧美日韩国产综合在线| 日韩欧美成人一区| 91污片在线观看| 久久99久久久久| 亚洲欧美日韩中文播放 | 亚洲最新视频在线观看| 久久综合色一综合色88| 在线精品视频小说1| 激情六月婷婷久久| 亚洲午夜久久久久中文字幕久| 久久综合999| 欧美色视频在线观看| 国产精品2024| 日欧美一区二区| 综合久久久久综合| 久久久国产精品不卡| 9191国产精品| 色综合久久中文字幕综合网| 国产综合色视频| 天天操天天干天天综合网| 成人欧美一区二区三区白人 |