• 技术文章 >web前端 >H5教程

    HTML5 canvas如何实现代码流瀑布?(附代码)

    青灯夜游青灯夜游2020-06-17 10:30:58转载2188
    本篇文章给大家分享HTML5 canvas代码流瀑布的具体代码。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

    在js部分写canvas代码,有详细注释

    html部分:

    一个canvas元素:

    <canvas id="canvas" ></canvas>

    css部分:

    <style>
      *{
       padding: 0;
       margin: 0;
      }
      canvas{
       background-color: #111;
      }
      body{
       overflow: hidden;
      
      }
    </style>

    js部分

    <script>
      var canvas = document.getElementById('canvas');
      var context = canvas.getContext('2d');
      // 获取浏览器的宽度和高度
      var w = window.innerWidth;
      var h = window.innerHeight;
      // 设置canvas的宽高
      canvas.width = w;
      canvas.height = h;
      // 每个文字的大小
      var fontSize = 16;
      // 一共可以有多少列文字
      var col = Math.floor(w / fontSize);
      // 记录每列文字的y轴坐标
      var cpy = [];
      for(var i = 0;i< col; i++)
      {
       cpy[i] = 1;
      }
      //定义文字
      var str = "Javascriphafhsdhfsfsf{}";
      // 绘制
      draw();
      setInterval(draw,30);
      function draw(){
       context.beginPath();
       // 背景填充颜色
       context.fillStyle = "rgba(0,0,0,0.05)";
       context.fillRect(0,0,w,h);
       // 设置字体大小
       context.font = fontSize +"px bold 微软雅黑 ";
       // 设置字体颜色
       context.fillStyle = "#00cc33";
       for(var i = 0; i < col;i++)
       {
        var index = Math.floor(Math.random()*str.length);
        var x = i*fontSize;
        var y = cpy[i]*fontSize;
        context.fillText(str.charAt(index),x,y);
        if(y >= h && Math.random()> 0.99)// 出现时间延迟的效果
        {
         cpy[i]=0;// 只要Math.random> 0.99 时才纵坐标从0开始写字
        }
        cpy[i]++;// 数组值加一,以便下一次写的字在下面一行
       }
      }
    </script>

    动态效果图:

    1.gif

    更多炫酷特效,推荐访问:js特效大全

    以上就是HTML5 canvas如何实现代码流瀑布?(附代码)的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:csdn,如有侵犯,请联系admin@php.cn删除
    上一篇:meta标签的三要素是什么 下一篇:分享一些前端必备的Canvas接口和动画效果(大全)
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• HTML5 Canvas绘图之drawImage() 方法的详细介绍(代码示例)• canvas如何实现七巧板图案和粒子时钟效果?(代码示例)• 小程序用canvas绘制海报的做法• canvas实现雪花随机动态飘落效果(代码示例)
    1/1

    PHP中文网