创建一个类似于《黑客帝国》的文字矩阵效果是一个有趣的项目。我们可以使用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