所有的三位物体都是由点构成,两点构成线,三点构成面,ThreeJs又如何绘制出点、线、面呢 ?

在ThreeJs中:

  • 模型由几何体和材质构成
  • 模型以何种形式(点、线、面)展示取决于渲染方式

1. 几何体

首先我们来创建一个自定义的几何体

var geometry = new THREE.Geometry(); //声明一个几何体对象Geometry
THREE.Geometry是所有几何体的基类,它有几个重要的属性:
  • vertices : 数组,保存该几何体下所有顶点(Vector3对象)
  • colors : 数组,保存该几何体下所有顶点的颜色信息(Color对象)
  • faces : 数组,保存该几何体下所有面信息(Face3对象)

此时该几何体为空,我们需要创建一些点,然后绑定到该几何体

var p1 = new THREE.Vector3( 0, 0, 0 );
var p2 = new THREE.Vector3( 50, 0, 50 );
var p3 = new THREE.Vector3( 50, 50, 50 );
var p4 = new THREE.Vector3( 0, 50, 0 );
//绑定顶点到几何体
geometry.vertices.push(p1, p2, p3, p4);
//如果需要每个点展示不同颜色,需要给每个顶点添加颜色,也可以通过材质设置统一颜色
geometry.colors = [
new THREE.Color( 0xFF0000 ),
new THREE.Color( 0x00FF00 ),
new THREE.Color( 0x0000FF ),
new THREE.Color( 0xFFFF00 )
];

这里创建了一个几何体,接下来我们把他以点的形式渲染到页面上

    //如果以点的形式渲染,需要设置点对应材质
var pointMaterial = new THREE.PointsMaterial({
color: 0xFFFFFF, //设置颜色,默认 0xFFFFFF
vertexColors: true, //定义材料是否使用顶点颜色,默认false ---如果该选项设置为true,则color属性失效
size: 5 //定义粒子的大小。默认为1.0
});
//生成点模型
var points = new THREE.Points(geometry, pointMaterial);
//将模型添加到场景
scene.add(points);

接下来我们创建一个线模型

    //如果以线的形式渲染,需要设置线材质
var lineMaterial = new THREE.LineBasicMaterial({
color: 0xFFFFFF, //设置颜色,默认 0xFFFFFF
vertexColors: true, //设置为true线条会以两点颜色渐变 ---如果该选项设置为true,则color属性失效
linewidth: 5, //线宽,window下不生效
}); var line = new THREE.Line(geometry, lineMaterial);
scene.add(line);

再来创建一个网格(面)模型

    //创建一个面,参数为几何体顶点的索引
var face1 = new THREE.Face3( 0, 1, 2 );
//设置这个面的法向量
face1.normal = new THREE.Vector3( 0, 0, -1 );
//设置各个顶点对应颜色
face1.vertexColors = [
new THREE.Color(0xFF0000),
new THREE.Color(0x00FF00),
new THREE.Color(0x0000FF),
];
geometry.faces.push(face1);
//设置网格材质,这里设置为Lambert材质为一种不发光材质
var meshMaterial = new THREE.MeshLambertMaterial({
vertexColors : THREE.VertexColors,
side: THREE.DoubleSide
}); var mesh = new THREE.Mesh(geometry, meshMaterial);
scene.add(mesh);

可以看出以网格形式渲染需要先创建Face3对象,这是因为我们几何体的每个面都有其对应的法向量,即设置以哪个角度反射光线

Face3对象对应的属性

  • a,b,c : 对应三角面的三个点(Vector3对象)
  • color :颜色
  • normal :该三角面的法向量(Vector3对象)
  • vertexColors : 设置三角面三个点对应的法向量(Vector3对象数组),通常一个面都有一个统一的法向量,即设置 normal 即可

以上是我们创建自定义模型的基本操作,ThreeJs为我们提供了很多自带的模型,我们只需要调用API即可创建

等等....

ThreeJs 绘制点、线、面的更多相关文章

  1. 【带着canvas去流浪(5)】绘制K线图

    目录 一. 任务说明 二. 重点提示 三. 示例代码 示例代码托管在:http://www.github.com/dashnowords/blogs 博客园地址:<大史住在大前端>原创博文 ...

  2. CAD交互绘制样条线(网页版)

    在CAD设计时,需要绘制样条线,用户可以设置样条线线重及颜色等属性. 主要用到函数说明: _DMxDrawX::SendStringToExecuteFun 把命令当着函数执行,可以传参数.详细说明如 ...

  3. CAD交互绘制样条线(com接口)

    在CAD设计时,需要绘制样条线,用户可以设置样条线线重及颜色等属性. 主要用到函数说明: _DMxDrawX::SendStringToExecuteFun 把命令当着函数执行,可以传参数.详细说明如 ...

  4. CAD参数绘制样条线(com接口)

    在CAD设计时,需要绘制样条线,用户可以设置样条线线重及颜色等属性. 主要用到函数说明: _DMxDrawX::PathLineTo 把路径下一个点移到指定位置.详细说明如下: 参数 说明 DOUBL ...

  5. CAD参数绘制样条线(网页版)

    在CAD设计时,需要绘制样条线,用户可以设置样条线线重及颜色等属性. 主要用到函数说明: _DMxDrawX::PathLineTo 把路径下一个点移到指定位置.详细说明如下: 参数 说明 DOUBL ...

  6. CAD动态绘制样条线(网页版)

    在CAD设计时,需要绘制样条线,用户可以设置样条线线重及颜色等属性. 主要用到函数说明: _DMxDrawX::SendStringToExecuteFun 把命令当着函数执行,可以传参数.详细说明如 ...

  7. 带着canvas去流浪系列之五 绘制K线图

    [摘要] 用canvas原生API实现百度Echarts 示例代码托管在:http://www.github.com/dashnowords/blogs 一. 任务说明 使用原生canvasAPI绘制 ...

  8. 用Python爬取股票数据,绘制K线和均线并用机器学习预测股价(来自我出的书)

    最近我出了一本书,<基于股票大数据分析的Python入门实战 视频教学版>,京东链接:https://item.jd.com/69241653952.html,在其中用股票范例讲述Pyth ...

  9. 使用Python的pandas模块、mplfinance模块、matplotlib模块绘制K线图

    目录 pandas模块.mplfinance模块和matplotlib模块介绍 pandas模块 mplfinance模块和matplotlib模块 安装mplfinance模块.pandas模块和m ...

  10. mapboxgl绘制3D线

    最近遇到个需求,使用mapboxgl绘制行政区划图层,要求把行政区划拔高做出立体效果,以便突出显示. 拿到这个需求后,感觉很简单呀,只需要用fill-extrusion方式绘制就可以啦,实现出来是这个 ...

随机推荐

  1. 上手d3js

    0---什么是d3js: d3js是一个开源的,基于对svg操作的数据可视化框架,简单的说他提供了数据提供了一系列的数据可视化工具,可以用他很方便的创造出关于svg的动画:svg动画具有可伸缩,不失真 ...

  2. Ubuntu中,wxpython的TextCtrl引发的error:_pixman_log_error

    1>在windows下,执行下面的代码,不会报错,但是在Ubuntu下,就会报错 2>在Ubuntu下执行上面的代码,会提示下面的错. 解决方法: 若是TextCtrl中不写wx.TE_M ...

  3. 深入理解CSS选择器优先级

    题外话 今天把 <CSS REFACTORING>(中文名叫<CSS重构:样式表性能调优>)电子书粗略的浏览了一遍,这本书很薄,150页左右,首先是介绍了什么是重构并举了两个简 ...

  4. imp 导入以及换用户报错

    数据库导入操作:SQL> create user user identified by passwd; SQL> create tablespace user datafile '/dat ...

  5. lnmp一件安装包 搭建laravel 环境(lnmp1.4)(报错500)

    https://blog.csdn.net/huangyuxin_/article/details/78998486

  6. 微软AD相关操作的免费工具

    https://www.ittsystems.com/best-free-active-directory-tools/

  7. 工控随笔_04_西门子_解决Step 7软件因授权问题不能打开的方式和方法

    西门子的软件是授权软件,只有经过授权认证的用户才能使用,如果没有通过授权认证则不能 正常的使用软件的相关功能. 一.西门子授权不成功问题 如上图所示报故障代码: 000001-0505.报警文本为:未 ...

  8. Ubuntn16.04.3安装Hadoop3.0+scale2.12+spark2.2

    Ubuntn16.04.3安装Hadoop3.0+scale2.12+spark2.2 对比参照此博文.bovenson 前言:因为安装的Hadoop.Scale是基于JAVA的应用程序,所以必须先安 ...

  9. 2018-2019-2 20165312《网络攻防技术》Exp4 恶意代码分析

    2018-2019-2 20165312<网络攻防技术>Exp4 恶意代码分析 知识点总结 1.有关schtasks schtacks的作用:安排命令和程序定期运行或在指定时间内运行.从计 ...

  10. 知识点:Mysql 索引优化实战(3)

    知识点:Mysql 索引原理完全手册(1) 知识点:Mysql 索引原理完全手册(2) 知识点:Mysql 索引优化实战(3) 知识点:Mysql 数据库索引优化实战(4) 索引原理知识回顾 索引的性 ...