骇客帝国

创建一个类似于《黑客帝国》的文字矩阵效果是一个有趣的项目。我们可以使用HTML5的Canvas API来实现这一效果。

设计说明:

  1. HTML结构:
    • 使用一个 canvas 元素 (id="matrixCanvas") 来绘制文字矩阵效果。
  2. CSS样式:
    • body 元素设置为无边距、无填充,并隐藏溢出内容。背景颜色设为黑色(#000)。
    • canvas 元素设置为块级元素,以确保它占据整个视口。
  3. 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

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注