码迷,mamicode.com
首页 > 其他好文 > 详细

黑客帝国特效

时间:2019-03-14 13:47:05      阅读:129      评论:0      收藏:0      [点我收藏+]

标签:back   ++   黑客   add   single   clear   and   loop   XML   

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>骇客帝国</title>
 
<style type="text/css">
/*basic reset*/
* {margin: 0; padding: 0;}
/*adding a black bg to the body to make things clearer*/
body {background: black;}
canvas {display: block;}
</style>
 
</head>
<body>
 
<canvas id="c"></canvas>
 
<script type="text/javascript">
var c = document.getElementById("c");
var ctx = c.getContext("2d");
 
//making the canvas full screen
c.height = window.innerHeight;
c.width = window.innerWidth;
 
//chinese characters - taken from the unicode charset
var chinese = "我真帅";
//converting the string into an array of single characters
chinese = chinese.split("");
 
var font_size = 10;
var columns = c.width / font_size; //number of columns for the rain
//an array of drops - one per column
var drops = [];
//x below is the x coordinate
//1 = y co-ordinate of the drop(same for every drop initially)
for (var x = 0; x < columns; x++)
    drops[x] = 1;
 
//drawing the characters
function draw() {
    //Black BG for the canvas
    //translucent BG to show trail
    ctx.fillStyle = "rgba(0, 0, 0, 0.05)";
    ctx.fillRect(0, 0, c.width, c.height);
 
    ctx.fillStyle = "#0F0"; //green text
    ctx.font = font_size + "px arial";
    //looping over drops
    for (var i = 0; i < drops.length; i++) {
        //a random chinese character to print
        var text = chinese[Math.floor(Math.random() * chinese.length)];
        //x = i*font_size, y = value of drops[i]*font_size
        ctx.fillText(text, i * font_size, drops[i] * font_size);
 
        //sending the drop back to the top randomly after it has crossed the screen
        //adding a randomness to the reset to make the drops scattered on the Y axis
        if (drops[i] * font_size > c.height && Math.random() > 0.975)
            drops[i] = 0;
 
        //incrementing Y coordinate
        drops[i]++;
    }
}
 
setInterval(draw, 50);
</script>
 
</body>
</html>

 

黑客帝国特效

标签:back   ++   黑客   add   single   clear   and   loop   XML   

原文地址:https://www.cnblogs.com/Leslie-Cheung1584304774/p/10529410.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!