HTML5 Canvas实现黑客帝国文字掉落效果
效果:
原理:
用canvas逐行输出文字,然后让背景颜色逐渐加深,再随机中断某些列。
代码:
HTML:
<canvas id="c"></canvas>
CSS:
canvas {display: block;}
JS:
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);

分类:
JavaScript
, 前端
标签:
canvas
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· 展开说说关于C#中ORM框架的用法!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?