Web前端基于jQuery实现弹幕APP,Canvas实现弹幕效果

今天闲着无聊,写了个弹幕APP,主要实现以下几个功能:

Web前端,基于jQuery实现弹幕APP,jquery幕app

今天闲着无聊,写了个弹幕APP,主要实现以下几个功能:

1.点击“弹幕发射”或回车可以输出弹幕到弹幕墙上。
2.弹幕的运行轨迹是从弹幕墙的最右边到最左边,Y轴的数值在弹幕墙的高度内随机,颜色HEX随机,速度随机。
3.右侧的表格可以储存弹幕内容以及弹幕的发射时间,越靠近现在的越靠前。
4.点击“清除弹幕”可以把弹幕墙内的所有弹幕清除掉,但不会影响到表格中的数据。
5.如果弹幕长度过长(我设置的是6个字符),则超过规定长度之外的弹幕内容都会由“…”代替,并放入表格中。但弹幕墙中的内容依然是完整的。

Web前端 1

HTML代码:

<div class="frame"> 
 <div class="row"> 
 <div class="col-xs-8 col-sm-8 col-md-8 col-lg-8 danmu-box-frame"> 
  <div class="danmu-box"> 
  </div> 
 </div> 
 <div class="col-xs-4 col-sm-4 col-md-4 col-lg-4 danmu-table-frame"> 
  <table class="table .table-condensed danmu-table"> 
  <thead> 
   <tr> 
   <th> 
    弹幕内容 
   </th> 
   <th> 
    弹幕时间 
   </th> 
   </tr> 
  </thead> 
  <tbody> 
  </tbody> 
  </table> 
 </div> 
 </div> 
 <div class="danmu-form"> 
 <form class="form-inline"> 
  <input type="text" class="form-control" placeholder="开始吐槽!"> 
  <button type="button" class="btn btn-primary shoot"> 
  发射弹幕! 
  </button> 
  <button type="button" class="btn btn-danger clear"> 
  清空弹幕 
  </button> 
 </form> 
 </div> 
</div> 
<hr> 
<footer> 
 Designed By 
 <a href="http://blog.csdn.net/alenhhy" target="_blank"> 
 Alen Hu 
 </a> 
</footer> 

*使用了Bootstrap3框架。

JQuery部分:

$(document).ready(function() { 
 $(".shoot").on("click", startDanmu); 
 $("form").keypress(function(event) { 
 if (event.keyCode === 13) { 
  event.preventDefault(); 
  startDanmu(); 
 } 
 }); 
 $(".clear").on("click", clearDanmu); 
}); 

//get random number in certain range 
function RandomNum(Min, Max) { 
 var Range = Max - Min; 
 var Rand = Math.random(); 
 var num = Min + Math.round(Rand * Range); 
 return num; 
} 

//time number add 0 before if <10 
function plusZero(x) { 
 if (x < 10) { 
 x = "0" + x; 
 } else { 
 x = x; 
 } 
 return x; 
} 

//start danmu 
function startDanmu() { 

 var message = $("input"); 
 var messageVal = message.val(); 
 var danmuMessage = "" + messageVal + ""; 

 //get random color HEX 
 //u can also save the colors u want by array 
 var color = RandomNum(100000, 999999); 

 //get random danmu speed 
 var speed = RandomNum(10000, 20000); 

 //get random position Y 
 //danmu box height is 450, we set the danmu position Y max 400 in case it blocks the subtitle 
 var positionY = RandomNum(50, 400); 

 if (messageVal.length > 0) { 
 //insert danmu message into danmu box 
 $(".danmu-box").prepend(danmuMessage); 

 //have to use first() cuz we prepend the message, u can try what's gonna happen if no first() 
 //set it's style 
 $(".danmu-message").first().css({ 
  "right": "0", 
  "top": positionY, 
  "color": "#" + color 
 }); 

 //set it's animation 
 //from right 0 to left 0 
 //hide it after move 
 $(".danmu-message").first().animate({ 
  left: '0px', 
 }, 
 speed, 
 function() { 
  $(this).fadeOut(); 
 }); 
 //get danmu time 
 var time = new Date(); 
 var month = time.getMonth() + 1; 
 var day = time.getDay(); 
 var hour = time.getHours(); 
 var minute = time.getMinutes(); 
 var danmuTime = plusZero(month) + "-" + plusZero(day) + " " + plusZero(hour) + ":" + plusZero(minute); 

 //insert danmu message to table 
 if (messageVal.length > 6) { 
  messageVal = messageVal.substring(0, 6) + "..."; 
 } 
 var messageToTable = "<tr><td>" + messageVal + "</td><td>" + danmuTime + "</td></tr>"; 
 $(".danmu-table > tbody").prepend(messageToTable); 

 } else {} 

 //empty the input 
 message.val(""); 
} 

//clear danmu box 
function clearDanmu() { 
 $(".danmu-box").html(""); 
} 

DEMO在这儿,欢迎来FORK:Danmu APP。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持帮客之家。

今天闲着无聊,写了个弹幕APP,主要实现以下几个功能:
1.点击“弹幕发射”或回车可以输出弹幕到弹幕墙…

 JQuery和HTML5 Canvas两种方法实现弹幕效果:

1.点击“弹幕发射”或回车可以输出弹幕到弹幕墙上。
2.弹幕的运行轨迹是从弹幕墙的最右边到最左边,Y轴的数值在弹幕墙的高度内随机,颜色HEX随机,速度随机。
3.右侧的表格可以储存弹幕内容以及弹幕的发射时间,越靠近现在的越靠前。
4.点击“清除弹幕”可以把弹幕墙内的所有弹幕清除掉,但不会影响到表格中的数据。
5.如果弹幕长度过长(我设置的是6个字符),则超过规定长度之外的弹幕内容都会由“…”代替,并放入表格中。但弹幕墙中的内容依然是完整的。

Web前端 2

Web前端 3

方法一,JQuery实现。 源码:

HTML代码:

<!DOCTYPE html> 
<html> 
<head> 
  <meta charset="utf-8"> 
  <meta http-equiv="X-UA-Compatible" content="IE=edge"> 
  <meta name="viewport" content="width=device-width, initial-scale=1"> 
  <!-- 
  <link href="favicon.ico" rel="shortcut icon" type="image/x-icon" /> 
  <link href="favicon.ico" rel="Bookmark" type="image/x-icon" /> 
  --> 
  <meta name="Generator" content="EditPlus®"> 
  <meta name="Author" content=""> 
  <meta name="Keywords" content=""> 
  <meta name="Description" content=""> 
  <title>JQuery弹幕</title> 
  <link href="" rel="stylesheet" /> 
  <script type="text/javascript" src="http://apps.bdimg.com/libs/jquery/1.9.1/jquery.min.js"></script> 
  <style type="text/css"> 
    .ctxt{ 
      background:#666; 
      width:1000px; 
      height:400px; 
      overflow:hidden; 
      margin:0 auto; 
    } 
    .ctxt p{ 
      position:relative; 
      left:1000px; 
      margin:0; 
      padding:0; 
    } 
  </style> 
</head> 
<body> 
<div id="" class="ctxt"></div> 
<br /> 
<form method="post" action="" align="center"> 
  <input type="text" id="msg" style="height:24px;width:200px;" /> <button type="button" id="submitBut">发布</button> 
</form> 

<script type="text/javascript"> 
$(document).ready(function(){ 

  $("#submitBut").click(function(){ 
    var msgtxt=$("#msg").val(); 
    var colortxt = getReandomColor(); 
    var topPos = generateMixed(3); 
    if (topPos > 300) 
    { 
      topPos = 30; 
    } 
    var newtxt = '<p style="top:'+topPos+'px; color:'+colortxt+'">'+$("#msg").val()+'</p>'; 
    $(".ctxt").prepend(newtxt); 
    var addTextW = $(".ctxt").find("p").width(); 
    $(".ctxt p").animate({left: '-'+addTextW+"px"}, 30000,function(){ 
      $(this).hide(); 
    }); 
  }); 

}); 
//随机获取颜色值 
  function getReandomColor(){ 
    return '#'+(function(h){ 
    return new Array(7-h.length).join("0")+h 
    })((Math.random()*0x1000000<<0).toString(16)) 
  } 

//生成随机数据。n表示位数  
  var jschars = ['0','1','2','3','4','5','6','7','8','9'];  
  function generateMixed(n) {  
    var res = "";  
    for(var i = 0; i < n ; i ++) {  
      var id = Math.ceil(Math.random()*9);  
      res += jschars[id];  
    }  
    return res;  
  }  
</script> 

</body> 
</html>
<div class="frame"> 
 <div class="row"> 
 <div class="col-xs-8 col-sm-8 col-md-8 col-lg-8 danmu-box-frame"> 
  <div class="danmu-box"> 
  </div> 
 </div> 
 <div class="col-xs-4 col-sm-4 col-md-4 col-lg-4 danmu-table-frame"> 
  <table class="table .table-condensed danmu-table"> 
  <thead> 
   <tr> 
   <th> 
    弹幕内容 
   </th> 
   <th> 
    弹幕时间 
   </th> 
   </tr> 
  </thead> 
  <tbody> 
  </tbody> 
  </table> 
 </div> 
 </div> 
 <div class="danmu-form"> 
 <form class="form-inline"> 
  <input type="text" class="form-control" placeholder="开始吐槽!"> 
  <button type="button" class="btn btn-primary shoot"> 
  发射弹幕! 
  </button> 
  <button type="button" class="btn btn-danger clear"> 
  清空弹幕 
  </button> 
 </form> 
 </div> 
</div> 
<hr> 
<footer> 
 Designed By 
 <a href="http://blog.csdn.net/alenhhy" target="_blank"> 
 Alen Hu 
 </a> 
</footer> 

 方法二,HTML5 Canvas实现。
源码:

*使用了Bootstrap3框架。

<!DOCTYPE html> 
<html> 
<head> 
  <meta charset="utf-8"> 
  <meta http-equiv="X-UA-Compatible" content="IE=edge"> 
  <meta name="viewport" content="width=device-width, initial-scale=1"> 
  <!-- 
  <link href="favicon.ico" rel="shortcut icon" type="image/x-icon" /> 
  <link href="favicon.ico" rel="Bookmark" type="image/x-icon" /> 
  --> 
  <meta name="Generator" content="EditPlus®"> 
  <meta name="Author" content=""> 
  <meta name="Keywords" content=""> 
  <meta name="Description" content=""> 
  <title>Canvas弹幕</title> 
  <link href="" rel="stylesheet" /> 
  <style type="text/css"> 

    #c1{background:#f1f1f1;} 
    span{color:#FFFFFF;} 
  </style> 
</head> 
<body> 
<canvas id="c1" width="600" height="300" > 
  该浏览器不支持html5 
</canvas> 
<br /> 
<input type="text" name='smsg' value="" id="smsg" placeholder="请输入内容" /> <button id="send">发送</button> 
<!--<button id='start' onclick="startFun('test')">Start</button> 
<button id='stop' onclick="stopFun()">Stop</button>--> 



<script type="text/javascript" src="http://apps.bdimg.com/libs/jquery/1.9.1/jquery.min.js"></script> 
<script type="text/javascript">   
  var sv; 
  var sId; 
  var oC; 
  var oGC;   
  var numW; 
  var numH; 
  var maxTxt = 600; 


$(function(){ 
$("#send").click(function(){ 
    clearInterval(sId); 
    var m = $("#smsg").val(); 
    //alert(m); 
    startFun(m); 
    $("#smsg").val('') 
  }); 
}) 
  function doDraw(msg){ 
    oC = document.getElementById('c1'); 
    oGC = oC.getContext('2d');   
    numW = oC.width; 
    numH = oC.height; 
    console.log(numW+'-'+numH); 

    oGC.fillStyle="red"; 
    //oGC.fillRect(0,0,numW,100); 
    oGC.fillText(msg,numW,100); 
  } 
  function startFun(msg){ 
    doDraw(msg); 
    sId = setInterval(function(){    
      if (numW > -610) 
      { 
        numW--; 
        console.log(numW); 
        oGC.clearRect(0,0,oC.width,oC.height); 
        oGC.fillText(msg,numW,100); 
      } else { 
        oGC.clearRect(0,0,oC.width,oC.height); 
        clearInterval(sId); 
      } 
    },10);  
  } 
  </script> 
</body> 
</html> 

JQuery部分:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

$(document).ready(function() { 
 $(".shoot").on("click", startDanmu); 
 $("form").keypress(function(event) { 
 if (event.keyCode === 13) { 
  event.preventDefault(); 
  startDanmu(); 
 } 
 }); 
 $(".clear").on("click", clearDanmu); 
}); 

//get random number in certain range 
function RandomNum(Min, Max) { 
 var Range = Max - Min; 
 var Rand = Math.random(); 
 var num = Min + Math.round(Rand * Range); 
 return num; 
} 

//time number add 0 before if <10 
function plusZero(x) { 
 if (x < 10) { 
 x = "0" + x; 
 } else { 
 x = x; 
 } 
 return x; 
} 

//start danmu 
function startDanmu() { 

 var message = $("input"); 
 var messageVal = message.val(); 
 var danmuMessage = "" + messageVal + ""; 

 //get random color HEX 
 //u can also save the colors u want by array 
 var color = RandomNum(100000, 999999); 

 //get random danmu speed 
 var speed = RandomNum(10000, 20000); 

 //get random position Y 
 //danmu box height is 450, we set the danmu position Y max 400 in case it blocks the subtitle 
 var positionY = RandomNum(50, 400); 

 if (messageVal.length > 0) { 
 //insert danmu message into danmu box 
 $(".danmu-box").prepend(danmuMessage); 

 //have to use first() cuz we prepend the message, u can try what's gonna happen if no first() 
 //set it's style 
 $(".danmu-message").first().css({ 
  "right": "0", 
  "top": positionY, 
  "color": "#" + color 
 }); 

 //set it's animation 
 //from right 0 to left 0 
 //hide it after move 
 $(".danmu-message").first().animate({ 
  left: '0px', 
 }, 
 speed, 
 function() { 
  $(this).fadeOut(); 
 }); 
 //get danmu time 
 var time = new Date(); 
 var month = time.getMonth() + 1; 
 var day = time.getDay(); 
 var hour = time.getHours(); 
 var minute = time.getMinutes(); 
 var danmuTime = plusZero(month) + "-" + plusZero(day) + " " + plusZero(hour) + ":" + plusZero(minute); 

 //insert danmu message to table 
 if (messageVal.length > 6) { 
  messageVal = messageVal.substring(0, 6) + "..."; 
 } 
 var messageToTable = "<tr><td>" + messageVal + "</td><td>" + danmuTime + "</td></tr>"; 
 $(".danmu-table > tbody").prepend(messageToTable); 

 } else {} 

 //empty the input 
 message.val(""); 
} 

//clear danmu box 
function clearDanmu() { 
 $(".danmu-box").html(""); 
} 

您可能感兴趣的文章:

  • 终于实现了!精彩的jquery弹幕效果
  • 又一枚精彩的弹幕效果jQuery实现
  • 简单实现jQuery弹幕效果
  • jQuery实现的弹幕效果完整实例
  • 基于jquery实现弹幕效果
  • jQuery实现弹幕效果
  • 基于jQuery实现弹幕APP
  • JS实现的视频弹幕效果示例
  • 基于JavaScript实现弹幕特效
  • 简单实现JavaScript弹幕效果
  • jQuery实现的页面弹幕效果【测试可用】

DEMO在这儿,欢迎来FORK:Danmu APP。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

您可能感兴趣的文章:

  • 终于实现了!精彩的jquery弹幕效果
  • 又一枚精彩的弹幕效果jQuery实现
  • 简单实现jQuery弹幕效果
  • jQuery实现的弹幕效果完整实例
  • 基于jquery实现弹幕效果
  • JQuery和HTML5
    Canvas实现弹幕效果
  • jQuery实现弹幕效果
  • JS实现的视频弹幕效果示例
  • 基于JavaScript实现弹幕特效
  • 简单实现JavaScript弹幕效果
  • jQuery实现的页面弹幕效果【测试可用】