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

首頁 > 開發 > CSS > 正文

CSS3 實現彈幕的示例代碼

2024-07-11 09:07:48
字體:
來源:轉載
供稿:網友

最近需要項目需要實現彈幕,網上參考了各種方法,最后覺得transform+transition實現的效果在移動設備上性能最好,在iphone6和紅米4上測試,看不到卡頓的感覺。用jquery的animate動畫在移動設備上有明顯的卡頓。

1.首先創建彈幕區域

<div class="barrage"><div class="mask"><!--//彈幕內容--></div></div><input type="text" ng-model="data.comment"/><button ng-click="addDanmu()">說兩句</button >

2.css

.webPage .barrage{width:100%;height:22%;position: absolute; bottom: 50px; background-color: transparent;pointer-events: none;}.webPage .barrage .mask{width:100%;height:100%;background:transparent;z-index:100;}

注:以上html,css根據自己需求來即可

3.js

$scope.data = {comment:''};$scope.danmuCount = 5; //最大彈幕行數$scope.danmus = ['1545466666還是','9777777','哈哈哈哈哈','對企業讀完后環球網好齊齊哈','42115我我我5','556噢噢噢噢45','54哦','54545646','666但近段時間66','56565','454465465565', '1545466666還是','9777777','哈哈哈哈哈','對企業讀完后環球網好齊齊哈','42115我我我5','556噢噢噢噢45','54哦','54545646','666但近段時間66','56565','454465465565']; //彈幕數據源//創建彈幕區域$scope.createDanmuContent = function () {var height = 1 / $scope.danmuCount * 100 + '%';for (var i = 0; i < $scope.danmuCount; i++) {var item = '<div style="width: 100%; height: '+height+'"></div>';$('.mask').append(item);} $scope.createDanmu ();};//開始彈幕繪制$scope.createDanmu = function () {var maxCount = 0;if ($scope.danmus.length > $scope.danmuCount) { maxCount = $scope.danmuCount; } else {maxCount = $scope.danmus.length;}var _left = window.screen.width;for (var i = 0; i < maxCount; i++) {var _lable = $("<p style='margin: 0;position: absolute;opacity:1;display:table;left: "+_left + 'px'+';color:'+$scope.getRandomColor()+"'>"+$scope.danmus[i]+"</p>");$(".mask div").each(function () {//檢測該區域是否繪制了彈幕if ($scope.checkDanmu($(this))) {$(this).append(_lable);$scope.moveArray(i); i--;return false;}});}$scope.init_barrage();};//將數組第一位放到最后一位,(因彈幕池內容太少,所以沒刪除已顯示的彈幕)$scope.moveArray = function (i) { var temp = $scope.danmus[i];$scope.danmus.splice(i,1);$scope.danmus.push(temp);}//判斷content區域有沒有彈幕$scope.checkDanmu = function (el) {return el.find('p').length == 0 ? true : false;};//獲取隨機顏色$scope.getRandomColor = function () {return '#' + (function(h){return new Array(7 - h.length).join("0") + h})((Math.random() * 0x1000000 << 0).toString(16))};//初始化彈幕參數$scope.init_barrage = function () {$(".mask div p").show().each(function() { var _moveLeft = window.screen.width+$(this).width();var time = 100000 / $(this).width() + 5000;//彈幕滑動時間$scope.addCssAnimate($(this),_moveLeft,time);});};//添加彈幕動畫$scope.addCssAnimate = function (el,_moveLeft,time) {el.css({'transform':'translateX('+-_moveLeft+'px)','transition':'all '+time+'ms'+ ' linear','-webkit-transform':'translateX('+-_moveLeft+'px)','-webkit-transition':'all '+time+'ms'+ ' linear','-moz-transform':'translateX('+-_moveLeft+'px)','-moz-transition':'all '+time+'ms'+ ' linear','-ms-transform':'translateX('+-_moveLeft+'px)','-ms-transition':'all '+time+'ms'+ ' linear'});//當動畫執行完畢后,將彈幕移到原處,更換彈幕文字,重新開始執行動畫,相當于對原本彈幕的復用$timeout(function () {//判斷彈幕池是否還有內容,如果沒有則移除彈幕if ($scope.danmus.length > 0) {el.css({'transform':'translateX(0px)','transition':'all 0ms linear','-webkit-transform':'translateX(0px)','-webkit-transition':'all 0ms linear','-moz-transform':'translateX(0px)','-moz-transition':'all 0ms linear','-ms-transform':'translateX(0px)','-ms-transition':'all 0ms linear'});$scope.resetAnimate(el);} else {el.remove();}},time);};//更換彈幕內容,重新開始彈幕動畫$scope.resetAnimate = function (el) {el.html($scope.danmus[0]);$scope.moveArray(0);var _moveLeft = el.width() + screen.width;var time = 100000 / el.width() + 5000;$scope.addCssAnimate(el,_moveLeft,time);};//評論,添加彈幕$scope.addDanmu = function () {var text = $scope.data.comment;if(text == ""){return;}$scope.danmus.unshift(text);};$scope.createDanmuContent();

至此,功能基本實現了。要關閉彈幕只需移除彈幕的區域,文中就沒有寫了。

邏輯:首先根據$scope.danmuCount來創建彈幕的行數,然后在每行里面添加彈幕,并添加相應的動畫。當一個動畫執行完畢后,將彈幕移回原處,更換彈幕內容,重新執行動畫,這樣避免了彈幕重疊。每條彈幕動畫執行時間是根據彈幕長度決定的。

個人經驗,希望大家指出不足。上述代碼使用的angularjs,但邏輯都是一樣

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


注:相關教程知識閱讀請移步到CSS教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩电影视频免费| 亚洲精品久久视频| 国产精品直播网红| 欧美交受高潮1| 国产精品视频午夜| 欧美黑人一级爽快片淫片高清| 亚洲精品电影在线| 欧美精品性视频| 国产精品草莓在线免费观看| 色婷婷综合久久久久| 成人免费xxxxx在线观看| 国产欧美一区二区| 国产一区玩具在线观看| 高清在线视频日韩欧美| 亚洲免费高清视频| 午夜精品一区二区三区视频免费看| 欧美国产日韩视频| 国产综合在线视频| 亚洲精品98久久久久久中文字幕| 欧美久久久精品| 一本色道久久88综合日韩精品| 人妖精品videosex性欧美| 精品自拍视频在线观看| 国外成人性视频| 狠狠久久亚洲欧美专区| 中文字幕日韩在线观看| 久久国产精品电影| 日本精品视频网站| 日韩欧美在线国产| 国产精品一区二区三区毛片淫片| 欧美大荫蒂xxx| 欧美高清视频免费观看| 成人性生交大片免费观看嘿嘿视频| 91在线中文字幕| 成人黄色在线免费| 成人午夜小视频| 一本色道久久综合狠狠躁篇怎么玩| 亚洲r级在线观看| 亚洲电影免费在线观看| 精品久久在线播放| 992tv在线成人免费观看| 55夜色66夜色国产精品视频| 亚洲福利视频在线| 亚洲国产欧美自拍| 亚洲欧美日韩直播| 欧美日在线观看| 一本色道久久综合狠狠躁篇怎么玩| 中文字幕日韩免费视频| 精品久久久一区二区| 超碰97人人做人人爱少妇| 久久69精品久久久久久久电影好| 啪一啪鲁一鲁2019在线视频| 欧美日韩电影在线观看| 一区二区三区视频观看| 国产精品嫩草影院一区二区| 欧美老女人性生活| 亚洲欧美另类在线观看| 国产亚洲激情在线| 欧美国产精品人人做人人爱| 亚洲精品视频二区| 欧美激情日韩图片| 在线电影欧美日韩一区二区私密| 热门国产精品亚洲第一区在线| 欧美激情一区二区三区在线视频观看| 国内精品小视频在线观看| 欧美日韩国产一中文字不卡| 欧美精品久久久久久久| 91精品91久久久久久| 久久久久久国产精品三级玉女聊斋| 欧美视频在线观看免费| 亚洲www视频| 日韩电影在线观看永久视频免费网站| 中文字幕亚洲国产| 狠狠躁夜夜躁人人爽超碰91| 91久久久久久| 国产精品久久久久久久久免费| 亚洲精品一区二区久| 91av福利视频| 国产日韩欧美夫妻视频在线观看| 日本欧美黄网站| 国产啪精品视频| 4k岛国日韩精品**专区| 成人写真视频福利网| 色黄久久久久久| 国产精品永久免费在线| 亚洲欧美在线看| 国产乱肥老妇国产一区二| 成人激情免费在线| 国产成人精品电影久久久| 国产精品嫩草视频| 欧美日韩成人在线观看| 美女黄色丝袜一区| 国产一区香蕉久久| 美女av一区二区| 国产日本欧美一区| 精品一区二区亚洲| 日韩一中文字幕| 国产精品私拍pans大尺度在线| 欧美性猛xxx| 亚洲性生活视频| 国产成人精品a视频一区www| 97国产在线视频| 美女黄色丝袜一区| 日韩精品视频在线播放| 国产视频观看一区| 日韩电影中文字幕在线观看| 成人激情视频小说免费下载| 亚洲天堂一区二区三区| 91在线免费网站| xx视频.9999.com| 亚洲偷熟乱区亚洲香蕉av| 欧美国产日韩一区二区| 亚洲精品欧美日韩专区| 国模私拍视频一区| 亚洲综合中文字幕68页| 2021国产精品视频| 久久久久久久久中文字幕| 国产经典一区二区| 国产精品18久久久久久首页狼| 国产成人精品免高潮费视频| 日韩电影在线观看永久视频免费网站| 日本精品一区二区三区在线播放视频| 久久深夜福利免费观看| 亚洲精品国产电影| 精品一区二区三区三区| 最新国产精品拍自在线播放| 国产97人人超碰caoprom| 欧美激情一区二区三级高清视频| 亚洲字幕在线观看| 亚洲成人黄色网址| 日韩av免费观影| 97在线视频免费| 麻豆乱码国产一区二区三区| 91国产高清在线| 中文字幕一区电影| 亚洲国产91精品在线观看| 欧美超级免费视 在线| 青青a在线精品免费观看| 国产日韩中文字幕在线| 亚洲精品白浆高清久久久久久| 国产中文字幕91| 欧美日韩国产123| 国外色69视频在线观看| 国产成人精品久久| 欧美最顶级丰满的aⅴ艳星| 国产视频精品自拍| 97热精品视频官网| 欧美xxxwww| 在线观看视频99| 九九精品在线观看| 中文字幕精品视频| 久久人人看视频| 中文字幕亚洲一区| 欧美视频中文字幕在线| 日韩欧美成人免费视频| 日韩美女视频免费看| 亚洲xxxxx性| 欧亚精品在线观看| 久久99视频精品| 日韩视频欧美视频| 久久国产精品久久精品| 国产精品视频白浆免费视频| 欧美影院成年免费版| 日韩电影中文字幕av|