当前位置:首页 > 技术分析 > 正文内容

一文看懂3D模型obj文件

ruisui881个月前 (03-25)技术分析8

你是否好奇那些3D游戏中复杂的角色、建筑、场景是怎么实现的,美工使用3D建模软件设计好角色模型之后,程序又是怎么让它们动起来的哪?

在计算机中,3D角色等模型最终都是存储成文件,这些文件必然携带了角色形状、材质等属性,程序就是通过读取并解析这些文件,通过代码控制它们动起来,创造了一个又一个精彩的游戏世界。另外,看似复杂无比的模型都是通过大量三角形来逼近的,表示单个三角形就简单很多了,而3D模型文件的内容也就是立足于三角形。

obj文件是Alias|Wavefront公司为3D建模和动画软件"Advanced Visualizer"开发的一种标准3D模型文件格式,大部分3D软件都支持导入、导出obj格式的模型文件。

立方体模型

接下来,我们使用blender这款开源的3D建模软件创建一个简单的立方体模型,设置立方体的顶面颜色为橘黄色,其他面全部为红色,j将其导出为obj文件,使用任意文本编辑器打开来一步步看看里面都有什么。

说明:导出共生成了两个文件,一个为.obj后缀模型文件,一个为.mtl后缀的材质文件。

看懂obj模型文件

完整的obj文件内容如下

# Blender v3.1.2 OBJ File: ''
# www.blender.org
mtllib mycube.mtl
o Cube
v 1.000000 1.000000 -1.000000
v 1.000000 -1.000000 -1.000000
v 1.000000 1.000000 1.000000
v 1.000000 -1.000000 1.000000
v -1.000000 1.000000 -1.000000
v -1.000000 -1.000000 -1.000000
v -1.000000 1.000000 1.000000
v -1.000000 -1.000000 1.000000
vt 0.625000 0.500000
vt 0.875000 0.500000
vt 0.875000 0.750000
vt 0.625000 0.750000
vt 0.375000 0.750000
vt 0.625000 1.000000
vt 0.375000 1.000000
vt 0.375000 0.000000
vt 0.625000 0.000000
vt 0.625000 0.250000
vt 0.375000 0.250000
vt 0.125000 0.500000
vt 0.375000 0.500000
vt 0.125000 0.750000
vn 0.0000 1.0000 0.0000
vn 0.0000 0.0000 1.0000
vn -1.0000 0.0000 0.0000
vn 0.0000 -1.0000 0.0000
vn 1.0000 0.0000 0.0000
vn 0.0000 0.0000 -1.0000
usemtl Material
s off
f 1/1/1 5/2/1 7/3/1 3/4/1
usemtl Material.001
f 4/5/2 3/4/2 7/6/2 8/7/2
f 8/8/3 7/9/3 5/10/3 6/11/3
f 6/12/4 2/13/4 4/5/4 8/14/4
f 2/13/5 1/1/5 3/4/5 4/5/5
f 6/11/6 5/10/6 1/1/6 2/13/6
  • #开头的表示注释。
  • mtllib mycube.mtl表示引用了一个外部的材质文件,材质文件名为mycube.mtl,后面会介绍材质文件的内容。
  • o Cube指定了模型名称为Cube。
  • v开头的共有8行,表示立方体的8个顶点坐标(x,y,z)。
  • vt开头的共有14行,表示uv贴图坐标(x,y),看到这些奇怪的数字可能让你一头雾水,当我们把这14行数字表示的坐标点逐一绘制出来,并将相邻的点连接起来就得到了下面的图形。这样就豁然开朗了,它就像是一张包装纸,刚好可以包裹住一个立方体盒子的6个面。

  • vn开头的共有6行,它表示立方体6个面对应的法向量,法向量在这里起到识别某个面是正面还是反面的作用。
  • usemtl Material表示使用mycube.mtl文件中Material定义的材质,接下来的通过索引指定的面将使用该材质。
  • s off表示关闭光滑组(Smoothing group)。
  • f开头的表示由顶点、uv纹理坐标、法向量索引确定的表面,如5/2/1表示v开头的第5个顶点、这个点对应vt贴图的第2个坐标(就是包装纸的某个点应该和立方体盒子的哪个点对齐)、这个点对应vn开头的第1个法向量;一个立方体表面共有4个点,因此需要有4组索引数据来确定一个面。使用Material材质的面只有一个,就是建模时设置为橘黄色的面。
  • usemtl Material.001表示使用mycube.mtl文件中Material.001表示的材质,接下来的通过索引指定的面将使用该材质。
  • 之后5行以f开头的面是建模时设置为红色的面,格式同橘黄色的面。

看懂mtl材质文件

现在,来看看mycube.mtl材质文件都包含什么内容,完整内容如下:

# Blender MTL File: 'None'
# Material Count: 2

newmtl Material
Ns 359.999993
Ka 1.000000 1.000000 1.000000
Kd 0.800000 0.582192 0.154415
Ks 0.500000 0.500000 0.500000
Ke 0.000000 0.000000 0.000000
Ni 1.450000
d 1.000000
illum 2

newmtl Material.001
Ns 250.000000
Ka 1.000000 1.000000 1.000000
Kd 0.800000 0.002207 0.009875
Ks 0.500000 0.500000 0.500000
Ke 0.000000 0.000000 0.000000
Ni 1.450000
d 1.000000
illum 2
  • #开头表示注释。
  • newmtl Material定义材质Material,接下来的内容都是该材质的属性。
  • Ns表示高光色的权重。
  • Ka表示环境光,三个数字分别对应R、G、B值。
  • Kd表示漫反射光,三个数字分别对应R、G、B值。
  • Ks表示高光,三个数字分别对应R、G、B值。
  • Ke表示发射光,三个数字分别对应R、G、B值。
  • Ni表示光学密度。
  • d表示透明度,0是完全透明,1是完全不透明。
  • illum 2表示指定的光照模型(参考:Phong光照模型),illum后面的数字范围为0~10,具体含义如下:
0 Color on and Ambient off  
1 Color on and Ambient on  
2 Highlight on  
3 Reflection on and Ray trace on  
4 Transparency: Glass on  
  Reflection: Ray trace on  
5 Reflection: Fresnel on and Ray trace on  
6 Transparency: Refraction on  
  Reflection: Fresnel off and Ray trace on  
7 Transparency: Refraction on  
  Reflection: Fresnel on and Ray trace on  
8 Reflection on and Ray trace off  
9 Transparency: Glass on  
  Reflection: Ray trace off  
10 Casts shadows onto invisible surfaces	
  • newmtl Material.001表示指定材质Material.001,之后的内容都是关于该材质的属性,具体含义和Material完全相同,不再详述。

参考文献

[1]. 《WebGL指南》第10章高级技术>加载三维模型,401页。

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/3019.html

分享给朋友:

“一文看懂3D模型obj文件” 的相关文章

几个linux发行版使用感受

linux发行版有哪些linux发行版有上千种,但每一种发行版并不是与其它的发行版没任何关系,有些发行版是基于其他发行版制作的。如果乐意,你自己也可以动手制作属于自己的发行版,然后分发给其他人使用,所以非常自由,可选择的非常多。常见的发行版有:RedHat、Ubuntu、OpenSUSE、Gento...

react hooks自定义组件居然能这样做

前言  这里写一下如何封装可复用组件。首先技术栈 react hooks + props-type + jsx封装纯函数组件。类组件和typeScript在这不做讨论,大家别白跑一趟。接下来会说一下封装可复用组件的思路,比如一个新手应该怎么去封装,都需要有哪些东西。  然后说一些复杂组件需要的功能,...

Python中的11 种数组算法

1. 创建数组 创建数组意味着留出一个连续的内存块来存储相同类型的元素。在大多数语言中,您可以在创建数组时指定数组的大小。假设您正在书架上整理一组书籍,并且您需要为正好 10 本书预留空间。功能架上的每个空间都对应于数组中的一个索引。# Example in Python arr = [1, 2,...

js中数组filter方法的使用和实现

定义filter() 方法创建一个新数组, 其包含通过所提供函数实现的测试的所有元素。语法var newArray = arr.filter(callback(element[, index[, selfArr]])[, thisArg])参数callback循环数组每个元素时调用的回调函数。回调函...

vue3使用vue-router路由(路由懒加载、路由传参)

vue-router 是 vue的一个插件库1. 专门用来实现一个SPA单页面应用2 .基于vue的项目基本都会用到此库SPA的理解1) 单页Web应用(single page web application,SPA)2) 整个应用只有一个完整的页面3) 点击页面中的链接不会刷新页面, 本身也不会向...

基于微信小程序+springboot+vue技术构建的开源微信商城

介绍基于 微信小程序 + springboot + vue 技术构建 ,支持单店铺,多店铺入驻的商城平台。项目包含 微信小程序,管理后台。基于java后台语言,已功能闭环,且达到商用标准的一套项目体系。技术栈平台功能介绍小程序演示图管理后端演示图小程序体验码演示地址1.0版演示地址说明后台管理端演示...