验证码: 看不清楚,换一张 查询 注册会员,免验证
  • {{ basic.site_slogan }}
  • 打开微信扫一扫,
    您还可以在这里找到我们哟

    关注我们

怎么使用canvas制作炫酷黑客帝国数字雨背景

阅读:1143 来源:乙速云 作者:代码code

怎么使用canvas制作炫酷黑客帝国数字雨背景

制作:

1.定义canvas标签:

2.开始js部分,先定义变量:

         /* 获取画布 */
        var canvas = document.querySelector("#canvas");
        var ctx = canvas.getContext('2d');
        /* 定义一个字符串数组,后面字符串会从里随机选值 */
        var text = "SAFAF1D56FLK43F7PHM76VC9XNJL23";
        /* 定义 w为窗口宽度,h为窗体高度 */
        var w=window.innerWidth;
        var h=window.innerHeight;
        /* 设置len为20,其为背景里每条字符串的长度 */
        var len = 20;
        /* 设置num为100,窗口一共显示100条字符串 */
        var num = 100;
        /* 定义数组,里面存取每条字符串的字符与位置 */
        var arr=[];
        /* 画布宽等于窗口宽 */
        canvas.width=window.innerWidth;
        /* 画布高等于窗口高 */
        canvas.height=window.innerHeight;

3.初始化字符串数组,先给每条字符串位置,字符先不给:

 /* 初始化字符串数组 */
         for(let i=0;i

4.绘制每条字符串:

 /* 绘制每条字符串 */
        function txt(){
            /* 给个循环,共绘制num条 */
            for(let i=0;i

5.更新字符串:

 /* 让字符串移动,若某字符串出了可视区,则重新生成 */
        function move(){
            /* 来个循环,给全部字符串更新位置 */
            for(let j=0;j=h){
                    arr[j]={
                        str:[],
                 x: parseInt(w*Math.random()),
                 y: parseInt(h*Math.random()-150)
                    }
                }
            }
        }

6.设置动画过程:

 setInterval(function(){
             /* 清屏 */
            ctx.clearRect(0,0,w,h);
            /* 渲染 */
            move();
            /* 更新 */
            txt();
         },50);

7.在窗口大小改变时,设置canvas画布能实时铺满屏幕:

/* 绑定窗口大小发生改变事件,重新绘制字符串数组,让canvas随时铺满浏览器可视区 */
        window.onresize=resizeCanvas;
        function resizeCanvas(){
            w=canvas.width=window.innerWidth;
            h=canvas.height=window.innerHeight;
            /* 重新给全部字符串赋值 */
            for(let j=0;j

完整代码:




    
    
    
    Document
    


    

北极光之夜。

         
分享到:
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: hlamps#outlook.com (#换成@)。
相关文章
{{ v.title }}
{{ v.description||(cleanHtml(v.content)).substr(0,100)+'···' }}
你可能感兴趣
推荐阅读 更多>