当前位置:Gxlcms > JavaScript > canvas 弹幕效果(实例分享)

canvas 弹幕效果(实例分享)

时间:2021-07-01 10:21:17 帮助过:26人阅读

话不多说,请看代码

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Document</title>
  6. </head>
  7. <body>
  8. <canvas style="width: 1280px;height: 720px;background-color: rgba(0,0,0,0.2)">你的浏览器不支持canvas</canvas>
  9. </body>
  10. <script src="http://www.jq22.com/jquery/jquery-1.10.2.js"></script>
  11. <script>
  12. (function ($) {
  13. function Barrager(dom) {
  14. this.canvas = dom.get(0);
  15. this.ctx = this.canvas.getContext("2d");
  16. this.msgs = new Array(300);//缓冲池,长度越大,屏幕上显示的就越多
  17. this.width = 1280;//canvas分辨率1280*720
  18. this.height = 720;
  19. this.canvas.width=this.width;//上边的两步可以省略,直接在这里赋值
  20. this.canvas.height=this.height;
  21. this.font = "30px 黑体";//字体和字体大小
  22. this.ctx.font=this.font;
  23. //颜色数组,在绘制过程中随机从这里取出颜色
  24. this.colorArr=["Olive","OliveDrab","Orange","OrangeRed","Orchid","PaleGoldenRod","PaleGreen","PaleTurquoise","PaleVioletRed","PapayaWhip","PeachPuff","Peru","Pink","Plum","PowderBlue","Purple","Red","RosyBrown","RoyalBlue","SaddleBrown","Salmon","SandyBrown","SeaGreen","SeaShell","Sienna","Silver","SkyBlue"];
  25. this.interval = "";
  26. this.draw = function () {//绘制方法
  27. if (this.interval != "")return;
  28. var _this=this;
  29. this.interval = setInterval(function () {//每隔20毫秒重新绘制一次,间隔最好小于40,要不然效果就跟播放图片差不多
  30. //1,清除屏幕
  31. _this.ctx.clearRect(0, 0, _this.width, _this.height);
  32. _this.ctx.save();
  33. //2,循环缓冲区域,把没有设置Left,Top,Speed,Color先赋值,赋值的就改变left值(产生移动效果),left值小于200就会从缓冲区移除
  34. for (var i = 0; i < _this.msgs.length; i++) {
  35. if (!(_this.msgs[i] == null || _this.msgs[i] == "" || typeof(_this.msgs[i]) == "undefined")) {
  36. if(_this.msgs[i].L==null || typeof(_this.msgs[i].L)=="undefined"){
  37. _this.msgs[i].L=_this.width;
  38. _this.msgs[i].T=parseInt(Math.random() * 700);
  39. _this.msgs[i].S=parseInt(Math.random() * (10 - 4) + 4);
  40. _this.msgs[i].C=_this.colorArr[Math.floor(Math.random() * _this.colorArr.length)];
  41. }else{
  42. if(_this.msgs[i].L<-200){
  43. _this.msgs[i]=null;
  44. }else {
  45. _this.msgs[i].L=parseInt(_this.msgs[i].L-_this.msgs[i].S);
  46. _this.ctx.fillStyle =_this.msgs[i].C;
  47. _this.ctx.fillText(_this.msgs[i].msg,_this.msgs[i].L,_this.msgs[i].T);
  48. _this.ctx.restore();
  49. }
  50. }
  51. }
  52. }
  53. }, 20);
  54. };
  55. //添加数据,数据格式[{"msg":"nihao"}]
  56. this.putMsg = function (datas) {//循环缓冲区,把位置是空的装填上数据
  57. for (var j = 0; j < datas.length; j++) {
  58. for (var i = 0; i < this.msgs.length; i++) {
  59. if (this.msgs[i] == null || this.msgs[i] == "" || typeof(this.msgs[i]) == "undefined") {
  60. this.msgs[i] = datas[j];
  61. break;
  62. }
  63. }
  64. }
  65. this.draw();
  66. };
  67. this.clear = function () {//清除定时器,清除屏幕,清空缓冲区
  68. clearInterval(this.interval);
  69. this.interval="";
  70. this.ctx.clearRect(0, 0, this.width, this.height);
  71. this.ctx.save();
  72. for(var i=0;i<this.msgs.length;i++){
  73. this.msgs[i]=null;
  74. }
  75. };
  76. }
  77. $.fn.barrager = function (para) {
  78. if (typeof(para)=="string") {
  79. try{
  80. var api = $(this).data('barrager_api');
  81. api[para].apply(api);
  82. }catch (e){}
  83. } else if (typeof para == 'object' || !para) {
  84. $this = $(this);
  85. if ($this.data('barrager_api') != null && $this.data('barrager_api') != ''){
  86. var api = $this.data('barrager_api');
  87. api.putMsg(para);
  88. }else{
  89. var api = new Barrager($this);
  90. $this.data('barrager_api', api);
  91. api.putMsg(para);
  92. }
  93. } else {
  94. $.error('Method ' + method + ' does not exist on jQuery.slidizle');
  95. }
  96. return this;
  97. }
  98. })(jQuery);
  99. </script>
  100. <script>
  101. // $('canvas').barrager([{"msg":"这是我发的。。。哈哈哈"}]);// 发送弹幕
  102. $('canvas').barrager([{"msg":"看着不错。。。。"},{"msg":"哈哈哈。。。。"},{"msg":"不错不错。。"},{"msg":"真好看。。。。"}]);//多条发送方式
  103. // $('canvas').barrager("clear"); //清除/关闭弹幕
  104. </script>
  105. </html>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持脚本之家!

人气教程排行