本文是Three.js电子书的14.2节
基本所有的三维软件都支持导出.stl
格式的三维模型文件,.stl
格式的三维模型不包含材质Material信息,只包含几何体顶点数据的信息,你可以简单地把stl文件理解为几何体对象Geometry,本节课素材box.STL
是一个立方体, 你可以用记事本或代码编辑器打开文件box.STL
查看stl的数据结构。
.stl
文件格式的数据结构,对于大多数普通开发者来说,如果仅仅为了加载显示一个三维模型,也没必要掌握,这里之所以要强调,不是为了让你记住,而是为了从底层了解Threejs模型加载的原理,达到举一反三的目的
三个位置坐标和一个三角形面的法线方向向量是一组数据,这一组数据表示一个三角形面的信息,可以回忆下第二章关于三角形面Face3的讲解。
表示一个三角形面信息的一组数据
//三角面1
facet normal 0 0 -1 //三角形面法向量
outer loop
vertex 50 50 -50 //顶点位置
vertex 50 -50 -50 //顶点位置
vertex -50 50 -50 //顶点位置
endloop
endfacet
一个立方体有6个矩形平面,每个矩形平面至少需要两个三角形拼接而成。那么立方体6个矩形平面至少需要12个三角形面构成,你可以查看文件box.STL
中的12个三角形信息。
solid box //文件名字
//三角面1
facet normal 0 0 -1 //三角形面法向量
outer loop
vertex 50 50 -50 //顶点位置
vertex 50 -50 -50 //顶点位置
vertex -50 50 -50 //顶点位置
endloop
endfacet
//三角面2
facet normal 0 0 -1 //三角形面法向量
outer loop
vertex -50 50 -50 //顶点位置
vertex 50 -50 -50 //顶点位置
vertex -50 -50 -50 //顶点位置
endloop
endfacet
facet normal 0 1 0
.....
.....
//三角面12
facet normal -1 0 0
outer loop
vertex -50 -50 -50
vertex -50 50 50
vertex -50 50 -50
endloop
endfacet
endsolid
STLLoader.js
加载.stl文件如果你想通过Threejs加载.stl格式三维模型文件,可以使用Threejs提供的一个扩展库stl加载器STLLoader.js
,你可以在Three.js-master包中找到STLLoader.js
文件,具体路径是three.js-master\examples\js\loaders
.
.html文件中引入Threejs的扩展库STLLoader.js
,引入该文件后,就可以在代码中使用构造函数THREE.STLLoader()
实例化一个加载器。
<script src="STLLoader.js">script>
通过构造函数THREE.STLLoader()
可以把.stl
文件中几何体顶点信息提取出来转化为Three.js自身格式的几何体对象BufferGeometry
。如果你有兴趣可以阅读STLLoader.js
源码,尤其是你想独立开发自己公司特定格式加载器的情况下,更有必要参照学习。
// THREE.STLLoader创建一个加载器
var loader = new THREE.STLLoader();
loader.load('立方体.stl',function (geometry) {
// 加载完成后会返回一个几何体对象BufferGeometry,你可以通过Mesh、Points等方式渲染该几何体
})
/**
* stl数据加载
*/
var loader = new THREE.STLLoader();
// 立方体默认尺寸长宽高各200
loader.load('立方体.stl',function (geometry) {
// 控制台查看加载放回的threejs对象结构
console.log(geometry);
// 查看顶点数,一个立方体6个矩形面,每个矩形面至少2个三角面,每个三角面3个顶点,
// 如果没有索引index复用顶点,就是说一个立方体至少36个顶点
console.log(geometry.attributes.position.count);
// 缩放几何体
// geometry.scale(0.5,0.5,0.5);
// 几何体居中
// geometry.center();
// 平移立方体
// geometry.translate(-50,-50,-50);
var material = new THREE.MeshLambertMaterial({
color: 0x0000ff,
}); //材质对象Material
var mesh = new THREE.Mesh(geometry, material); //网格模型对象Mesh
scene.add(mesh); //网格模型添加到场景中
})
你可以使用下面代码代替上面代码,查看Three.js如果通过点模型Points渲染stl文件中的顶点数据。
/**
* 点渲染模式
*/
loader.load('离心叶轮.stl',function (geometry) {
var material = new THREE.PointsMaterial({
color: 0x000000,
size: 0.5//点对象像素尺寸
}); //材质对象
var points = new THREE.Points(geometry, material); //点模型对象
scene.add(points); //点对象添加到场景中
})