THREE.js 管道体TubeGeometry

2023-10-08 03:40
文章标签 js 管道 three tubegeometry

本文主要是介绍THREE.js 管道体TubeGeometry,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

THREE.js封装了很多几何体供我们使用,其中一个叫TubeGeometry的十分神奇,
它根据3d曲线curve来张成一条管道,我们来看看它的构造函数。

TubeGeometry(path : Curve, tubularSegments : Integer, radius : Float, radialSegments : Integer, closed : Boolean)

其中各参数描述如下:
path — Curve - A path that inherits from the Curve base class(曲线,路径,即管道的形状)
tubularSegments — Integer - The number of segments that make up the tube, default is 64(管道分成多少段)
radius — Float - The radius of the tube, default is 1(管道的半径)
radialSegments — Integer - The number of segments that make up the cross-section, default is 8 (管道口分成多少段,即管道口是几边形)
closed — Boolean Is the tube open or closed, default is false (是否闭合管道,首尾相接的意思)

下面给出官网的一段示例:

function CustomSinCurve( scale ) {THREE.Curve.call( this );this.scale = ( scale === undefined ) ? 1 : scale;}CustomSinCurve.prototype = Object.create( THREE.Curve.prototype );
CustomSinCurve.prototype.constructor = CustomSinCurve;CustomSinCurve.prototype.getPoint = function ( t ) {var tx = t * 3 - 1.5;var ty = Math.sin( 2 * Math.PI * t );var tz = 0;return new THREE.Vector3( tx, ty, tz ).multiplyScalar( this.scale );};var path = new CustomSinCurve( 10 );
var geometry = new THREE.TubeGeometry( path, 20, 2, 8, false );
var material = new THREE.MeshBasicMaterial( { color: 0x00ff00 } );
var mesh = new THREE.Mesh( geometry, material );
scene.add( mesh );

这段代码大概是声明了一个CustomSinCurve类,这个类继承自THREE.Curve类,然后重写了类的getPoint方法。

THREE.Curve类中getPoint方法的描述:返回在曲线中给定位置 t 的向量

.getPoint ( t : Float, optionalTarget : Vector ) : Vectort - A position on the curve. Must be in the range [ 0, 1 ]. 
optionalTarget — (optional) If specified, the result will be copied into this Vector, otherwise a new Vector will be created. Returns a vector for a given position on the curve.

最后生成了这样一段曲线:
这里写图片描述

在这篇文章的启发下,我们也可以按一定规律生成一些点的坐标,用这些点生成一条曲线,然后通过这条曲线构造一个TubeGeometry几何体。

THREE.js中提供的生成曲线的方法有挺多的,比如

ArcCurve()CatmullRomCurve3()CubicBezierCurve3()LineCurve3()QuadraticBezierCurve3()

可以到官网查看相关资料。

然后造了一棵植物
这里写图片描述

加一点粒子:
这里写图片描述

这篇关于THREE.js 管道体TubeGeometry的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/162465

相关文章

C++20管道运算符的实现示例

《C++20管道运算符的实现示例》本文简要介绍C++20管道运算符的使用与实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录标准库的管道运算符使用自己实现类似的管道运算符我们不打算介绍太多,因为它实际属于c++20最为重要的

Linux基础命令@grep、wc、管道符的使用详解

《Linux基础命令@grep、wc、管道符的使用详解》:本文主要介绍Linux基础命令@grep、wc、管道符的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录grep概念语法作用演示一演示二演示三,带选项 -nwc概念语法作用wc,不带选项-c,统计字节数-

使用Python获取JS加载的数据的多种实现方法

《使用Python获取JS加载的数据的多种实现方法》在当今的互联网时代,网页数据的动态加载已经成为一种常见的技术手段,许多现代网站通过JavaScript(JS)动态加载内容,这使得传统的静态网页爬取... 目录引言一、动态 网页与js加载数据的原理二、python爬取JS加载数据的方法(一)分析网络请求1

VSCode中配置node.js的实现示例

《VSCode中配置node.js的实现示例》本文主要介绍了VSCode中配置node.js的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一.node.js下载安装教程二.配置npm三.配置环境变量四.VSCode配置五.心得一.no

Redis Pipeline(管道) 详解

《RedisPipeline(管道)详解》Pipeline管道是Redis提供的一种批量执行命令的机制,通过将多个命令一次性发送到服务器并统一接收响应,减少网络往返次数(RTT),显著提升执行效率... 目录Redis Pipeline 详解1. Pipeline 的核心概念2. 工作原理与性能提升3. 核

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

用js控制视频播放进度基本示例代码

《用js控制视频播放进度基本示例代码》写前端的时候,很多的时候是需要支持要网页视频播放的功能,下面这篇文章主要给大家介绍了关于用js控制视频播放进度的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言html部分:JavaScript部分:注意:总结前言在javascript中控制视频播放

Redis中管道操作pipeline的实现

《Redis中管道操作pipeline的实现》RedisPipeline是一种优化客户端与服务器通信的技术,通过批量发送和接收命令减少网络往返次数,提高命令执行效率,本文就来介绍一下Redis中管道操... 目录什么是pipeline场景一:我要向Redis新增大批量的数据分批处理事务( MULTI/EXE