在这里插入图片描述

<!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;background-color: #000;display: flex;justify-content: center;align-items: center;height: 100vh;overflow: hidden;font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;}.container {position: relative;width: 100%;max-width: 900px;text-align: center;}canvas {background-color: black;border-radius: 8px;box-shadow: 0 0 20px rgba(0, 100, 255, 0.3);}.title {color: rgba(255, 255, 255, 0.85);margin-bottom: 20px;font-size: 2.2rem;text-shadow: 0 0 10px rgba(0, 150, 255, 0.8);letter-spacing: 1.5px;}.description {color: rgba(200, 220, 255, 0.7);max-width: 600px;margin: 20px auto;font-size: 1.1rem;line-height: 1.6;}.controls {margin: 20px 0;}.control-btn {background: rgba(30, 60, 120, 0.7);color: white;border: none;padding: 10px 20px;margin: 0 10px;border-radius: 4px;cursor: pointer;font-size: 1rem;transition: all 0.3s ease;outline: none;}.control-btn:hover {background: rgba(50, 100, 200, 0.9);transform: translateY(-2px);box-shadow: 0 5px 15px rgba(0, 100, 255, 0.4);}.footer {color: rgba(150, 180, 220, 0.6);margin-top: 25px;font-size: 0.9rem;}</style>
</head>
<body><div class="container"><h1 class="title">数学粒子动画</h1><canvas id="particleCanvas" width="900" height="900"></canvas><div class="description">这个动画展示了10,000个粒子按照复杂的数学公式运动。每个粒子的位置由三角函数的组合计算得出,创造出令人着迷的视觉效果。</div><div class="controls"><button id="pauseBtn" class="control-btn">暂停</button><button id="resetBtn" class="control-btn">重置</button><button id="speedUpBtn" class="control-btn">加速</button><button id="slowDownBtn" class="control-btn">减速</button></div><div class="footer">HTML5 Canvas实现 | 数学公式驱动的艺术</div></div><script>// 获取Canvas元素和上下文const canvas = document.getElementById('particleCanvas');const ctx = canvas.getContext('2d');// 粒子数组const particles = [];const numParticles = 10000;// 时间变量和速度控制let t = 0;let animationSpeed = 1;let isPaused = false;// 初始化粒子function initParticles() {particles.length = 0;for (let i = 0; i <= numParticles; i++) {const x = i % 200;const y = i / 43;const k = 5 * Math.cos(x / 14) * Math.cos(y / 30);const e = y / 8 - 13;const d = (k * k + e * e) / 59 + 4;const a = Math.atan2(k, e);particles.push({k, e, d, a,x: 0, // 将在更新时计算y: 0  // 将在更新时计算});}}// 更新粒子位置function updateParticles() {t += Math.PI / 20 * animationSpeed;for (let i = 0; i < particles.length; i++) {const p = particles[i];const q = 60 - 3 * Math.sin(p.a * p.e) + p.k * (3 + 4 / p.d * Math.sin(p.d * p.d - t * 2));const c = p.d / 2 + p.e / 99 - t / 18;p.x = q * Math.sin(c) + 200;p.y = (q + p.d * 9) * Math.cos(c) + 200;}}// 绘制粒子function drawParticles() {ctx.fillStyle = 'rgba(0, 0, 0, 0.15)';ctx.fillRect(0, 0, canvas.width, canvas.height);for (let i = 0; i < particles.length; i++) {const p = particles[i];// 根据位置计算颜色const colorValue = Math.floor(150 + 100 * Math.sin(t/5 + p.x/50));ctx.fillStyle = `rgba(150, ${colorValue}, 255, 0.4)`;ctx.beginPath();ctx.arc(p.x, p.y, 1.2, 0, Math.PI * 2);ctx.fill();}}// 动画循环function animate() {if (!isPaused) {updateParticles();drawParticles();}requestAnimationFrame(animate);}// 事件监听器document.getElementById('pauseBtn').addEventListener('click', function() {isPaused = !isPaused;this.textContent = isPaused ? '继续' : '暂停';});document.getElementById('resetBtn').addEventListener('click', function() {t = 0;animationSpeed = 1;initParticles();});document.getElementById('speedUpBtn').addEventListener('click', function() {animationSpeed = Math.min(animationSpeed + 0.5, 5);});document.getElementById('slowDownBtn').addEventListener('click', function() {animationSpeed = Math.max(animationSpeed - 0.5, 0.5);});// 初始化并开始动画initParticles();animate();</script>
</body>
</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/88209.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/88209.shtml
英文地址,请注明出处:http://en.pswp.cn/diannao/88209.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SQLite3 在嵌入式系统中的应用指南

SQLite3 在嵌入式系统中的应用指南 一、嵌入式系统中 SQLite3 的优势 SQLite3 是嵌入式系统的理想数据库解决方案&#xff0c;具有以下核心优势&#xff1a; 特性嵌入式系统价值典型指标轻量级适合资源受限环境库大小&#xff1a;500-700KB零配置无需数据库管理员开箱即用无…

通义大模型与现有企业系统集成实战《CRM案例分析与安全最佳实践》

1. 集成架构设计 &#xff08;1&#xff09;混合部署架构演进 #mermaid-svg-eW4YPoU2fdbnT4xp {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-eW4YPoU2fdbnT4xp .error-icon{fill:#552222;}#mermaid-svg-eW4YPoU2f…

leetcode:746. 使用最小花费爬楼梯

学习要点 动态规划正着推动态规划倒着推理解递归在动态规划与纯递归的类比分析中体会两者各自的特点 题目链接 746. 使用最小花费爬楼梯 - 力扣&#xff08;LeetCode&#xff09; 题目描述 解法1&#xff1a;动态规划倒着推 // dp[i]--->从第i阶楼梯到达楼顶最小花费int…

汽车毫米波雷达增强感知:基于相干扩展和高级 IAA 的超分辨率距离和角度估计.

重庆西南大学毫米波雷达团队在IEEE Transactions on Consumer Electronics 上发表的一篇论文&#xff1a;《基于相干扩展和高级 IAA 的超分辨率距离和角度估计》。 本文深入研究了毫米波&#xff08;mmWave&#xff09;调频连续波雷达距离和角度的超分辨问题。首先&#xff0c;…

软件更新 | 从数据到模型,全面升级!TSMaster新版助力汽车研发新突破

为满足汽车电子开发领域日益增长的测试与仿真需求&#xff0c;TSMaster最新版本聚焦实车数据采集、MBD智能建模与新API扩展三大核心功能。无论您是进行车载网络测试、ECU开发还是自动化验证&#xff0c;新版本都能为您提供更高效、更可靠的解决方案&#xff01; TSMaster 2025.…

PDF-XSS

前言&#xff1a; PDF文件是一种复杂的文档格式&#xff0c;由一系列对象组成&#xff0c;包括字体、图像、页面内容等。PDF文件支持嵌入JavaScript代码&#xff0c;这使得PDF文件不仅可以显示静态内容&#xff0c;还可以执行动态操作。这种特性被攻击者利用来嵌入恶意脚本代码…

MySQL 表关联关系详解

MySQL 表关联关系详解 本文档详细列举了MySQL中常见的表关联关系场景以及对应的SQL语句示例。 1. 一对一关系 (One-to-One) 场景&#xff1a;用户表和用户详情表 一个用户对应一个用户详情通常用于将大表拆分&#xff0c;提高查询性能 -- 创建用户表 CREATE TABLE users (…

kubernetes(k8s)集群部署(超详细)

k8s部署 kubernetes集群图例kubernetes 安装仓库初始化1、创建云主机2、初始化私有仓库kube-master安装1、防火墙相关配置2、配置yum仓库(跳板机)3、安装软件包(master)4、镜像导入私有仓库5、Tab键设置6、安装代理软件包7、配置内核参数8、使用kubeadm部署9、验证安装结果计算…

「Flink」算子主要方法介绍

背景&#xff1a; 上期文章主要讲了Flink项目搭建的一些方法&#xff0c;其中对于数据流的处理很大一部分是通过算子来进行计算和处理的&#xff0c;算子也是Flink中功能非常庞大&#xff0c;且很重要的一部分。 算子介绍&#xff1a; 算子在Flink的开发者文档中是这样介绍的…

3405. 统计恰好有 K 个相等相邻元素的数组数目

3405. 统计恰好有 K 个相等相邻元素的数组数目 给你三个整数 n &#xff0c;m &#xff0c;k 。长度为 n 的 好数组 arr 定义如下&#xff1a; arr 中每个元素都在 闭 区间 [1, m] 中。恰好 有 k 个下标 i &#xff08;其中 1 < i < n&#xff09;满足 arr[i - 1] arr…

Spring AI 项目实战(十):Spring Boot + AI + DeepSeek 构建智能合同分析技术实践(附完整源码)

系列文章 序号文章名称1Spring AI 项目实战(一):Spring AI 核心模块入门2Spring AI 项目实战(二):Spring Boot + AI + DeepSeek 深度实战(附完整源码)3Spring AI 项目实战(三):Spring Boot + AI + DeepSeek 打造智能客服系统(附完整源码)4

impala中时间戳转(DATE)指定格式的字符串

注意i&#xff1a;注意大小写 timestamp\date–>string SELECT now(),from_timestamp(now(),yyyyMMdd);string->timestamp SELECT 20230710,to_timestamp(20230710,yyyyMMdd);日期加减 select 20231201,from_timestamp(date_add(to_timestamp(20231201,yyyyMMdd),1),…

百度下拉框出词技术解密:72小时出下拉词软件原理分享

如何才能刷下拉词&#xff1f;这个问题一直是企业做流量时最纠结的问题&#xff0c;百度下拉词作为百度搜索体验中的一项智能化功能&#xff0c;极大地方便了用户快速完成搜索&#xff0c;也成为了企业在搜索引擎优化&#xff08;SEO&#xff09;策略中的重要流量入口。通过研究…

上海人工智能实验室明珠湖会议首开,解答AI前沿疑问,推进科学智能

在通用人工智能&#xff08;AGI&#xff09;探索如火如荼的当下&#xff0c;如何加速突破&#xff1f;如何凝练关键问题、孕育颠覆性创新&#xff1f;2025年6月13日&#xff0c;上海人工智能实验室主任、首席科学家&#xff0c;清华大学惠妍讲席教授周伯文在首届明珠湖会议&…

BeyondCompare安装(永久免费使用+全网最详细版)

一.下载&#xff1a; 官网下载&#xff08;速度较慢&#xff09;&#xff1a; https://www.scootersoftware.com/download.php 阿里云盘&#xff08;不限速&#xff09; https://www.alipan.com/s/WaG1z54BQ2U 二.安装&#xff08;无脑下一步即可&#xff09; 三.永久免费…

如何用AI开发完整的小程序<7>—让AI微调UI排版

上一节我们介绍了如何让AI修改整体UI视觉效果。 不过有时候AI调整的并不理想&#xff0c;一些UI的布局还是需要微调。 比如已经实现的这个开始页面&#xff0c;我觉得标题太高了&#xff0c;这时候可以自己调&#xff0c;也可以让AI单独调&#xff0c;下面详细介绍。 一、手动…

64-Oracle Redo Log

小伙伴们&#xff0c;关于数据库的redo log相信大家都操作很多次了,且这是OCM考试必考内容。Oracle Redo Log是一种特殊的日志文件&#xff0c;用于完整地记录数据库中所有数据变更的详细信息。当数据库执行插如、更新或删除等更新操作&#xff0c;这些操作并不会立刻写入数据库…

hive集群优化和治理常见的问题答案

Hive 集群优化与治理常见问题答案合集 &#x1f42d;1. Q&#xff1a;Hive中如何优化大表Join操作&#xff1f; A&#xff1a; 使用Map Join&#xff08;小表Join大表时&#xff09;避免Reduce阶段。启用自动Map Join&#xff08;设置hive.auto.convert.jointrue&#xff09;…

C#采集电脑硬件(CPU、GPU、硬盘、内存等)温度和使用状况

这是采集出来的Json&#xff0c;部分电脑&#xff08;特别是笔记本&#xff09;无法获取到&#xff1a; {"HardwareList": [{"Name": "MITX-6999","Type": "主板","Sensors": [],"WmiReport": null}, …

C3新增特性

✅ 一、选择器&#xff08;Selectors&#xff09; 1. 属性选择器 [attr^value]: 匹配属性值以特定字符串开头的元素。[attr$value]: 匹配属性值以特定字符串结尾的元素。[attr*value]: 匹配属性值包含特定字符串的元素。 2. 子元素和兄弟元素选择器 :nth-child(n): 匹配父元…