创建一个类似于《黑客帝国》的文字矩阵效果是一个有趣的项目。我们可以使用HTML5的Canvas API来实现这一效果。
设计说明:
- HTML结构:
- 使用一个
canvas元素 (id="matrixCanvas") 来绘制文字矩阵效果。
- 使用一个
- CSS样式:
body元素设置为无边距、无填充,并隐藏溢出内容。背景颜色设为黑色(#000)。canvas元素设置为块级元素,以确保它占据整个视口。
- JavaScript逻辑与交互:
- 获取
canvas元素并设置其宽度和高度为窗口的宽度和高度。 - 定义一个包含所有可能字符的字符串
characters,并将其转换为数组charArray。 - 设置字体大小
fontSize和列数columns。 - 初始化
drops数组,用于跟踪每一列的滴落位置。 drawMatrix()函数负责清除画布、绘制绿色的文字字符,并更新每一列的滴落位置。- 使用
requestAnimationFrame()实现平滑的动画效果。 - 添加窗口大小调整事件监听器,以确保
canvas尺寸随窗口变化而变化。
- 获取
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>骇客帝国文字矩阵效果</title>
<style>
body {
margin: 0;
padding: 0;
overflow: hidden;
background-color: black;
}
canvas {
display: block;
}
</style>
</head>
<body>
<canvas id="matrixCanvas"></canvas>
<script>
const canvas = document.getElementById('matrixCanvas');
const ctx = canvas.getContext('2d');
canvas.width = window.innerWidth;
canvas.height = window.innerHeight;
const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789@#$%^&*()_+[]{}|;:,.<>?';
const charArray = characters.split('');
const fontSize = 16;
const columns = Math.floor(canvas.width / fontSize);
const drops = [];
for (let i = 0; i < columns; i++) {
drops[i] = 1;
}
function drawMatrix() {
ctx.fillStyle = 'rgba(0, 0, 0, 0.05)';
ctx.fillRect(0, 0, canvas.width, canvas.height);
ctx.fillStyle = '#0F0'; // Green color
ctx.font = `${fontSize}px monospace`;
for (let i = 0; i < drops.length; i++) {
const text = charArray[Math.floor(Math.random() * charArray.length)];
ctx.fillText(text, i * fontSize, drops[i] * fontSize);
if (drops[i] * fontSize > canvas.height && Math.random() > 0.975) {
drops[i] = 0;
}
drops[i]++;
}
requestAnimationFrame(drawMatrix);
}
drawMatrix();
window.addEventListener('resize', () => {
canvas.width = window.innerWidth;
canvas.height = window.innerHeight;
});
</script>
</body>
</html>

No responses yet