鱼C论坛

 找回密码
 立即注册
查看: 77|回复: 4

[资源分享] html-蛆

[复制链接]
发表于 2024-5-24 11:15:36 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
  <TITLE> New Document </TITLE>
  <META NAME="Generator" CONTENT="EditPlus">
  <META NAME="Author" CONTENT="">
  <META NAME="Keywords" CONTENT="">
  <META NAME="Description" CONTENT="">
  <style>
  body, html {
        position: absolute;
        margin: 0;
        padding: 0;
        width: 100%;
        height: 100%;
        overflow: hidden;
}

canvas {
        position: absolute;
        width: 100%;
        height: 100%;
        background: #000;
        cursor: pointer;
}
#node {
        display: none;
}
  </style>
</HEAD>

<BODY>
  <img id="node" src="" alt="">
  <script>
  "use strict";
{
        const Tentacle = class {
                constructor() {
                        this.length = 40 + Math.round(80 * Math.random());
                        this.vel = 2;
                        this.amp = 0.2 + 0.4 * Math.random();
                        this.freq = 0.05 + 0.3 * Math.random();
                        this.dir = 2 * Math.PI * Math.random();
                        this.frame = 0;
                        this.free = true;
                        this.vDir = 0;
                        this.nodes = [];
                        for (let i = 0; i < this.length; i++) {
                                this.nodes.push(
                                        new Tentacle.Node(
                                                this,
                                                i,
                                                canvas.width * Math.random(),
                                                canvas.height * Math.random()
                                        )
                                );
                        }
                }
                move() {
                        const head = this.nodes[0];
                        if (head.x > canvas.width) {
                                head.x--;
                                this.dir += 0.1;
                        } else if (head.x < 0) {
                                head.x++;
                                this.dir += 0.1;
                        }
                        if (head.y > canvas.height) {
                                head.y--;
                                this.dir += 0.1;
                        } else if (head.y < 0) {
                                head.y++;
                                this.dir += 0.1;
                        }
                        const dx = pointer.x - head.x;
                        const dy = pointer.y - head.y;
                        const dist = Math.sqrt(dx * dx + dy * dy);
                        if (dist < 300) {
                                if (this.free) {
                                        this.dir = Math.atan2(dy, dx);
                                        this.vel = 1 + dist * 0.1;
                                        if (dist < 1) {
                                                this.free = false;
                                        }
                                }
                        } else {
                                this.vel = 2;
                                this.free = true;
                        }
                        this.vDir += 0.05 * (Math.random() - Math.random());
                        this.dir += this.vDir;
                        this.vDir *= 0.9;
                        head.x += this.vel * Math.cos(this.dir);
                        head.y += this.vel * Math.sin(this.dir);
                        this.frame += this.freq;
                        const iDir = this.amp * Math.cos(this.frame);
                        const iHead = this.nodes[1];
                        iHead.x = head.x - this.vel * Math.cos(this.dir + iDir);
                        iHead.y = head.y - this.vel * Math.sin(this.dir + iDir);
                        for (let i = 2; i < this.length; i++) {
                                this.nodes[i].move();
                        }
                }
        };
        Tentacle.Node = class {
                constructor(tentacle, i, x, y) {
                        this.tentacle = tentacle;
                        const s = tentacle.length - i;
                        this.prev = i > 0 ? tentacle.nodes[i - 1] : null;
                        this.pprev = i > 1 ? tentacle.nodes[i - 2] : null;
                        this.size = 6 + s * s / tentacle.length;
                        this.x = x;
                        this.y = y;
                        this.a = 0;
                        this.img = document.getElementById("node");
                }
                move() {
                        const dx = this.x - this.pprev.x;
                        const dy = this.y - this.pprev.y;
                        this.a = Math.atan2(dy, dx);
                        const d = Math.sqrt(dx * dx + dy * dy);
                        this.x = this.prev.x + dx * 10 / d;
                        this.y = this.prev.y + dy * 10 / d;
                        ctx.save();
                        ctx.translate(this.x, this.y);
                        ctx.rotate(this.a + 0.4);
                        ctx.drawImage(
                                this.img,
                                -this.size * 0.5,
                                -this.size * 0.5,
                                this.size,
                                this.size
                        );
                        ctx.restore();
                }
        };
        const canvas = {
                init() {
                        this.elem = document.createElement("canvas");
                        document.body.appendChild(this.elem);
                        this.resize();
                        window.addEventListener("resize", () => this.resize(), false);
                        return this.elem.getContext("2d");
                },
                resize() {
                        this.width = this.elem.width = this.elem.offsetWidth;
                        this.height = this.elem.height = this.elem.offsetHeight;
                }
        };
        const pointer = {
                init(canvas) {
                        this.x = -1000;
                        this.y = 0;
                        ["mousemove", "touchstart", "touchmove"].forEach((event, touch) => {
                                document.addEventListener(
                                        event,
                                        e => {
                                                if (touch) {
                                                        e.preventDefault();
                                                        this.x = e.targetTouches[0].clientX;
                                                        this.y = e.targetTouches[0].clientY;
                                                } else {
                                                        this.x = e.clientX;
                                                        this.y = e.clientY;
                                                }
                                        },
                                        false
                                );
                        });
                }
        };
        const ctx = canvas.init();
        pointer.init(canvas);
        const tentacles = [];
        for (let i = 0; i < 12; i++) tentacles.push(new Tentacle());
        const run = () => {
                requestAnimationFrame(run);
                ctx.clearRect(0, 0, canvas.width, canvas.height);
                for (const tentacle of tentacles) {
                        tentacle.move();
                }
        };
        run();
}

  </script>
</BODY>
</HTML>


想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-5-24 11:15:59 | 显示全部楼层
这段代码是一个使用HTML5 canvas实现的动画效果,可以看到一些随机运动的触角在屏幕上移动。以下是对代码的解释:

首先是HTML部分:
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Tentacle</title>
    <style>
        body, html {
            position: absolute;
            margin: 0;
            padding: 0;
            width: 100%;
            height: 100%;
            overflow: hidden;
        }
        
        canvas {
            position: absolute;
            width: 100%;
            height: 100%;
            background: #000;
            cursor: pointer;
        }
    </style>
</head>
<body>
    <canvas id="canvas"></canvas>
    <img src="node.png" id="node" hidden>
    <script src="tentacle.js"></script>
</body>
</html>
以上是HTML部分,创建了一个canvas元素,用于绘制动画效果。同时引入了tentacle.js脚本文件。

接下来是JavaScript部分(tentacle.js):
"use strict";
{
    const Tentacle = class {
        constructor() {
            // 构造函数,初始化一些属性
        }
        move() {
            // 移动
        }
    };

    Tentacle.Node = class {
        constructor(tentacle, i, x, y) {
            // 构造函数,初始化一些属性
        }
        move() {
            // 移动
        }
    };

    const canvas = {
        // 初始化canvas元素
    };

    const pointer = {
        // 初始化鼠标/触摸事件监听
    };

    const ctx = canvas.init();
    pointer.init(canvas);
    const tentacles = [];
    for (let i = 0; i < 12; i++) tentacles.push(new Tentacle());

    // 动画循环
    const run = () => {
        requestAnimationFrame(run);
        ctx.clearRect(0, 0, canvas.width, canvas.height);
        for (const tentacle of tentacles) {
            tentacle.move();
        }
    };
    run();
}
以上是核心的JavaScript部分,定义了两个类:Tentacle和Tentacle.Node,以及一些方法用于初始化canvas和鼠标/触摸事件监听。然后创建了12个Tentacle对象,并在动画循环中依次调用它们的move方法进行移动。

如果你想要尝试运行这段代码,需要将其中的`<img src="node.png" id="node" hidden>`部分修改为正确的图片路径,并将整个代码保存为HTML文件,然后通过浏览器打开即可看到动画效果。

希望这样能够帮助到你!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-5-24 18:28:40 | 显示全部楼层
这是啥?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 4 天前 | 显示全部楼层

复制运行看看
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 3 天前 | 显示全部楼层
屏幕截图 2024-06-14 001759.png

哇趣,有点厉害!!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-6-17 01:12

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表