成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識(shí)庫 > 前端實(shí)現(xiàn)彈幕效果的方法總結(jié)(包含css3和canvas的實(shí)現(xiàn)方式)

前端實(shí)現(xiàn)彈幕效果的方法總結(jié)(包含css3和canvas的實(shí)現(xiàn)方式)

熱門標(biāo)簽:鎮(zhèn)江智能外呼系統(tǒng)有效果嗎 成都智能外呼系統(tǒng)平臺(tái) 黃島區(qū)地圖標(biāo)注 四川點(diǎn)撥外呼系統(tǒng) 江蘇智能電銷機(jī)器人哪家好 當(dāng)涂高德地圖標(biāo)注 南寧點(diǎn)撥外呼系統(tǒng)哪家公司做的好 云南大理400電話申請(qǐng)官方 電銷機(jī)器人電話用什么卡

之前在一個(gè)移動(dòng)端的抽獎(jiǎng)頁面中,在抽獎(jiǎng)結(jié)果的展示窗口需要彈幕輪播顯示,之前踩過一些小坑,現(xiàn)在總結(jié)一下前端彈幕效果的實(shí)現(xiàn)方式。

  • css3實(shí)現(xiàn)乞丐版的彈幕
  • css3彈幕性能優(yōu)化
  • canvas實(shí)現(xiàn)彈幕
  • canva彈幕的擴(kuò)展功能

1. css3實(shí)現(xiàn)乞丐版的彈幕

(1)如何通過css3實(shí)現(xiàn)彈幕

首先來看如何通過css的方法實(shí)現(xiàn)一個(gè)最簡(jiǎn)單的彈幕:

首先在html中定義一條彈幕的dom結(jié)構(gòu):

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

彈幕的移動(dòng)可以通過移動(dòng)這個(gè)block來實(shí)現(xiàn),以從右向左移動(dòng)的彈幕為例,彈幕的初始位置在容器的最左側(cè)且貼邊隱藏(彈幕的最左邊與容器的最右貼合),可以通過絕對(duì)定位加transform來實(shí)現(xiàn):

.block{
   position:absolute;
}

初始位置:

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

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

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

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

根據(jù)起始位置和結(jié)束位置可以定義完整的兩幀彈幕動(dòng)畫:

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

給彈幕元素引入這個(gè)動(dòng)畫:

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

這樣就可以實(shí)現(xiàn)一個(gè)乞丐版的彈幕效果:

 

(2)通過絕對(duì)定位和left實(shí)現(xiàn)彈幕的缺陷

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

I)根據(jù)HTML的結(jié)構(gòu)生成DOM樹(DOM樹中包含了display:none的節(jié)點(diǎn)) II)在DOM樹的基礎(chǔ)上,根據(jù)節(jié)點(diǎn)的幾何屬性(margin/padding/width/height/left等)生成render樹 III)在render樹的基礎(chǔ)上繼續(xù)渲染color,font等屬性

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

reflow(回流):當(dāng)render樹中的一部分或者全部因?yàn)榇笮∵吘嗟葐栴}發(fā)生改變而需要重建的過程叫做回流 repaint(重繪):當(dāng)元素的一部分屬性發(fā)生變化,如外觀背景色不會(huì)引起布局變化而需要重新渲染的過程叫做重繪

reflow(回流)會(huì)影響瀏覽器css的渲染速度,因此在做網(wǎng)頁性能優(yōu)化的時(shí)候要減少回流的發(fā)生。

在第一節(jié),我們通過left屬性,實(shí)現(xiàn)了彈幕的效果,left會(huì)改變?cè)氐牟季?,因此?huì)發(fā)生reflow(回流),表現(xiàn)在移動(dòng)端頁面上會(huì)造成彈幕動(dòng)畫的卡頓。

2. css3彈幕性能優(yōu)化

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

(1)CSS開啟硬件加速

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

CSS animations, transforms 以及 transitions 不會(huì)自動(dòng)開啟GPU加速,而是由瀏覽器的緩慢的軟件渲染引擎來執(zhí)行。那我們?cè)鯓硬趴梢郧袚Q到GPU模式呢,很多瀏覽器提供了某些觸發(fā)的CSS規(guī)則。

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

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

這樣就可以通過開啟硬件加速的方式,優(yōu)化網(wǎng)頁性能。但是這種方式?jīng)]有從根本上解決問題,同時(shí)使用GPU增加了內(nèi)存的使用,會(huì)減少移動(dòng)設(shè)備的電池壽命等等。

(2)不改變left屬性

第二種方法,就是想辦法在彈幕動(dòng)畫的前后不改變left屬性的值,這樣就不會(huì)發(fā)生reflow。

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

以父元素為body時(shí)為例:

//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計(jì)算了父元素的寬度,從而確定彈幕節(jié)點(diǎn)的初始位置之外,這里在彈幕節(jié)點(diǎn)中我們?yōu)榱朔乐钩跏嘉恢镁陀酗@示,增加了visibility:hidden屬性。防止彈幕節(jié)點(diǎn)在未確定初始位置時(shí)就顯示在父容器內(nèi)。只有彈幕開始從初始位置滾動(dòng),才會(huì)變得可見。

但是這種css的實(shí)現(xiàn)方式,在實(shí)現(xiàn)彈幕的擴(kuò)展功能方面比較麻煩,比如如何控制彈幕暫停等等。

3. canvas實(shí)現(xiàn)彈幕

除了通過css實(shí)現(xiàn)彈幕的方法之外,通過canvas也可以實(shí)現(xiàn)彈幕。

通過canvas實(shí)現(xiàn)彈幕的原理就是時(shí)時(shí)的重繪文字,下面來一步步的實(shí)現(xiàn)。

獲取畫布

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

繪制文字

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

上面的fillText就是實(shí)現(xiàn)彈幕效果的主要api,其中x表示橫方向的坐標(biāo),y表示縱方向的坐標(biāo),只要時(shí)時(shí)的改變x,y進(jìn)行重繪,就可以實(shí)現(xiàn)動(dòng)態(tài)的彈幕效果。復(fù)制代碼

清除繪制內(nèi)容

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

具體實(shí)現(xiàn)

通過定時(shí)器,定時(shí)改變x,y,每次改變之前先進(jìn)性清屏,然后根據(jù)改變后的x,y進(jìn)行重繪。當(dāng)存在多條彈幕的情況下,定義:

let colorArr=_this.getColor(color);  彈幕數(shù)組多對(duì)應(yīng)的顏色數(shù)組
    let numArrL=_this.getLeft();  彈幕數(shù)組所對(duì)應(yīng)的x坐標(biāo)位置數(shù)組
    let numArrT=_this.getTop();  彈幕數(shù)組所對(duì)應(yīng)的y坐標(biāo)位置數(shù)組
    let speedArr=_this.getSpeed(); 彈幕數(shù)組所對(duì)應(yīng)的彈幕移動(dòng)速度數(shù)組

定時(shí)的重繪彈幕函數(shù)為:

_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);

實(shí)現(xiàn)的效果為:

 

4. canva彈幕的擴(kuò)展功能

通過canvas實(shí)現(xiàn)彈幕的方式,很方便做比如暫停彈幕滾動(dòng)等擴(kuò)展功能,此外,也可以給彈幕增加頭像,給每條彈幕增加邊框等等功能,以后再補(bǔ)充。

最后給一個(gè)簡(jiǎn)單的react彈幕組件;https://github.com/forthealllight/react-barrage

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:十堰 酒泉 淮安 佳木斯 廣西 西寧 咸寧 南京

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《前端實(shí)現(xiàn)彈幕效果的方法總結(jié)(包含css3和canvas的實(shí)現(xiàn)方式)》,本文關(guān)鍵詞  前端,實(shí)現(xiàn),彈幕,效果,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《前端實(shí)現(xiàn)彈幕效果的方法總結(jié)(包含css3和canvas的實(shí)現(xiàn)方式)》相關(guān)的同類信息!
  • 本頁收集關(guān)于前端實(shí)現(xiàn)彈幕效果的方法總結(jié)(包含css3和canvas的實(shí)現(xiàn)方式)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    色中文字幕在线| 国产女片a归国片aa| 在线视频观看亚洲| 亚洲91在线| 欧美久久久久久蜜桃| 天堂va欧美va亚洲va老司机| 国产一区二区三区四区福利| 老师让我她我爽了好久视频| 成人中心免费视频| 国产日韩欧美视频在线观看| 国产传媒久久文化传媒| 擼擼色在线看观看免费| 日本少妇高潮喷水视频| 校花撩起jk露出白色内裤国产精品| 国内精品免费午夜毛片| 懂色av粉嫩av蜜臀av| 天堂中文资源在线观看| 中文字幕在线观看一区二区三区| 中文字幕免费在线观看视频| 91精品国产91久久久久久青草| 亚洲电影一区| 粉嫩av一区| 中文字幕在线观看1| 日本黄色网网页| 91中文在线视频| 另类的小说在线视频另类成人小视频在线| 亚洲色图都市激情| 亚洲国产精品va在线看黑人| 在线观看欧美日本| 蜜臀精品一区二区| 一区二区三区播放| 欧美日韩亚洲一| 国产精品乱码久久久| 无码人妻精品一区二区三区66| 99久久伊人久久99| 最新国产热播激情视频| 三级成人在线| 国产成在线观看免费视频| 中文字幕在线视频观看| 人与人69性欧美三人交| 国产精品无码无卡无需播放器| 日韩美女国产精品| 欧美一区三区二区在线观看| 国产精品污www一区二区三区| 精品国产一区二区三区性色av| 91久久嫩草影院一区二区| 26uuu色噜噜精品一区二区| 在线播放 亚洲| 日韩一二三在线视频播| 亚洲天堂第一区| 国产在线精品一区二区中文| 四虎成人在线播放| 亚洲女与黑人做爰| 国产精品视频一区二区三区麻豆| 欧美系列精品| 久久亚洲国产精品成人av秋霞| 欧美色欧美亚洲另类| 色婷婷综合久久| 高清1区2区| 欧美日韩国产一区| 亚洲国产精品久久一线不卡| 51av在线| 樱花草国产18久久久久| 欧美乱大交做爰xxxⅹ性3| 成人欧美一区二区三区黑人麻豆| 一区二区免费在线播放| 亚洲娇小娇小娇小| 国产一区二区在线视频观看| 五月天婷婷综合网| 色七七在线观看| 亚洲精品乱码久久久久久按摩观| 国产99久久九九精品无码免费| 欧美日韩久久不卡| 中国黄色录像片| 最近中文字幕免费mv| 日韩精品亚洲元码| 色帝国亚洲欧美在线| 欧美在线日韩精品| 国产成人亚洲综合色影视| 国产麻豆剧传媒精品国产| av毛片免费看| 大胆av不用播放器在线播放| 色一情一乱一伦一区二区三区丨| 欧美日韩一级视频| 午夜国产一级| 九色porny在线观看| 婷婷成人基地| 婷婷综合在线视频| 国产一区二区三区免费观看| 久久久久久久国产| 欧美一级理论性理论a| 日本一区二区三区四区五区六区| 色婷婷久久久亚洲一区二区三区| 日韩精品中文字幕久久臀| 国内精品久久久久影院色| 国产尤物视频在线观看| 精品亚洲国产成人av制服丝袜| 亚洲精品乱码久久久久久蜜桃动漫| 不卡一卡2卡3卡4卡精品在| 国产精品视频中文字幕91| 欧美精品在线免费观看| 伊人免费在线观看高清版| av片在线免费看| 亚洲色图视频网站| 国产美女久久久| 一区二区三区午夜视频| 日韩av电影免费播放| 国产3p露脸普通话对白| 欧美精品色婷婷五月综合| 国产又黄又爽又猛免费app| 国产农村妇女精品一二区| 日本少妇激情舌吻| 欧美激情一区二区三区在线视频| 欧洲日韩一区二区三区| 国产日韩欧美第一页| 精品一区电影| 成人福利免费观看| 欧美色图在线播放| 肥熟一91porny丨九色丨| 久久综合国产精品台湾中文娱乐网| 性欧美1819sex性高清| 欧美人与动牲交xxxxbbbb| 亚洲人成电影网站色| 欧美xxxxx精品| 久久精品免费网站| av鲁丝一区鲁丝二区鲁丝三区| 日日夜夜免费精品| 93久久精品日日躁夜夜躁欧美| 猛性xxxxx| 曰本三级在线| 国产精品久久久久久久免费大片| 偷拍盗摄高潮叫床对白清晰| 国产经典视频一区| 大陆极品少妇内射aaaaa| 99免费在线视频| 一区二区精品在线观看| 成人综合网站| 91电影在线播放| 国产美女在线一区| 亚洲人成人99网站| 东方av正在进入| 国产三级精品在线| 国产三区在线观看| 电影天堂最新网址| 成人手机在线电影| 国产成人无码一区二区在线播放| 都市激情亚洲色图| 国产95亚洲| 污网站免费在线| 欧美激情影音先锋| 超碰在线资源| 影音先锋2020色资源网| 成人a在线观看| 欧美成人免费网站| 精品成人av| 日韩一级大片在线观看| 久久精品国产综合| 800av在线免费观看| 国产福利一区二区三区在线视频| 国产一区二区三区免费不卡| 5858s免费视频成人| 精品亚洲免费视频| 久久久久久国产精品无码| 免费看av成人| 国产成人丝袜美腿| 91青青在线视频| 比比资源-先锋影音资源站| 国产三级精品三级观看| 欧美午夜精品久久久久久孕妇| a毛片在线免费观看| 欧美成人一二三| 国产精品老熟女一区二区| 日本美女一区二区三区视频| 久久aimee| 天堂色在线视频| 手机看片国产日韩| 国产一级免费黄色片| 欧美亚洲国产成人精品| 色悠悠久久88| 麻豆精品国产传媒mv男同| 国产精品亚洲综合天堂夜夜| xxx欧美尤物xxx| 久久国产精品99国产| 高清在线一区| 日韩视频在线观看国产| 欧美日韩午夜| 国产偷窥老熟盗摄视频| 久久久人成影片一区二区三区观看| 欧美日本国产精品| 一区不卡在线观看| 中文字幕丰满孑伦无码专区| 97视频在线观看网站| 欧美在线免费观看亚洲| 本田岬高潮一区二区三区| 麻豆高清免费国产一区| 欧美午夜电影一区二区三区| 日韩精品中文字幕在线播放| 蜜桃传媒一区二区三区| www.av99| 亚洲不卡中文字幕| 蜜桃视频一区二区三区| 亚洲少妇最新在线视频| 日韩中文不卡| 亚洲精品美女网站| 亚洲欧美国产一区二区| 亚洲最大福利视频网站| 久久九九精品视频| 韩国三级中文字幕hd久久精品| 欧美一区二区.| 国产精品99久久久久久久久| 国产麻豆精品一区二区三区v视界| 成熟亚洲日本毛茸茸凸凹| 久久99精品国产.久久久久久| 极品尤物av久久免费看| 色播亚洲视频在线观看| 欧美成人全部免费| 欧美成人一区在线| 欧美激情四色| 一本一道dvd在线观看免费视频| 2021亚洲天堂| 日本久久久久久久久久久久| 亚洲动漫精品| 在线精品观看国产| 天堂资源在线亚洲| 国产一区亚洲二区三区| 日本视频免费一区| 日韩高清不卡一区二区三区| 国产老熟妇精品观看| 精品无码在线观看| 伊人影院在线观看| 亚洲电影一二三区| 久久九九热re6这里有精品| 少妇精品高潮欲妇又嫩中文字幕| 亚洲精品免费一区亚洲精品免费精品一区| 成人动漫视频在线观看免费| 欧美成人三级在线视频| 日本乱码高清不卡字幕| 日韩护士脚交太爽了| 国产精品久av福利在线观看| 久久亚洲精精品中文字幕| 色成人在线视频| 久久免费高清| 亚洲色图都市小说| 91成人在线精品视频| 亚洲人精品午夜射精日韩| 亚洲AV无码国产精品午夜字幕| 51精品国产| 天堂在线第六区| 台湾佬成人中文网222vvv| 91国产中文字幕| 国精产品一区二区| 日本少妇xxx| 你懂的国产在线| 无码人妻精品一区二区三区温州| 国产伦精品一区二区三区在线观看| 91久久国产综合久久91| 91po在线观看91精品国产性色| 91麻豆国产精品久久| 成人3d动漫在线观看| 久热re这里精品视频在线6| 在线一区二区视频| 女教师高潮黄又色视频| 成人精品在线观看| 中文精品久久| 五月婷在线视频| 国产十六处破外女视频| 亚洲人视频在线观看| 国产波霸爆乳一区二区| 国产日韩欧美视频| 精品av在线播放| 操喷在线视频| 影音先锋资源av| 日韩成人三级视频| 男人午夜免费视频| 欧美网色网址| 国产又黄又粗又长| www.99r| 成人h动漫精品| 精品成人av一区二区在线播放| 三级一区在线视频先锋| 成人在线一区二区| 可以看污的网站| 日韩午夜在线观看视频| 午夜视频国产| 麻豆电影传媒二区| 在线播放视频一区| 中文字幕日韩一区二区三区不卡| 久久久久久av无码免费网站| 日韩欧美在线视频日韩欧美在线视频| 精品成人一区二区三区四区| 性xxxx丰满孕妇xxxx另类| 筱崎爱全乳无删减在线观看| 成年人视频网站免费观看| 久久影院免费观看| 成人av电影在线观看| 野外性xxxxfreexxxxx欧美| 亚洲午夜精品一区二区三区他趣| 日韩精品成人在线| 免费视频网站在线观看入口| 免费在线性爱视频| 欧美一区二区三区电影| 久色婷婷小香蕉久久| 久久久久久综合网天天| 久久影院资源网| 7777狠狠狠琪琪电影| 中文字幕黄色片| 你懂的在线视频观看| 久久精品国产亚洲夜色av网站| 欧美亚洲国产一区二区三区| 日本高清不卡中文字幕| 四虎国产精品免费观看| 亚洲天堂日韩av| 黄色动漫免费看| 午放福利视频在线播放| av在线播放免费| 大胆欧美人体视频| 1769免费视频在线观看| 亚洲欧美另类中文字幕| 久久亚洲中文字幕无码| 天堂久久精品忘忧草| 岛国av在线免费| 成人天堂av| 国产精品一区久久久| 亚洲一区免费在线观看| 久久另类ts人妖一区二区| 国产亚洲一本大道中文在线| 日本一区二区不卡视频| 亚洲国产精品成人|