`

Three.js 学习记录 之 几何体

 
阅读更多

几何体是一个很重要的东东,它描述了你所要显示的对象的结构形状,有了这个形状之后,就可以使用材质给这个形状增加外观,然后使用网格(Mesh)把对象显示出来。

Three.js提供了丰富的几何体模型,今天了解几个模型,来和大家分享一下:

Three.js库中的geometry和其它大多数三维库中的一样,基本上是三位空间中的点集,以及一些将这些点连接起来的面,举例来说,一个方块有8个角,每个角都可以定义为x、y、z坐标的一个组合,所以每个方块都是三维空间中的8个点。在Three.js中,这些点称为顶点(vertice)。有六个侧面,每个角有一个顶点,每个侧面称为面(face)。

下面主要是介绍一下各个几何体的属性,属性熟悉了,就基本会用了。

 

一、THREE.Geometry

这个是一个基础类,属性如下:

id:对象id属性

name:可以为当前对象定义一个名称,初始化是空

vertices:对象顶点位置存放在这个属性中,该属性是一个数组,初始化为空数组.

colors:根据索引的顺序一对一的保存顶点颜色

faces:包含的是组成该几何体的每个面的顶点索引编号,注意:不是顶点的坐标值

faceVertexUvs:包含每个面顶点对应的纹理坐标,Uv指的是纹理贴图

morphTargets: 是一个数组,允许物体发生变形

morphColors:是一个数组,包含了morphTarget对应的颜色

morphNormals:是一个数组,包含了morphTarget对应的法线方向

skinWeight:是一个数组,用于几何体蒙皮的

skinIndices:是一个数组,用于几何体蒙皮的

boundingSphere:是一个对象,表示能够包含当前几何体的最大球体

boundingBox:是一个对象,表示能够包含当前几何体的最大立方体

hasTangents(bool型):是否有切线

verticesNeedUpdate(bool型):需要更新当前几何体的顶点坐标数据使用

elementsNeedUpdate(bool型):要更新当前几何体中face顶点索引数据

uvsNeedUpdate(bool型):需要更新当前几何体的纹理坐标数据

normalsNeedUpdate(bool型):需要更新当前几何体的顶点法线数据

colorsNeedUpdate(bool型):需要更新当前几何体的顶点颜色数据

tangentsNeedUpdate(bool型):需要更新当前几何体的切线数据

 

二、THREE.PlaneGeometry

PlaneGeometry可以用来创建非常简单的二维图形,属性如下:

width:宽度

height:高度

widthSegments:指定矩形的宽度应该划分成几段

heightSegments:指定矩形的高度应该划分成几段

 

可以使用widthSegments和heightSegments属性把矩形分成多个小面,就像格子一样。

 

三、THREE.CircleGeometry

CircleGeometry可以用来创建出简单的二维圆,属性如下:

radius:半径

segments:分段,可以用来指定创建圆所用面的数量,最少3个,默认是8个,值越大,创建出的圆越光滑

thetaStart:指定从哪儿开始画圆,取值范围是0到2*Pi

thetaLength:指定圆要画多大,和thetaStart配合使用

 

四、THREE.ShapeGeometry

如果你想创建一个自定义的二维图形,你可以使用ShapeGeometry,不过这个就比较复杂一点了,需要配合使用THREE.Shape的绘图函数来完成相关效果。

 

三维几何体

 

1、CubeGeometry

主要是用来创建四方体的,只要指定宽度、高度、深度既可以创建出一个方块,参数如下:

new THREE.CubeGeometry(width, height, depth, widthSegments, heightSegments, depthSegments);

width, height, depth是必须的参数

width:宽度,沿x轴方向的长度

height:高度,沿y轴方向的长度

depth:深度,沿z轴方向的长度

widthSegments:沿x轴的方向,将面分成多少份,默认值是1

heightSegments:沿y轴的方向,将面分成多少份,默认值是1

depthSegments:沿z轴的方向,将面分成多少份,默认值是1

 

2、SphereGeometry

可以用来创建球体,new THREE.SphereGeometry()就可以创建一个默认的圆形,参数如下:

radius:半径,默认是50

widthSegments:竖直(经度)方向上的分段数,分段越多,球体的表面越光滑,默认值是8,最小值是3

heightSegments:水平(纬度)方向上的分段数,分段越多,球体的表面越光滑,默认值是8,最小值是3

phiStart:指定从x轴的什么地方开始绘制,取值是0~2*Pi,默认是0

phiLength:用来指定从phiStart开始画多少,2*Pi是个整球,0.5Pi画的是一个竖直的1/4球。换句话说,就是竖直方向画多宽,就像西瓜一样,一瓣切多大

theStart:指定从y轴的什么地方开始绘制,取值是0~2*Pi,默认是0

thetaLength:用来指定从theStart开始画多少,Pi是个整球,0.5Pi画的是一个上半球。

 

3、CylinderGeometry

可以创建圆柱和类似圆柱的物体,new THREE.CylinderGeometry()就可以创建一个默认的圆柱,参数如下:

radiusTop:设置圆柱顶部的尺寸,默认是20

radiusBottom:设置圆柱底部的尺寸,默认是20

height:设置圆柱的高度,默认是100

segmentsX:沿x轴分成多少段,默认是8,值越大圆柱越光滑

segmentsY:沿y轴分成多少段,默认是1,分段越多,面越多

openEnded:指定网格的顶部和底部是否封闭,默认是false

 

4、TorusGeometry

可以画一个圆环,像甜甜圈的那种,new THREE.TorusGeometry()就可以创建一个默认的圆环,参数如下:

这个要贴一张图,不然说不清楚:

 

radius:圆环的尺寸,就是这个圆有多大,默认是100

tube:管子的半径,就是图中彩色的那根管子,默认是40

radialSegments:沿圆环长度方向分成的段数,默认是8,看到管子上的白线没有,值越大越密

tubularSegments:沿圆环宽度方向分成的段数,默认是6,比如图中的就是6节

arc:可以控制是否绘制一个完整的圆,默认是2*Pi(完整圆环)

 

5、TorusKnotGeometry

可以创建一个环面纽结,就像绳子绕在一起一样,参数如下:

radius:圆环的尺寸,默认是100

tube:管子的半径,默认是40

radialSegments:沿圆环长度方向分成的段数,默认是8

tubularSegments:沿圆环宽度方向分成的段数,默认是6

p:定义结的形状,默认是2

q:定义结的形状,默认是3

heightScale:可以拉伸环面纽结,默认是1

 

6、PolyhedronGeometry

用来创建多面体,参数如下:

vertices:设置构成多面体的顶点

faces:指定由vertices创建的面

radius:指定多面的大小

detail:通过这个属性你可以给这个多面体添加额外的细节,如果设为1,这个多面体上的每个三角形都会分成4个小三角形,如果设为2,那么那些4个小三角形中的每一个都会继续分成个小三角形,以此类推

 

有几个现成的多面体可以使用,包括,IcosahedronGeometry(20面体),TetrahedronGeometry(正四面体),OctahedronGeometry(正八面体)

 

分享到:
评论

相关推荐

    Three.js线条光波动画特效.zip

    总的来说,"Three.js线条光波动画特效.zip"涉及的知识点包括:Three.js库的使用、3D几何体和材质的理解、动画原理与实现、jQuery操作DOM、CSS样式设计以及前端开发实践。通过学习和研究这个项目,开发者不仅可以提升...

    html5+three.js科幻地球仪3D旋转动画特效.zip

    3. **3D几何体创建**:Three.js提供了多种内置几何体,如SphereGeometry(球体几何体)用于创建地球模型。 4. **纹理映射**:通过TextureLoader加载地图图像,并将其应用到地球几何体上。 5. **动画处理**:使用...

    Three.js配合Webpack的Demo项目

    Three.js支持各种3D对象,如几何体、材质、光源、相机等,同时提供了动画系统、加载器、物理引擎接口等功能,广泛应用于游戏开发、数据可视化、产品展示等领域。 【Webpack】 Webpack是一个模块打包工具,它可以将...

    Three.js碎片化图片切换特效.zip

    在Three.js中,可以创建多个平面几何体,并将图片纹理贴在这些几何体上,然后通过编程控制它们的运动,形成碎片化视觉效果。 3. **图片切换**:在特效中,图片的切换可能涉及到动态替换纹理或者改变碎片的排列方式...

    three.js三维图形图表特效.zip

    6. **图表**:虽然three.js主要用于3D图形,但通过自定义几何体和数据映射,也可以创建出具有3D视觉效果的图表,比如柱状图、饼图等。 7. **特效**:压缩包中的“特效”可能涉及粒子系统、雾效、镜面反射、深度贴图...

    #资源达人分享计划#threejs学习Demo笔记.rar

    【标题】:在这个资源达人分享计划中,我们关注的是"threejs学习Demo笔记.rar",这是一个关于Three.js库的学习资源,特别聚焦于线条和动画效果的实现。 【描述】:这个压缩包包含了一系列Three.js的源码示例,用于...

    HTML5+Three.js酷炫烟雾文字背景动画特效.zip

    至于文字部分,Three.js提供了TextGeometry类,可以将文本转换为3D几何体。开发者可能通过这个类创建3D文字,并将其与烟雾效果结合,形成一种立体且动态的文字背景。 此外,动画的流畅性通常依赖于定时器(如`...

    HTML5+three.js水面倒影太阳动画特效.zip

    2. **three.js基本用法**: three.js库简化了WebGL的使用,提供了几何体、材质、光源、相机等对象,以及动画控制等功能。在这里,我们需要了解如何创建和配置这些对象,以及如何将它们添加到场景中。 3. **水面模拟*...

    基于threejs的3D爆炸碎片轮播图特效

    1. **几何体(Geometry)**:在Three.js中,图片被转换为3D几何形状,如多边形或平面,每个碎片都是一个独立的几何体。 2. **材质(Material)**:每个碎片被赋予特定的材质,可以是基本材质如颜色材质,也可以是...

    3D 签到墙 ThreeJS动画

    **3D签到墙ThreeJS动画详解** Three.js是一个基于WebGL的JavaScript库,用于在浏览器中创建3D图形。这个“3D签到墙”项目利用Three.js的强大功能,为活动、年会等场合提供一种新颖且互动的签到体验。通过WebGL,它...

    threejs video演示,从笔记本摄像头获取媒体流,将场景渲染在立方体上

    总结一下,这个"threejs video演示"项目展示了如何利用Three.js库和HTML5 Media API,从笔记本摄像头捕获视频流,并将其实时渲染到3D立方体表面。通过这个过程,开发者可以学习到如何操作媒体流、创建和更新纹理,...

    three.js+html5 Canvas酷炫宇宙黑洞粒子动画特效.zip

    学习如何创建和操作3D几何体,如Sphere(球体)或Points(粒子)。 2. **粒子系统**:Three.js中的ParticleSystem或Points用于创建粒子效果。了解如何设置粒子的数量、大小、颜色、透明度等属性,以及如何实现粒子...

    three.js航空火箭发射特效.zip

    学习 three.js 的基本概念,如场景(Scene)、相机(Camera)、光源(Light)和几何体(Geometry)是很重要的。同时,了解如何加载和应用纹理(Textures),以及如何控制物体运动(Animations)也是必不可少的。对于...

    3D雪花世界(基于three.js和NW.js开发)

    标题中的“3D雪花世界”是一个使用WebGL技术呈现的三维动画应用,它利用了JavaScript库three.js的强大功能。Three.js是一个广泛使用的开源库,它为浏览器中的3D图形渲染提供了方便的API,使得开发者无需深入理解底层...

    three.js抽象液体背景特效.zip

    1. **几何体(Geometries)**:液体可能由平面几何体如PlaneGeometry或更复杂的几何形状如SphereGeometry来表示。 2. **材质(Materials)**:使用ShaderMaterial或者MeshStandardMaterial等,通过自定义着色器...

    Three.js源码阅读笔记(物体是如何组织的)

    在Three.js中,物体的组织主要体现在如何将几何形体(geometry)和材质(material)结合在一起,形成一个可视化的3D对象。Three.js中的基本物体构造函数是THREE.Mesh,它使用THREE.Object3D作为其原型,后者是所有...

    html5+three.js酷炫立方体碎片鼠标跟随动画特效.zip

    在本项目中,"html5+three.js酷炫立方体碎片鼠标跟随动画特效.zip"是一个利用HTML5技术结合JavaScript库three.js创建的互动视觉特效。Three.js是基于WebGL的3D库,它使得在浏览器中创建复杂的3D图形变得相对简单。 ...

    HTML5+Three.js实现人体摇头晃脑动作3D立体动画特效源码.zip

    Three.js不仅提供了对WebGL的封装,还包含了大量的预设几何体、材质、光源、相机等,使得开发者可以更便捷地创建复杂的3D场景。 在这个项目中,开发者首先需要使用Three.js来创建3D人体模型。这可能涉及到导入3D...

    three.js基于html5 canvas绘制液态抽象背景动画特效.zip

    3. 创建几何体(Geometry)和材质(Material)来表示液态效果。这可能涉及到使用粒子系统(ParticleSystem)或者自定义的几何形状,并应用流体动画纹理。 4. 将几何体添加到场景中。 5. 设置渲染循环,使用`...

    html5+three.js天空乌云密布背景动画特效.zip

    其中,可能有一个主要的JavaScript文件,用于设置Three.js的场景、相机、光照、几何体、材质和动画。例如,他们可能创建了一个天空盒(Skybox)来模拟无限远的天空,并用乌云纹理覆盖它,使其看起来像是天空中乌云...

Global site tag (gtag.js) - Google Analytics