中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

使用CSS3怎么實(shí)現(xiàn)一個(gè)彈幕功能-創(chuàng)新互聯(lián)

本篇文章給大家分享的是有關(guān)使用CSS3怎么實(shí)現(xiàn)一個(gè)彈幕功能,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。

創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括綿竹網(wǎng)站建設(shè)、綿竹網(wǎng)站制作、綿竹網(wǎng)頁(yè)制作以及綿竹網(wǎng)絡(luò)營(yíng)銷策劃等。多年來(lái),我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,綿竹網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到綿竹省份的部分城市,未來(lái)相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

1.首先創(chuàng)建彈幕區(qū)域


<div class="barrage">
<div class="mask">
<!--//彈幕內(nèi)容-->
</div>
</div>

<input type="text" ng-model="data.comment"/>
<button ng-click="addDanmu()">說(shuō)兩句</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根據(jù)自己需求來(lái)即可

3.js

$scope.data = {comment:''};
$scope.danmuCount = 5; //較大彈幕行數(shù)
$scope.danmus = ['1545466666還是','9777777','哈哈哈哈哈','對(duì)企業(yè)讀完后環(huán)球網(wǎng)好齊齊哈','42115我我我5','556噢噢噢噢45','54哦','54545646','666但近段時(shí)間66','56565','454465465565', '1545466666還是','9777777','哈哈哈哈哈','對(duì)企業(yè)讀完后環(huán)球網(wǎng)好齊齊哈','42115我我我5','556噢噢噢噢45','54哦','54545646','666但近段時(shí)間66','56565','454465465565']; //彈幕數(shù)據(jù)源

//創(chuàng)建彈幕區(qū)域
$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 ();
};

//開(kāi)始彈幕繪制
$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 () {
//檢測(cè)該區(qū)域是否繪制了彈幕
if ($scope.checkDanmu($(this))) {
$(this).append(_lable);
$scope.moveArray(i);
 i--;
return false;
}
});
}
$scope.init_barrage();
};

//將數(shù)組第一位放到最后一位,(因彈幕池內(nèi)容太少,所以沒(méi)刪除已顯示的彈幕)
$scope.moveArray = function (i) {
 var temp = $scope.danmus[i];
$scope.danmus.splice(i,1);
$scope.danmus.push(temp);
}
//判斷content區(qū)域有沒(méi)有彈幕
$scope.checkDanmu = function (el) {
return el.find('p').length == 0 ? true : false;
};
//獲取隨機(jī)顏色
$scope.getRandomColor = function () {
return '#' + (function(h){
return new Array(7 - h.length).join("0") + h
})((Math.random() * 0x1000000 << 0).toString(16))
};

//初始化彈幕參數(shù)
$scope.init_barrage = function () {
$(".mask div p").show().each(function() {
 var _moveLeft = window.screen.width+$(this).width();
var time = 100000 / $(this).width() + 5000;//彈幕滑動(dòng)時(shí)間
$scope.addCssAnimate($(this),_moveLeft,time);
});
};

//添加彈幕動(dòng)畫
$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'
});
//當(dāng)動(dòng)畫執(zhí)行完畢后,將彈幕移到原處,更換彈幕文字,重新開(kāi)始執(zhí)行動(dòng)畫,相當(dāng)于對(duì)原本彈幕的復(fù)用
$timeout(function () {
//判斷彈幕池是否還有內(nèi)容,如果沒(méi)有則移除彈幕
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);
};

//更換彈幕內(nèi)容,重新開(kāi)始彈幕動(dòng)畫
$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);
};

//評(píng)論,添加彈幕
$scope.addDanmu = function () {
var text = $scope.data.comment;
if(text == ""){
return;
}
$scope.danmus.unshift(text);
};

$scope.createDanmuContent();

以上就是使用CSS3怎么實(shí)現(xiàn)一個(gè)彈幕功能,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

網(wǎng)站名稱:使用CSS3怎么實(shí)現(xiàn)一個(gè)彈幕功能-創(chuàng)新互聯(lián)
標(biāo)題來(lái)源:http://www.rwnh.cn/article34/cesjse.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作全網(wǎng)營(yíng)銷推廣、軟件開(kāi)發(fā)、用戶體驗(yàn)、品牌網(wǎng)站建設(shè)、網(wǎng)站內(nèi)鏈

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設(shè)
兰州市| 准格尔旗| 鲜城| 平遥县| 江阴市| 久治县| 西宁市| 台安县| 宜昌市| 谢通门县| 大丰市| 天台县| 同江市| 黄骅市| 青龙| 井冈山市| 布尔津县| 沭阳县| 大冶市| 和静县| 连州市| 鹤山市| 汉川市| 沐川县| 博白县| 开阳县| 长岛县| 长岭县| 保德县| 依兰县| 聂荣县| 玉龙| 政和县| 杨浦区| 五原县| 溧阳市| 西贡区| 大城县| 尼玛县| 赤城县| 石首市|