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

【three.js】搭建环境

一、安装Node.js和npm

  1. 下载与安装

访问Node.js官方网站(nodejs.org),根据你的操作系统下载并安装最新稳定版(LTS版本)的Node.js。安装过程中,npm(Node包管理器)会随Node.js一起安装。

二、初始化项目

  1. 创建项目文件夹

在你的文件系统中创建一个新的文件夹,用于存放你的Three.js项目。

  1. 打开命令行

打开命令行界面(例如Windows的cmd、PowerShell,macOS的Terminal,或Linux的终端),并导航到你刚刚创建的项目文件夹。

  1. 初始化项目

在命令行中运行npm init -y(或npm init并按提示填写信息)来初始化npm项目,这将生成一个package.json文件,用于管理项目的依赖和配置。

三、安装Three.js

  1. 通过npm安装

在命令行中运行npm install three命令来安装Three.js库及其依赖。

四、配置项目结构

  1. 创建src文件夹

在项目文件夹中创建一个名为src的文件夹,用于存放源代码文件。

  1. 创建HTML和JS文件

src文件夹中创建一个名为index.html的文件,作为项目的入口文件。

src文件夹中创建一个名为main.js的文件,用于编写Three.js的脚本代码。

  1. 配置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>

  1. 编写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();

五、启动开发服务器

  1. 安装开发服务器(可选):

你可以使用Vite、Parcel、Webpack等现代前端构建工具来启动开发服务器,这些工具提供了热重载、代码拆分、优化等功能。

例如,使用Vite,你可以运行npm init vite@latest来初始化Vite项目,然后按照提示操作。

  1. 使用简单HTTP服务器(可选):

如果你不想使用复杂的构建工具,也可以使用简单的HTTP服务器,如http-server

在命令行中运行npm install -g http-server来全局安装http-server

然后,在项目文件夹中运行http-server -o来启动服务器并打开浏览器。

六、查看效果

  1. 打开浏览器

根据启动的开发服务器或HTTP服务器的地址,打开浏览器并访问相应的URL。

应该能看到一个旋转的绿色立方体,这是Three.js在网页中渲染的3D效果。

通过以上步骤,就可以在本地成功搭建一个Three.js的开发环境,并开始创建和展示3D图形了。

相关文章:

【three.js】搭建环境

一、安装Node.js和npm 下载与安装&#xff1a; 访问Node.js官方网站&#xff08;nodejs.org&#xff09;&#xff0c;根据你的操作系统下载并安装最新稳定版&#xff08;LTS版本&#xff09;的Node.js。安装过程中&#xff0c;npm&#xff08;Node包管理器&#xff09;会随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、条件式&#xff08;蕴含式&#xff09; P → Q 的真值规则 1.4.2、双条件式&#xff08;等值式&#xff09; P ↔ Q 的真值规则 1.…...

道可云人工智能元宇宙每日资讯|崂山区政务服务虚拟大厅启用

道可云元宇宙每日简报&#xff08;2024年12月31日&#xff09;讯&#xff0c;今日元宇宙新鲜事有&#xff1a; 崂山区政务服务虚拟大厅启用 近日&#xff0c;崂山区政务服务“虚拟大厅”在青岛正式上线&#xff0c;成为该市首个采用虚拟现实、人工智能、大数据及3D虚拟数字人…...

高并发写利器-组提交,我的Spring组件实战

高并发写优化理论 对于高并发的读QPS优化手段较多&#xff0c;最经济简单的方式是上缓存。但是对于高并发写TPS该如何提升&#xff1f;业界常用的有分库分表、异步写入等技术手段。但是分库分表对于业务的改造十分巨大&#xff0c;涉及迁移数据的麻烦工作&#xff0c;不会作为…...

音视频入门基础:MPEG2-PS专题(4)——FFmpeg源码中,判断某文件是否为PS文件的实现

一、引言 通过FFmpeg命令&#xff1a; ./ffmpeg -i XXX.ps 可以判断出某个文件是否为PS文件&#xff1a; 所以FFmpeg是怎样判断出某个文件是否为PS文件呢&#xff1f;它内部其实是通过mpegps_probe函数来判断的。从《FFmpeg源码&#xff1a;av_probe_input_format3函数和AVI…...

如何使用OpenCV进行抓图-多线程

前言 需求&#xff1a; 1、如何使用OpenCV捕抓Windows电脑上USB摄像头的流、 2、采用多线程 3、获知当前摄像头的帧率。 这个需求&#xff0c;之前就有做了&#xff0c;但是由于出现了一个问题&#xff0c;人家摄像头的帧率目前都可以达到60帧/s 了&#xff0c;而我的程序…...

电子应用设计方案86:智能 AI背景墙系统设计

智能 AI 背景墙系统设计 一、引言 智能 AI 背景墙系统旨在为用户创造一个动态、个性化且具有交互性的空间装饰体验&#xff0c;通过融合先进的技术和创意设计&#xff0c;提升室内环境的美观度和功能性。 二、系统概述 1. 系统目标 - 提供多种主题和风格的背景墙显示效果&…...

【《python爬虫入门教程11--重剑无峰168》】

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 【《python爬虫入门教程11--selenium的安装与使用》】 前言selenium就是一个可以实现python自动化的模块 一、Chrome的版本查找&#xff1f;-- 如果用edge也是类似的1.chrome…...

.net core 线程锁,互斥锁,自旋锁,混合锁

线程锁、互斥锁、自旋锁和混合锁是多线程编程中的重要概念&#xff0c;它们用于控制对共享资源的访问&#xff0c;避免数据竞争和不一致性。每种锁有其特定的适用场景和特点。我们来逐一解释它们&#xff0c;并进行比较。 1. 线程锁&#xff08;Thread Lock&#xff09; 线程…...

【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机器视觉:霍夫变换

在一个阳光灿烂得近乎放肆的午后&#xff0c;阿强的实验室就像被施了魔法的科学城堡&#xff0c;到处闪耀着神秘的科技光芒。阿强呢&#xff0c;像个即将踏上惊险征程的探险家&#xff0c;一屁股坐在那堆满奇奇怪怪设备的桌前&#xff0c;眼神中透露出按捺不住的兴奋劲儿&#…...

Kraft模式安装Kafka(含常规、容器两种安装方式)

一、#创作灵感# 公司使用Kafka的软件项目较多&#xff0c;故写技术笔记巩固知识要点 二、软件环境 - Kafka 3.9.0 官方下载地址&#xff1a;Kafka 3.9.0 - Docker Desktop 4.37 容器图形化工具 官方下载地址&#xff1a;Docker Desktop 4.37 特别说明 - Docker Desktop…...

Linux驱动开发(16):输入子系统–电容触摸驱动实验

有关电容触摸的基础知识内容可以参考野火STM32相关教程&#xff0c;这里只介绍电容触摸驱动的相关内容。 本章配套源码、设备树以及更新固件位于“~/embed_linux_driver_tutorial_imx6_code/linux_driver/touch_scream_GTxxx”目录下。 触摸面板通过双面胶粘在显示屏上&#…...

《深入浅出HTTPS​​​​​​​​​​​​​​​​​》读书笔记(24):椭圆曲线密码学

《深入浅出HTTPS​​​​​​​​​​》读书笔记&#xff08;24&#xff09;&#xff1a;椭圆曲线密码学 为了保证DH的密钥对不被破解&#xff0c;提升安全性的主要手段就是增加密钥对的长度&#xff0c;但是长度越长&#xff0c;性能越低。 为了解决性能问题&#xff0c;需要…...

现代光学基础5

总结自老师的讲义 yt5 开卷考试复习资料&#xff1a;光探测器与光伏技术 目录 光探测器&#xff08;Photodetector&#xff09; 工作原理二极管电路连接方式响应度&#xff08;Responsivity&#xff09;微弱光检测超导纳米线单光子探测光电二极管噪声 太阳能电池&#xff0…...

力扣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如何实现防抖?

第一 防抖就是我们设置一个调用时间&#xff0c;点击后设置时间开始倒计时&#xff0c;如果再次点击会重新倒计时 npm或yarn安装&#xff1a; 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局域网通信障碍&#xff1f;飞秋Mac版让你无缝连接同事电脑 【免费下载链接】feiq 基于qt实现的mac版飞秋&#xff0c;遵循飞秋协议(飞鸽扩展协议)&#xff0c;支持多项飞秋特有功能 项目地址: https://gitcode.com/gh_mirrors/fe/feiq 还在为Mac电脑无法与…...

SeqGPT-560M企业知识图谱构建:从非结构化文本中抽取实体关系三元组

SeqGPT-560M企业知识图谱构建&#xff1a;从非结构化文本中抽取实体关系三元组 1. 项目概述 SeqGPT-560M是一个专门为企业知识图谱构建设计的智能信息抽取系统。与通用的聊天对话模型不同&#xff0c;这个系统专注于一件事&#xff1a;从各种非结构化文本中精准提取实体和关系…...

上海 GEO 优化机构实力解析:十大标杆服务商核心优势深度呈现

随着生成式 AI 全面打通上海用户信息查询、消费下单全决策链条&#xff0c;超过六成上海本地企业都陷入共性增长难题&#xff1a;自身产品与服务实力出众&#xff0c;却在 AI 智能问答里曝光不足、信息偏差&#xff0c;品牌用户心智持续被同城竞品挤压。不少企业入局上海 GEO 赛…...

如何一站式管理《原神》《星穹铁道》等热门游戏的模组?XXMI启动器终极指南

如何一站式管理《原神》《星穹铁道》等热门游戏的模组&#xff1f;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调用一步到位

保姆级教学&#xff1a;Qwen3-4B-Instruct-2507镜像部署&#xff0c;vLLM服务Chainlit调用一步到位 1. 环境准备与快速部署 1.1 镜像获取与启动 Qwen3-4B-Instruct-2507镜像已预装vLLM推理框架和Chainlit交互界面&#xff0c;部署过程简单高效。启动步骤如下&#xff1a; 在…...

【亲测免费】 CrealityPrint 开源项目教程

CrealityPrint 开源项目教程 【免费下载链接】CrealityPrint 项目地址: https://gitcode.com/gh_mirrors/cr/CrealityPrint 1. 项目目录结构及介绍 在克隆或下载https://github.com/CrealityOfficial/CrealityPrint.git后的项目中&#xff0c;您将看到以下主要目录结构…...

Alpamayo-R1-10B保姆级教学:WebUI中Trajectory Visualization坐标系解读

Alpamayo-R1-10B保姆级教学&#xff1a;WebUI中Trajectory Visualization坐标系解读 1. 引言&#xff1a;从鸟瞰图到方向盘&#xff0c;看懂自动驾驶的“导航地图” 当你第一次打开Alpamayo-R1-10B的WebUI&#xff0c;点击“开始推理”后&#xff0c;最吸引眼球的可能就是右侧…...

老玩家回坑指南:手把手教你用‘版本号’快速定位《冒险岛》的青春年代

老玩家回坑指南&#xff1a;用版本号解锁《冒险岛》的时光密码 推开记忆的闸门&#xff0c;2004年盛夏的彩虹岛BGM仿佛又在耳边响起。十六年光阴流转&#xff0c;当你想重新登录那个充满童话色彩的横版世界时&#xff0c;却发现眼前是数十个标榜"怀旧服"的服务器选择…...

告别virt-manager!纯命令行搞定KVM虚拟机创建与管理(附常用命令清单)

告别virt-manager&#xff01;纯命令行搞定KVM虚拟机创建与管理&#xff08;附常用命令清单&#xff09; 在当今追求极致效率的运维环境中&#xff0c;图形界面工具往往成为制约自动化流程的瓶颈。对于熟悉Linux命令行的工程师而言&#xff0c;virt-manager这类GUI工具不仅操作…...

JetsonNano实战(五):ARM架构下的PyTorch与Torchvision环境搭建全攻略

1. 为什么Jetson Nano需要特殊版本的PyTorch 第一次接触Jetson Nano的开发者经常会遇到一个困惑&#xff1a;为什么直接从PyTorch官网下载的安装包无法使用&#xff1f;这其实涉及到计算机体系结构的一个关键差异。我们日常使用的笔记本电脑和台式机&#xff0c;绝大多数采用的…...