HTML5 Canvas實現黑客帝國文字掉落效果

效果:canvas

原理:數組

  用canvas逐行輸出文字,而後讓背景顏色逐漸加深,再隨機中斷某些列。dom

代碼:spa

HTML:.net

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

CSS:code

canvas {display: block;}

JS:blog

var c = document.getElementById("c");
var ctx = c.getContext("2d");

//全屏
c.height = window.innerHeight;
c.width = window.innerWidth;

//文字
var txts = "0123456789";
//轉爲數組
txts = txts.split("");

var font_size = 16;
var columns = c.width/font_size; 
//用於計算輸出文字時座標,因此長度即爲列數
var drops = [];
//初始值
for(var x = 0; x < columns; x++)
    drops[x] = 1; 

//輸出文字
function draw()
{
    //讓背景逐漸由透明到不透明
    ctx.fillStyle = "rgba(0, 0, 0, 0.05)";
    ctx.fillRect(0, 0, c.width, c.height);
    
    ctx.fillStyle = "#0F0"; //文字顏色
    ctx.font = font_size + "px arial";
    //逐行輸出文字
    for(var i = 0; i < drops.length; i++)
    {
        //隨機取要輸出的文字
        var text = txts[Math.floor(Math.random()*txts.length)];
        //輸出文字,注意座標的計算
        ctx.fillText(text, i*font_size, drops[i]*font_size);
        
        //若是繪滿一屏或隨機數大於0.95(此數可自行調整,效果會不一樣)
        if(drops[i]*font_size > c.height || Math.random() > 0.95)
            drops[i] = 0;
        
        //用於Y軸座標增長
        drops[i]++;
    }
}

setInterval(draw, 33);
相關文章
相關標籤/搜索