当前位置: 首页 > article >正文

从土星到太阳系:两个Three.js项目的调试手记

缘起最近用Three.js写了两个小项目一个是土星粒子环一个是完整的太阳系。本来只是自己玩没想到调试过程还挺有意思记录一下遇到的一些问题和解法。项目一开普勒土星粒子环第一个想法很简单做一个土星核心是粒子球周围是旋转的粒子环粒子运动要符合开普勒定律。遇到的问题**1. 粒子太规整了**一开始粒子环匀速转看起来像旋转木马不像行星环。开普勒定律说离中心越远速度越慢所以给每个粒子设置了不同的速度因子speedFactor 0.6 / Math.pow(r, 0.5)。**2. 滚轮缩放时的亮度变化**需求是小暗大亮也就是拉近看时要更亮。这个用uniform传递缩放因子到着色器在片元着色器里乘到颜色上就行。**3. 近距混沌效果**当粒子放大到快出屏幕时要叠加无规则噪点。问题是怎么判断快到屏幕边缘最后用相机距离判断当zoomFactor 1.6时混沌强度 (zoomFactor - 1.6) * 3.5。噪声用正弦余弦组合虽然不真正随机但视觉效果够用了。项目二可行走的太阳系有了土星的经验想做个更大的整个太阳系还能站在星球表面走。踩过的坑**1. 星球表面行走的算法**这个想了很久。用经纬度是最简单的方案- 纬度(-90~90)经度(0~360)- 球面坐标转笛卡尔x r*cos(lat)*cos(lon), y r*sin(lat), z r*cos(lat)*sin(lon)- W前时lat speed*cos(yaw), lon speed*sin(yaw)**2. WASD没反应**写完了发现按W没动检查发现- 移动速度设成了0.02太慢了改成0.5才感觉到- 没加event.preventDefault()页面滚动把事件吞了**3. 星球材质太单调**用Canvas动态生成纹理- 岩质行星加随机噪点- 气态行星画水平条纹- 地球简单画几块绿色代表大陆- 月球画明暗圆环模拟坑洞虽然比不上真实纹理但至少能区分出不同星球了。**4. 性能问题**一开始星星设了10000个行星分段数48阴影2048结果掉帧严重。降到2000星星、24分段、512阴影流畅多了。肉眼其实看不出差别。**5. ESC退出**按ESC时没有退出星球视角。加了个监听if (event.code Escape isPlanetView) exitPlanetView()。## 一些有用的代码片段**球面行走核心**javascriptfunction updateSurfacePosition() {if (moveState.forward) {latitude moveSpeed * Math.cos(yaw)longitude moveSpeed * Math.sin(yaw)}// ... 其他方向// 转笛卡尔坐标const surfaceOffset new THREE.Vector3(radius * Math.cos(latRad) * Math.cos(lonRad),radius * Math.sin(latRad),radius * Math.cos(latRad) * Math.sin(lonRad))camera.position.copy(planetPos.clone().add(surfaceOffset))}**简单的纹理生成**javascriptfunction createGasTexture(baseColor) {const canvas document.createElement(canvas)// 画条纹...return new THREE.CanvasTexture(canvas)}小结这两个项目没用什么高级技术就是Three.js基础API加一些数学计算。主要工作是1. 把需求拆解成具体的算法开普勒定律、球面行走2. 遇到问题先看控制台再看事件有没有被拦截3. 性能不够就降配置往往看不出差别代码都在上面了有兴趣的可以跑跑看。有问题欢迎交流

相关文章:

从土星到太阳系:两个Three.js项目的调试手记

缘起最近用Three.js写了两个小项目:一个是土星粒子环,一个是完整的太阳系。本来只是自己玩,没想到调试过程还挺有意思,记录一下遇到的一些问题和解法。项目一:开普勒土星粒子环第一个想法很简单:做一个土星…...

5步掌握QtScrcpy按键映射:从零到精通的完整配置指南

5步掌握QtScrcpy按键映射:从零到精通的完整配置指南 【免费下载链接】QtScrcpy Android实时投屏软件,此应用程序提供USB(或通过TCP/IP)连接的Android设备的显示和控制。它不需要任何root访问权限 项目地址: https://gitcode.com/barry-ran/QtScrcpy …...

Unity Addressables 本地资源组热更新问题分析与解决方案:Prevent Updates 的正确使用

Unity Addressables 本地资源组热更新问题分析与解决方案:Prevent Updates 的正确使用 问题描述 在使用 Addressables 进行资源管理时,同时配置了本地资源组和远程资源组。首次打包运行正常。当两个资源组均有改动,并对远程资源组执行 Update…...

树莓派三、控制四轮小车运动(ing)

1.硬件配置树莓派3b、两个L298N、双层车架、四个麦轮、四个TT马达2.接线2.1 L298N和马达这部分除了同一侧的轮子接同一个电机驱动外,其余接的比较随意,因为是四驱,到时候调代码能够统一转动方向。2.2 L298N和电源两个L298N和树莓派都要共地&a…...

告别‘夜盲症’:手把手教你用MFNet和热成像数据提升自动驾驶夜间语义分割精度

夜间自动驾驶的视觉革命:基于MFNet与热成像的语义分割实战指南 当一辆自动驾驶汽车在暴雨夜驶过无路灯的乡间公路时,传统摄像头捕捉到的画面几乎是一片模糊的灰色噪点。这正是2017年MFNet论文揭示的核心问题:单一可见光谱传感器在低照度环境下…...

电源PFC入门:TI单相三相维也纳VIENNA整流器无桥原理图及PCB资料与PFC设计案例汇编

电源PFC入门 TI单相三相维也纳VIENNA整流器无桥 原理图PCB资料 一个PFC设计案例,大量的PFC相关的资料。 注意:设计案例无核心小板。电源设计里PFC总像个磨人的小妖精,尤其是做工业级大功率设备的时候。最近折腾TI的维也纳整流器方案发现&…...

Swin2SR案例实录:一张512px图片的完整增强旅程

Swin2SR案例实录:一张512px图片的完整增强旅程 1. 引言:当模糊小图遇见AI显微镜 你有没有遇到过这种情况?在网上找到一张特别喜欢的图片,想用来做壁纸或者打印出来,结果发现它只有512像素宽,放大一看全是…...

BLE跨平台抽象层设计:低功耗蓝牙中间件工程实践

1. BLE模块技术解析:跨平台低功耗蓝牙抽象层设计与工程实践1.1 模块定位与工程价值BLE(Bluetooth Low Energy)模块并非具体硬件驱动,而是一个跨平台、分层抽象的软件中间件,其核心目标是屏蔽底层蓝牙协议栈实现差异&am…...

如何用OCAT轻松搞定OpenCore配置:黑苹果新手终极指南

如何用OCAT轻松搞定OpenCore配置:黑苹果新手终极指南 【免费下载链接】OCAuxiliaryTools Cross-platform GUI management tools for OpenCore(OCAT) 项目地址: https://gitcode.com/gh_mirrors/oc/OCAuxiliaryTools OpenCore配置工具O…...

Qwen3-32B-Chat效果展示:中文法律条款解读与合同风险点识别真实案例

Qwen3-32B-Chat效果展示:中文法律条款解读与合同风险点识别真实案例 1. 法律AI的突破性应用 在法律服务领域,AI技术正带来革命性变化。Qwen3-32B-Chat作为当前最先进的中文大模型之一,在法律文本处理方面展现出惊人的理解能力。基于RTX4090…...

别再裸写Delay!C语言RTOS移植必做的4层抽象重构:硬件驱动→BSP→HAL OS Wrapper→POSIX兼容层(已落地12个工业项目)

第一章:裸写Delay的陷阱与RTOS移植的认知革命 在资源受限的嵌入式系统中,初学者常以裸机方式实现毫秒级延时:通过循环计数或SysTick中断累加变量。这种看似简洁的 delay_ms() 实际埋下严重隐患——它阻塞整个CPU,使中断响应延迟不…...

09年408真题解析6~10题

选B:选A。I 每条边贡献2度。II 边数最少n-1,最多n(n-1)/2,大于等于III 可以没有选D,D是B树选A。 冒泡排序: 从左到右两两相邻比较,如果左边 > 右边就交换,每一轮把当前…...

微电网主从控制孤岛-并网平滑切换策略分析及实现:VF孤岛控制、PQ并网控制及其他常见问题归纳...

微电网(两台)主从控制孤岛-并网平滑切换的分析。 分析了: 1.孤岛下VF控制 2.并网下PQ控制 3.孤岛下主从控制 4.孤岛到并网的平滑切换控制 5.除模型外还对分布式发电与主动配电网一些常见问题做了归纳。 包括:matlab201…...

Clawdbot部署Qwen3:32B实战体验:搭建监控AI代理平台如此简单

Clawdbot部署Qwen3:32B实战体验:搭建监控AI代理平台如此简单 1. 为什么选择Clawdbot管理Qwen3:32B 在AI代理开发领域,模型部署与管理一直是技术团队面临的痛点。传统方式需要开发者手动处理API对接、负载均衡、监控告警等一系列复杂操作。而Clawdbot的…...

Qwen3-ASR-1.7B效果展示:电话客服录音(低码率AMR)识别质量实测

Qwen3-ASR-1.7B效果展示:电话客服录音(低码率AMR)识别质量实测 电话客服录音识别一直是语音技术的难点,低码率AMR格式更是增加了识别难度。本文将实测Qwen3-ASR-1.7B在这一场景下的表现,看看这个17亿参数的大模型能否应…...

BN层在神经网络中的实战应用:为什么Conv+BN+ReLU是黄金组合?

BN层在神经网络中的实战应用:为什么ConvBNReLU是黄金组合? 当你在深夜调试神经网络时,是否遇到过这样的场景:模型训练初期loss下降很快,但突然陷入停滞;或者小心翼翼地调整学习率,稍大就梯度爆炸…...

AI大模型帮助快速掌握百万字小说梗概--以凡人修仙传为例

这是一篇为您整理好的CSDN博客文章。我对您提供的原始素材进行了梳理、润色和适度扩写,使其逻辑更清晰、语言更流畅,更符合一篇技术/经验分享类博客的发布标准。AI大模型助我高效“啃”完百万字巨著:以《凡人修仙传》为例 你是否也曾面对书架…...

MATLAB机械臂轨迹规划实战:三次多项式插值从入门到精通

MATLAB机械臂轨迹规划实战:三次多项式插值从入门到精通 机械臂的精准控制一直是工业自动化与机器人技术中的核心挑战。想象一下,当一台六轴机械臂需要将零件从传送带精准抓取并装配到指定位置时,如何确保它的运动既快速又平稳?这正…...

基于QT的Lingyuxiu MXJ LoRA桌面应用开发

基于QT的Lingyuxiu MXJ LoRA桌面应用开发 将AI绘画能力装进桌面应用,让创意触手可及 1. 为什么需要桌面端LoRA应用? 如果你用过在线AI绘画平台,肯定遇到过这样的困扰:网络不稳定时生成中断,想批量处理图片却只能一张张…...

Janus-Pro-7B创意编程作品展:生成交互式艺术与诗歌

Janus-Pro-7B创意编程作品展:生成交互式艺术与诗歌 最近我花了不少时间折腾Janus-Pro-7B这个模型,它最吸引我的地方,不是处理那些严肃的文档或者回答标准问题,而是它在创意和艺术表达上展现出的那种“灵性”。简单来说&#xff0…...

YOLOv12模型解释性分析:使用Grad-CAM可视化检测决策依据

YOLOv12模型解释性分析:使用Grad-CAM可视化检测决策依据 你是不是也好奇过,那个能精准识别出图片里猫猫狗狗的YOLO模型,它到底“看”到了什么?为什么有时候它会认错,把一只猫看成狗?今天,咱们就…...

Day19:让我的AI助手彻底离线!LangChain+Ollama本地模型实战 [特殊字符]

Day19:让我的AI助手彻底离线!LangChainOllama本地模型实战 🚀 前言:为什么我的AI助手总在关键时刻“掉线”? 兄弟们,有没有遇到过这种尴尬时刻:你正兴致勃勃地给朋友演示你的AI助手&#xff0…...

工业相机选型必看:Mono8、Mono10、Mono12这些像素格式到底该怎么选?(附应用场景对比)

工业相机像素格式深度解析:从Mono8到Mono12的实战选型指南 在工业视觉系统中,像素格式的选择往往被工程师们低估——直到项目遇到瓶颈。我曾亲眼见证一个价值数百万的检测产线因为像素格式选型不当,导致良品率统计出现5%的偏差。这不是理论问…...

ChatTTS操作全解析:语速调节与音色锁定的最佳实践

ChatTTS操作全解析:语速调节与音色锁定的最佳实践 "它不仅是在读稿,它是在表演。" ChatTTS 是目前开源界最逼真的语音合成模型之一,专门针对中文对话进行了优化。它能自动生成自然极高的停顿、换气声、笑声,听起来完全不…...

LeeCode HOT 100 94.二叉树的中序遍历

给定一个二叉树的根节点 root ,返回 它的 中序 遍历 。示例 1:输入:root [1,null,2,3] 输出:[1,3,2]示例 2:输入:root [] 输出:[]示例 3:输入:root [1] 输出&#xff…...

技术迭代背景下B端拓客号码核验的困境与发展路径氪迹科技法人股东决策人号码核验系统

B端拓客精细化运营的深化,使得企业核心决策人(法人、股东、董监高)号码的核验与筛选,成为影响拓客成效的关键前置环节。其服务质量直接关联拓客投入产出比,更是各类拓客主体实现规模化发展的重要支撑。当前&#xff0c…...

aE2库:Arduino平台E2总线温湿度传感器驱动指南

1. 项目概述aE2(Arduino-E2)是一个专为Arduino平台设计的轻量级E2总线通信库,用于驱动奥地利EE Elektronik公司生产的EE系列温湿度传感器(如EE-07)。该库不依赖任何第三方硬件抽象层或中间件,仅需标准Ardui…...

别再只会 pip freeze 了!用 pip-tools 和 pipreqs 搞定 Python 项目依赖,告别版本混乱

告别Python依赖管理混乱:pip-tools与pipreqs实战指南 每次接手新项目时,你是否也经历过这样的噩梦?克隆代码后运行pip install -r requirements.txt,结果等待你的不是顺利运行,而是各种版本冲突和依赖地狱。作为从业多…...

CoPaw模型版本管理与回滚实战:使用MLflow跟踪实验

CoPaw模型版本管理与回滚实战:使用MLflow跟踪实验 1. 为什么需要模型版本管理 在AI项目的实际开发中,模型迭代是家常便饭。你可能遇到过这种情况:上周的模型效果明明很好,这周更新后指标却突然下降,想找回之前的版本…...

小程序毕业设计-基于微信小程序的停车预约系统设计与实现-停车预约小程序

小程序毕业设计-基于微信小程序的停车预约系统设计与实现 https://www.bilibili.com/video/BV1hxKNzaER3/?spm_id_from333.1387.search.video_card.click&vd_source832d614817260f8f26d9431e5d8f726b 技术说明: 技术说明: 用户前端:微信小程序原生框架 管理前端:Vue.js 系…...