黑客帝国代码雨H5效果


黑客帝国代码雨效果

黑客帝国代码雨效果

<canvas id="canvas" style="background:white" ></canvas>
<style type="text/css">
body{margin: 0; padding: 0; overflow: hidden;}
</style>
<script type="text/javascript">
window.onload = function(){
	//获取图形对象
	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 = 15;
	//计算列
	var colunms = Math.floor(W /fontSize);
	//记录每列文字的y轴坐标
	var drops = [];
	//给每一个文字初始化一个起始点的位置
	for(var i=0;i<colunms;i++){
		drops.push(0);
	}

	//运动的文字
	var str ="01abcdefghijklmnopqurstuvwxyz";
	//4:fillText(str,x,y);原理就是去更改y的坐标位置
	//绘画的函数
	function draw(){
		//让背景逐渐由透明到不透明
		context.fillStyle = "rgba(0,0,0,0.05)";
		context.fillRect(0,0,W,H);
		//给字体设置样式
		//context.font = "700 "+fontSize+"px 微软雅黑";
		context.font = fontSize + 'px arial';
		//给字体添加颜色
		context.fillStyle ="green";//随意更改字体颜色
		//写入图形中
		for(var i=0;i<colunms;i++){
			var index = Math.floor(Math.random() * str.length);
			var x = i*fontSize;
			var y = drops[i] *fontSize;
			context.fillText(str[index],x,y);
			//如果要改变时间,肯定就是改变每次他的起点
			if(y >= canvas.height && Math.random() > 0.92){
				drops[i] = 0;
			}
			drops[i]++;
		}
	};
	function randColor(){
		var r = Math.floor(Math.random() * 256);
		var g = Math.floor(Math.random() * 256);
		var b = Math.floor(Math.random() * 256);
		return "rgb("+r+","+g+","+b+")";
	}

	draw();
	setInterval(draw,33);

};

</script>



H5特效

2020.11.17 23:58

https://www.meihaocloud.com.com/1006.html , 欢迎转载,请在文章页标出原文连接 !


Copyright © 2020 千夕网 联系站长

粤公网安备 44030302001408号 粤ICP备19099833号-1