【three.js】搭建环境
一、安装Node.js和npm
- 下载与安装:
访问Node.js官方网站(nodejs.org),根据你的操作系统下载并安装最新稳定版(LTS版本)的Node.js。安装过程中,npm(Node包管理器)会随Node.js一起安装。
二、初始化项目
- 创建项目文件夹:
在你的文件系统中创建一个新的文件夹,用于存放你的Three.js项目。
- 打开命令行:
打开命令行界面(例如Windows的cmd、PowerShell,macOS的Terminal,或Linux的终端),并导航到你刚刚创建的项目文件夹。
- 初始化项目:
在命令行中运行npm init -y(或npm init并按提示填写信息)来初始化npm项目,这将生成一个package.json文件,用于管理项目的依赖和配置。
三、安装Three.js
- 通过npm安装:
在命令行中运行npm install three命令来安装Three.js库及其依赖。
四、配置项目结构
- 创建src文件夹:
在项目文件夹中创建一个名为src的文件夹,用于存放源代码文件。
- 创建HTML和JS文件:
在src文件夹中创建一个名为index.html的文件,作为项目的入口文件。
在src文件夹中创建一个名为main.js的文件,用于编写Three.js的脚本代码。
- 配置HTML文件:
在index.html文件中,添加基本的HTML结构,并引入main.js文件。例如:
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Three.js Project</title>
</head>
<body><script type="module" src="./main.js"></script>
</body>
</html>
- 编写Three.js代码:
在
main.js文件中,编写Three.js的初始化代码,包括创建场景、相机、渲染器,以及添加3D对象等。例如:
import * as THREE from 'three';// 创建场景
const scene = new THREE.Scene();// 创建相机
const camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000);
camera.position.z = 5;// 创建渲染器
const renderer = new THREE.WebGLRenderer();
renderer.setSize(window.innerWidth, window.innerHeight);
document.body.appendChild(renderer.domElement);// 创建一个立方体
const geometry = new THREE.BoxGeometry();
const material = new THREE.MeshBasicMaterial({ color: 0x00ff00 });
const cube = new THREE.Mesh(geometry, material);
scene.add(cube);// 渲染循环
function animate() {requestAnimationFrame(animate);cube.rotation.x += 0.01;cube.rotation.y += 0.01;renderer.render(scene, camera);
}
animate();
五、启动开发服务器
- 安装开发服务器(可选):
你可以使用Vite、Parcel、Webpack等现代前端构建工具来启动开发服务器,这些工具提供了热重载、代码拆分、优化等功能。
例如,使用Vite,你可以运行npm init vite@latest来初始化Vite项目,然后按照提示操作。
- 使用简单HTTP服务器(可选):
如果你不想使用复杂的构建工具,也可以使用简单的HTTP服务器,如http-server。
在命令行中运行npm install -g http-server来全局安装http-server。
然后,在项目文件夹中运行http-server -o来启动服务器并打开浏览器。
六、查看效果
- 打开浏览器:
根据启动的开发服务器或HTTP服务器的地址,打开浏览器并访问相应的URL。
应该能看到一个旋转的绿色立方体,这是Three.js在网页中渲染的3D效果。
通过以上步骤,就可以在本地成功搭建一个Three.js的开发环境,并开始创建和展示3D图形了。
相关文章:
【three.js】搭建环境
一、安装Node.js和npm 下载与安装: 访问Node.js官方网站(nodejs.org),根据你的操作系统下载并安装最新稳定版(LTS版本)的Node.js。安装过程中,npm(Node包管理器)会随No…...
SQLite AND/OR 运算符
SQLite AND/OR 运算符 SQLite 的 AND 和 OR 运算符用于基于一个以上的条件来过滤记录。这些运算符在 WHERE 子句中与 SELECT、UPDATE 和 DELETE 语句一起使用。理解这些运算符的工作方式对于有效地查询数据库至关重要。 AND 运算符 AND 运算符允许我们在 WHERE 子句中指定多…...
《普通逻辑》学习记录——命题的判定与自然推理
目录 一、真值 1.1、真值联结词 1.2、真值联结词与逻辑联结词的区别 1.3、真值形式 1.3.1、真值符号的优先级和结合性规则 1.4、真值规则 1.4.1、条件式(蕴含式) P → Q 的真值规则 1.4.2、双条件式(等值式) P ↔ Q 的真值规则 1.…...
道可云人工智能元宇宙每日资讯|崂山区政务服务虚拟大厅启用
道可云元宇宙每日简报(2024年12月31日)讯,今日元宇宙新鲜事有: 崂山区政务服务虚拟大厅启用 近日,崂山区政务服务“虚拟大厅”在青岛正式上线,成为该市首个采用虚拟现实、人工智能、大数据及3D虚拟数字人…...
高并发写利器-组提交,我的Spring组件实战
高并发写优化理论 对于高并发的读QPS优化手段较多,最经济简单的方式是上缓存。但是对于高并发写TPS该如何提升?业界常用的有分库分表、异步写入等技术手段。但是分库分表对于业务的改造十分巨大,涉及迁移数据的麻烦工作,不会作为…...
音视频入门基础:MPEG2-PS专题(4)——FFmpeg源码中,判断某文件是否为PS文件的实现
一、引言 通过FFmpeg命令: ./ffmpeg -i XXX.ps 可以判断出某个文件是否为PS文件: 所以FFmpeg是怎样判断出某个文件是否为PS文件呢?它内部其实是通过mpegps_probe函数来判断的。从《FFmpeg源码:av_probe_input_format3函数和AVI…...
如何使用OpenCV进行抓图-多线程
前言 需求: 1、如何使用OpenCV捕抓Windows电脑上USB摄像头的流、 2、采用多线程 3、获知当前摄像头的帧率。 这个需求,之前就有做了,但是由于出现了一个问题,人家摄像头的帧率目前都可以达到60帧/s 了,而我的程序…...
电子应用设计方案86:智能 AI背景墙系统设计
智能 AI 背景墙系统设计 一、引言 智能 AI 背景墙系统旨在为用户创造一个动态、个性化且具有交互性的空间装饰体验,通过融合先进的技术和创意设计,提升室内环境的美观度和功能性。 二、系统概述 1. 系统目标 - 提供多种主题和风格的背景墙显示效果&…...
【《python爬虫入门教程11--重剑无峰168》】
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 【《python爬虫入门教程11--selenium的安装与使用》】 前言selenium就是一个可以实现python自动化的模块 一、Chrome的版本查找?-- 如果用edge也是类似的1.chrome…...
.net core 线程锁,互斥锁,自旋锁,混合锁
线程锁、互斥锁、自旋锁和混合锁是多线程编程中的重要概念,它们用于控制对共享资源的访问,避免数据竞争和不一致性。每种锁有其特定的适用场景和特点。我们来逐一解释它们,并进行比较。 1. 线程锁(Thread Lock) 线程…...
【DevOps】Jenkins项目发布
Jenkins项目发布 文章目录 Jenkins项目发布前言资源列表基础环境一、Jenkins发布静态网站1.1、项目介绍1.2、部署Web1.3、准备gitlab1.4、配置gitlab1.5、创建项目1.6、推送代码 二、Jenkins中创建gitlab凭据2.1、创建凭据2.2、在Jenkins中添加远程主机2.3、获取gitlab项目的UR…...
C# OpenCV机器视觉:霍夫变换
在一个阳光灿烂得近乎放肆的午后,阿强的实验室就像被施了魔法的科学城堡,到处闪耀着神秘的科技光芒。阿强呢,像个即将踏上惊险征程的探险家,一屁股坐在那堆满奇奇怪怪设备的桌前,眼神中透露出按捺不住的兴奋劲儿&#…...
Kraft模式安装Kafka(含常规、容器两种安装方式)
一、#创作灵感# 公司使用Kafka的软件项目较多,故写技术笔记巩固知识要点 二、软件环境 - Kafka 3.9.0 官方下载地址:Kafka 3.9.0 - Docker Desktop 4.37 容器图形化工具 官方下载地址:Docker Desktop 4.37 特别说明 - Docker Desktop…...
Linux驱动开发(16):输入子系统–电容触摸驱动实验
有关电容触摸的基础知识内容可以参考野火STM32相关教程,这里只介绍电容触摸驱动的相关内容。 本章配套源码、设备树以及更新固件位于“~/embed_linux_driver_tutorial_imx6_code/linux_driver/touch_scream_GTxxx”目录下。 触摸面板通过双面胶粘在显示屏上&#…...
《深入浅出HTTPS》读书笔记(24):椭圆曲线密码学
《深入浅出HTTPS》读书笔记(24):椭圆曲线密码学 为了保证DH的密钥对不被破解,提升安全性的主要手段就是增加密钥对的长度,但是长度越长,性能越低。 为了解决性能问题,需要…...
现代光学基础5
总结自老师的讲义 yt5 开卷考试复习资料:光探测器与光伏技术 目录 光探测器(Photodetector) 工作原理二极管电路连接方式响应度(Responsivity)微弱光检测超导纳米线单光子探测光电二极管噪声 太阳能电池࿰…...
力扣hot100——贪心
121. 买卖股票的最佳时机 class Solution { public:int maxProfit(vector<int>& a) {if (a.size() 1) return 0;int ans 0;int mi a[0];for (int i 1; i < a.size(); i) {ans max(ans, a[i] - mi);mi min(mi, a[i]);}return ans;} };55. 跳跃游戏 class S…...
vue3如何实现防抖?
第一 防抖就是我们设置一个调用时间,点击后设置时间开始倒计时,如果再次点击会重新倒计时 npm或yarn安装: npm install lodash <template><div click"debouncedInputHandler"><button>打印</button>…...
西安电子科技大学初/复试笔试、面试、机试成绩占比
西安电子科技大学初/复试笔试、面试、机试成绩占比 01通信工程学院 02电子工程学院 03计算机科学与技术学院 04机电工程学院 06经济与管理学院 07数学与统计学院 08人文学院 09外国语学院 12生命科学与技术学院 13空间科学与技术学院 14先进材料与纳米科技学院 15网络与信息安…...
spring mvc源码学习笔记之六
pom.xml 内容如下 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.org/P…...
Mac与Windows局域网通信障碍?飞秋Mac版让你无缝连接同事电脑
Mac与Windows局域网通信障碍?飞秋Mac版让你无缝连接同事电脑 【免费下载链接】feiq 基于qt实现的mac版飞秋,遵循飞秋协议(飞鸽扩展协议),支持多项飞秋特有功能 项目地址: https://gitcode.com/gh_mirrors/fe/feiq 还在为Mac电脑无法与…...
SeqGPT-560M企业知识图谱构建:从非结构化文本中抽取实体关系三元组
SeqGPT-560M企业知识图谱构建:从非结构化文本中抽取实体关系三元组 1. 项目概述 SeqGPT-560M是一个专门为企业知识图谱构建设计的智能信息抽取系统。与通用的聊天对话模型不同,这个系统专注于一件事:从各种非结构化文本中精准提取实体和关系…...
上海 GEO 优化机构实力解析:十大标杆服务商核心优势深度呈现
随着生成式 AI 全面打通上海用户信息查询、消费下单全决策链条,超过六成上海本地企业都陷入共性增长难题:自身产品与服务实力出众,却在 AI 智能问答里曝光不足、信息偏差,品牌用户心智持续被同城竞品挤压。不少企业入局上海 GEO 赛…...
如何一站式管理《原神》《星穹铁道》等热门游戏的模组?XXMI启动器终极指南
如何一站式管理《原神》《星穹铁道》等热门游戏的模组?XXMI启动器终极指南 【免费下载链接】XXMI-Launcher Modding platform for GI, HSR, WW and ZZZ 项目地址: https://gitcode.com/gh_mirrors/xx/XXMI-Launcher 还在为不同游戏模组的繁琐安装和管理而烦恼…...
保姆级教学:Qwen3-4B-Instruct-2507镜像部署,vLLM服务+Chainlit调用一步到位
保姆级教学:Qwen3-4B-Instruct-2507镜像部署,vLLM服务Chainlit调用一步到位 1. 环境准备与快速部署 1.1 镜像获取与启动 Qwen3-4B-Instruct-2507镜像已预装vLLM推理框架和Chainlit交互界面,部署过程简单高效。启动步骤如下: 在…...
【亲测免费】 CrealityPrint 开源项目教程
CrealityPrint 开源项目教程 【免费下载链接】CrealityPrint 项目地址: https://gitcode.com/gh_mirrors/cr/CrealityPrint 1. 项目目录结构及介绍 在克隆或下载https://github.com/CrealityOfficial/CrealityPrint.git后的项目中,您将看到以下主要目录结构…...
Alpamayo-R1-10B保姆级教学:WebUI中Trajectory Visualization坐标系解读
Alpamayo-R1-10B保姆级教学:WebUI中Trajectory Visualization坐标系解读 1. 引言:从鸟瞰图到方向盘,看懂自动驾驶的“导航地图” 当你第一次打开Alpamayo-R1-10B的WebUI,点击“开始推理”后,最吸引眼球的可能就是右侧…...
老玩家回坑指南:手把手教你用‘版本号’快速定位《冒险岛》的青春年代
老玩家回坑指南:用版本号解锁《冒险岛》的时光密码 推开记忆的闸门,2004年盛夏的彩虹岛BGM仿佛又在耳边响起。十六年光阴流转,当你想重新登录那个充满童话色彩的横版世界时,却发现眼前是数十个标榜"怀旧服"的服务器选择…...
告别virt-manager!纯命令行搞定KVM虚拟机创建与管理(附常用命令清单)
告别virt-manager!纯命令行搞定KVM虚拟机创建与管理(附常用命令清单) 在当今追求极致效率的运维环境中,图形界面工具往往成为制约自动化流程的瓶颈。对于熟悉Linux命令行的工程师而言,virt-manager这类GUI工具不仅操作…...
JetsonNano实战(五):ARM架构下的PyTorch与Torchvision环境搭建全攻略
1. 为什么Jetson Nano需要特殊版本的PyTorch 第一次接触Jetson Nano的开发者经常会遇到一个困惑:为什么直接从PyTorch官网下载的安装包无法使用?这其实涉及到计算机体系结构的一个关键差异。我们日常使用的笔记本电脑和台式机,绝大多数采用的…...
