Wavefront .OBJ文件格式解读【3D】

OBJ(或 .OBJ)是一种几何定义文件格式,最初由 Wavefront Technologies 为其高级可视化器动画包开发。 该文件格式是开放的,已被其他 3D 图形应用程序供应商采用。

OBJ 文件格式是一种简单的数据格式,仅表示 3D 几何体,即每个顶点的位置、顶点UV坐标、顶点法线以及使每个多边形定义为顶点列表的面。 默认情况下,顶点按逆时针顺序存储,因此无需显式声明面法线。 OBJ 坐标没有单位,但 OBJ 文件可以在人类可读的注释行中包含比例信息。

在这里插入图片描述

推荐:用 NSDT设计器 快速搭建可编程3D场景。

1、OBJ文件结构概述

哈希字符 (#) 后面的任何内容都是注释。

# this is a comment

OBJ 文件可以包含顶点数据、自由形式的曲线/曲面属性、元素、自由形式的曲线/曲面体声明、自由形式曲面之间的连接性、分组和显示/渲染属性信息。 最常见的元素是几何顶点、纹理坐标、顶点法线和多边形面:

# List of geometric vertices, with (x, y, z, [w]) coordinates, w is optional and defaults to 1.0.
v 0.123 0.234 0.345 1.0
v ...
...
# List of texture coordinates, in (u, [v, w]) coordinates, these will vary between 0 and 1. v, w are optional and default to 0.
vt 0.500 1 [0]
vt ...
...
# List of vertex normals in (x,y,z) form; normals might not be unit vectors.
vn 0.707 0.000 0.707
vn ...
...
# Parameter space vertices in (u, [v, w]) form; free form geometry statement (see below)
vp 0.310000 3.210000 2.100000
vp ...
...
# Polygonal face element (see below)
f 1 2 3
f 3/1 4/2 5/3
f 6/4/1 3/5/3 7/6/5
f 7//1 8//2 9//3
f ...
...
# Line element (see below)
l 5 8 1 2 4 9

1.1 几何顶点

顶点(Vertex)通过以字母 v 开头的行指定。后面是 (x,y,z[,w]) 坐标。 W 是可选的,默认为 1.0。 右手坐标系用于指定坐标位置。 某些应用程序通过在 x y 和 z 之后放置红色、绿色和蓝色值来支持顶点颜色(这会排除指定 w)。 颜色值范围从 0 到 1。

1.2 参数空间顶点

可以在以字符串 vp 开头的行中指定自由格式的几何语句。 在曲线或曲面的参数空间中定义点。 曲线点只需要u,非有理裁剪曲线的曲面点和控制点需要u 和v,有理裁剪曲线的控制点需要u、v 和w(权重)。

1.3 面元素

面(Face)是使用顶点、纹理和法线索引列表定义的,格式为 vertex_index/texture_index/normal_index,每个索引从 1 开始,并根据引用元素的定义顺序递增。 诸如四边形之类的多边形可以使用三个以上的索引来定义。

OBJ 文件还支持使用曲线和曲面来定义对象的自由形式几何体,例如 NURBS 曲面。

1.4 顶点索引

有效的顶点索引(Vertex indices)与先前定义的顶点列表的相应顶点元素相匹配。 如果索引为正,则它引用该顶点列表中的偏移量,从 1 开始。如果索引为负,则它相对引用顶点列表的末尾,-1 引用最后一个元素。

每个面可以包含三个或更多顶点。

f v1 v2 v3 ....

1.5 顶点纹理坐标索引

可选地,纹理坐标索引(Vertex texture coordinate indices)可用于在定义面时指定纹理坐标。 要在定义面时将纹理坐标索引添加到顶点索引,必须在顶点索引后紧接着放置斜线,然后放置纹理坐标索引。 斜杠前后不允许有空格。 有效的纹理坐标索引从 1 开始,与先前定义的纹理坐标列表中的相应元素匹配。 每个面可以包含三个或更多元素。

f v1/vt1 v2/vt2 v3/vt3 ...

1.6 顶点法线索引

或者,在定义面时,可以使用法线索引(Vertex normal indices)来指定顶点的法线向量。 要在定义面时将法线索引添加到顶点索引,必须在纹理坐标索引后放置第二个斜杠,然后放置法线索引。 有效的法线索引从 1 开始,并与先前定义的法线列表中的相应元素匹配。 每个面可以包含三个或更多元素

f v1/vt1/vn1 v2/vt2/vn2 v3/vt3/vn3 ...

1.7 没有纹理坐标索引的顶点法线索引

由于纹理坐标是可选的,因此可以在没有纹理坐标的情况下定义几何体,但必须在放置法线索引之前在顶点索引后面放置两个斜杠。

f v1//vn1 v2//vn2 v3//vn3 ...

1.8 线元素

以字母“l”(小写 L)开头的记录指定构建多段线(Polyline)的顶点的顺序。

l v1 v2 v3 v4 v5 v6 ...

1.9 其他几何格式

Obj 文件使用几种不同类型的插值(例如泰勒和 B 样条)支持高阶曲面,尽管第三方文件读取器对这些功能的支持还远未普及。 Obj 文件也不支持网格层次结构或任何类型的动画或变形,例如顶点蒙皮或网格变形。

1.10 材质引用

描述多边形视觉方面的材质存储在外部 .mtl 文件中。 OBJ 文件中可以引用多个外部 MTL 材料文件。 .mtl 文件可能包含一个或多个命名材质的定义。

mtllib [external .mtl file name]
...

该标签指定其后面的元素的材质名称。 材质名称与外部 .mtl 文件中的命名材质定义匹配。

usemtl [material name]
...

命名对象和多边形组通过以下标签指定。

o [object name]...g [group name]...

通过平滑组可以实现跨多边形的平滑着色。

s 1...# Smooth shading can be disabled as well.s off...

1.11 相对索引和绝对索引

OBJ 文件由于其列表结构,能够通过绝对位置(1 表示第一个定义的顶点,N 表示第 N 个定义的顶点)或相对位置(-1 表示最后定义的顶点)来引用顶点、法线等。

然而,并非所有软件都支持后一种方式,相反有些软件本质上只编写后一种形式(由于附加元素方便,无需重新计算顶点偏移量等),导致偶尔出现不兼容的情况。

2、材质模板库

材质模板库格式 (MTL) 或 .MTL 文件格式是 .OBJ 的配套文件格式,也由 Wavefront Technologies 定义,它描述一个或多个 .OBJ 文件中对象的表面着色(材质)属性。

.OBJ 文件引用一个或多个 .MTL 文件(称为“材质库”),并从那里按名称引用一个或多个材质描述。 .MTL 文件是 ASCII 文本,它根据 Phong 反射模型定义表面的光反射属性,以供计算机渲染之用。 该标准在不同的计算机软件包之间得到了广泛的支持,使其成为材料交换的有用格式。

MTL 格式虽然仍然广泛使用,但已经过时,并且不完全支持高光贴图和视差贴图等后来的技术。 然而,由于该格式的开放性和直观性,可以使用自定义 MTL 文件生成器轻松添加这些内容。

MTL 格式定义了多种格式。

2.1 基础材质

单个 .mtl 文件可以定义多种材质。 材质在文件中被逐个定义,每个材质都以 newmtl 命令开始:

# define a material named 'Colored'
newmtl Colored

材质的环境色(ambient)使用 Ka 声明。 颜色定义采用 RGB 格式,其中每个通道的值介于 0 和 1 之间。

# white
Ka 1.000 1.000 1.000

类似地,漫反射色(diffuse)是使用 Kd 声明的。

# white
Kd 1.000 1.000 1.000

镜面反射色(specular)使用 Ks 声明,并使用镜面指数 Ns 进行加权。

# black (off)
Ks 0.000 0.000 0.000# ranges between 0 and 1000
Ns 10.000

材质可以是透明的。 这称为 消融(dissolved)。 与真正的透明度不同,结果不取决于物体的厚度。 “d”的值为 1.0 是默认值,表示完全不透明,“Tr”的值为 0.0 也是如此。 消融适用于所有照明模型。

# some implementations use 'd'
d 0.9
# others use 'Tr' (inverted: Tr = 1 - d)
Tr 0.1

透明材料还可以具有透射滤光片颜色,用“Tf”指定。

# Transmission Filter Color (using R G B)
Tf 1.0 0.5 0.5 
# Transmission Filter Color (using CIEXYZ) - y and z values are optional and assumed to be equal to x if omitted
Tf xyz 1.0 0.5 0.5 
# Transmission Filter Color from spectral curve file (not commonly used)
Tf spectral <filename>.rfl <optional factor>

材质的表面也可以具有光密度(optical density), 这也称为折射率(index of refraction)。

# optical density
Ni 1.45000

值的范围可以从 0.001 到 10。值 1.0 表示光线在穿过对象时不会弯曲。 增加光密度会增加弯曲量。 玻璃的折射率约为1.5。 小于 1.0 的值会产生奇怪的结果,不推荐使用。

每种材质都有多种照明模型可用。 请注意,不需要设置透明照明模型来实现“d”或“Tr”的透明度,并且在现代使用中,即使使用透明材质,通常也不会指定照明模型。 照明模型列举如下:

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

2.2 纹理贴图

纹理材质(Texture material)使用与上面相同的属性,并另外定义纹理贴图。 以下是常见材质文件的示例。 有关更多详细信息,请参阅完整的 Wavefront 文件格式参考。

newmtl TexturedKa 1.000 1.000 1.000Kd 1.000 1.000 1.000Ks 0.000 0.000 0.000d 1.0illum 2# the ambient texture mapmap_Ka lemur.tga# the diffuse texture map (most of the time, it will be the same as the# ambient texture map)map_Kd lemur.tga# specular color texture mapmap_Ks lemur.tga# specular highlight componentmap_Ns lemur_spec.tga# the alpha texture mapmap_d lemur_alpha.tga# some implementations use 'map_bump' instead of 'bump' belowmap_bump lemur_bump.tga# bump map (which by default uses luminance channel of the image)bump lemur_bump.tga# displacement mapdisp lemur_disp.tga# stencil decal texture (defaults to 'matte' channel of the image)decal lemur_stencil.tga

纹理贴图语句也可能有选项参数(参见完整规范)

   # texture origin (1,1,1) map_Ka -o 1 1 1 ambient.tga# spherical reflection maprefl -type sphere clouds.tga

2.3 纹理选项

-blendu on | off                       # set horizontal texture blending (default on)
-blendv on | off                       # set vertical texture blending (default on)
-boost float_value                     # boost mip-map sharpness
-mm base_value gain_value              # modify texture map values (default 0 1)#     base_value = brightness, gain_value = contrast
-o u [v [w]]                           # Origin offset             (default 0 0 0)
-s u [v [w]]                           # Scale                     (default 1 1 1)
-t u [v [w]]                           # Turbulence                (default 0 0 0)
-texres resolution                     # texture resolution to create
-clamp on | off                        # only render texels in the clamped 0-1 range (default off)#   When unclamped, textures are repeated across a surface,#   when clamped, only texels which fall within the 0-1#   range are rendered.
-bm mult_value                         # bump multiplier (for bump maps only)-imfchan r | g | b | m | l | z         # specifies which channel of the file is used to # create a scalar or bump texture. r:red, g:green,# b:blue, m:matte, l:luminance, z:z-depth.. # (the default for bump is 'l' and for decal is 'm')

例如,

# says to use the red channel of bumpmap.tga as the bumpmap
bump -imfchan r bumpmap.tga

对于反射贴图…

-type sphere                           # specifies a sphere for a "refl" reflection map    
-type cube_top    | cube_bottom |      # when using a cube map, the texture file for eachcube_front  | cube_back   |      # side of the cube is specified separatelycube_left   | cube_right

2.4 供应商特定变更

由于解析文件的容易性以及文件格式的非官方传播,文件可能包含供应商特定的更改。

根据规范,选项应该位于纹理文件名之前。 但是,至少有一个供应商会生成末尾带有选项的文件。

# bump multiplier of 0.2
bump texbump.tga -bm 0.2

2.5 基于物理的渲染

在线 3D 编辑和建模工具 Clara.io 的创建者建议扩展 MTL 格式,以指定基于物理的渲染 (PBR) 贴图和参数。 此扩展随后被 Blender 和 TinyObjLoader 采用。 扩展 PBR 映射和参数为:

Pr/map_Pr     # roughness
Pm/map_Pm     # metallic
Ps/map_Ps     # sheen
Pc            # clearcoat thickness
Pcr           # clearcoat roughness
Ke/map_Ke     # emissive
aniso         # anisotropy
anisor        # anisotropy rotation
norm          # normal map (RGB components represent XYZ components of the surface normal)

进一步提议的扩展来自 Microsoft DirectX 引擎的 DirectXMesh 工具包,允许定义模型的预编译 RMA 材质。

map_RMA       # RMA material (roughness, metalness, ambient occlusion)
map_ORM       # alternate definition of map_RMA

原文链接:Wavefront .OBJ格式说明 — BimAnt

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/26336.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

node.js安装

下载 https://nodejs.org/en 安装 D:\Program Files\nodejs 配置 D:\Program Files\nodejs 目录下新建 node_cache 和 node_global 在cmd管理员身份运行&#xff1a; npm config set prefix "D:\Program Files\nodejs\node_global" npm config set cache &qu…

算法通关村第五关——HashMap和队列问题分析

1.HashMap 1.1Hash的概念和基本特征 哈希(Hash)&#xff1a;也称为散列。就是把任意长度的输入&#xff0c;通过散列算法&#xff0c;变换成固定长度的输出&#xff0c;这个输出值就是散列值。 假设数组array存放的是1到15这些数&#xff0c;现在要存在一个大小是7的Hash表中…

Android 刷新与显示

目录 屏幕显示原理&#xff1a; 显示刷新的过程 VSYNC机制具体实现 小结&#xff1a; 屏幕显示原理&#xff1a; 过程描述&#xff1a; 应用向系统服务申请buffer 系统服务返回一个buffer给应用 应用开始绘制&#xff0c;绘制完成就提交buffer&#xff0c;系统服务把buffer数据…

7_分类算法—逻辑回归

文章目录 逻辑回归&#xff1a;1 Logistic回归&#xff08;二分类问题&#xff09;1.1 sigmoid函数1.2 Logistic回归及似然函数&#xff08;求解&#xff09;1.3 θ参数求解1.4 Logistic回归损失函数1.5 LogisticRegression总结 2 Softmax回归&#xff08;多分类问题&#xff0…

Oracle安装与配置

一 把windows2003拖到vm里去 1.1 加一块虚拟网卡 1.2 把网卡信息改一下 配完之后点一下应用 这个地方改成一个不是1但是在255之内的数&#xff0c;就可以 二 后面调试很久&#xff0c;失败了 后面还有一些步骤&#xff0c;但是总的来说&#xff0c;这次安装失败了&#xf…

适合自己企业的erp系统怎么选?这8条关键因素缺一不可!

一文看懂&#xff1a;如何选择适合自己企业的ERP系统&#xff1f;选型过程中有哪些关键因素需要考虑&#xff1f; 无论你是多大规模的企业&#xff0c;看懂这一篇&#xff0c;你都能受用无穷。 哪怕你需求复杂&#xff0c;现成ERP系统无法满足&#xff0c;最后我也给出了一条…

政府大数据资源中心建设总体方案[56页PPT]

导读&#xff1a;原文《政府大数据资源中心建设总体方案[56页PPT]》&#xff08;获取来源见文尾&#xff09;&#xff0c;本文精选其中精华及架构部分&#xff0c;逻辑清晰、内容完整&#xff0c;为快速形成售前方案提供参考。 完整版领取方式 完整版领取方式&#xff1a; 如需…

Zebec Protocol ,不止于 Web3 世界的 “Paypal”

Paypal是传统支付领域的巨头企业&#xff0c;在北美支付市场占有率约为77%以上。从具体的业务数据看&#xff0c;在8月初&#xff0c;Paypal公布的2023年第二季度财报显示&#xff0c;PayPal第二季度净营收为73亿美元&#xff0c;净利润为10.29亿美元。虽然Paypal的净利润相交去…

javaWeb项目--二级评论完整思路

先来看前端需要什么吧&#xff1a; 通过博客id&#xff0c;首先需要显示所有一级评论&#xff0c;包括评论者的头像&#xff0c;昵称&#xff0c;评论时间&#xff0c;评论内容 然后要显示每个一级评论下面的二级评论&#xff0c;包括&#xff0c;评论者的头像&#xff0c;昵称…

6.s081/6.1810(Fall 2022)Lab5: Copy-on-Write Fork for xv6

前言 本来往年这里还有个Lazy Allocation的&#xff0c;今年不知道为啥直接给跳过去了。. 其他篇章 环境搭建 Lab1: Utilities Lab2: System calls Lab3: Page tables Lab4: Traps Lab5: Copy-on-Write Fork for xv6 参考链接 官网链接 xv6手册链接&#xff0c;这个挺重要…

Windows下安装Scala(以Scala 2.11.12为例)

Windows下安装Scala&#xff08;以Scala 2.11.12为例&#xff09; 一、Scala2.11.12官网下载二、Scala2.11.12网盘下载三、Scala各版本下载地址四、Scala安装4.1、点击 scala-2.11.12.msi 文件安装4.2、设置环境变量 %SCALA_HOME%4.3、环境变量Path添加条目%SCALA_HOME%\bin 四…

1466. 重新规划路线

题目描述&#xff1a; 主要思路&#xff1a; 将所有有向边抽象为无向边&#xff0c;将原有的方向权重置为1&#xff0c;其余置为0。 从0开始遍历所有城市&#xff0c;ans权重和。 class Solution { public:vector<vector<int>> a,w;int ans0;bool book[500010];v…

使用yarn启动项目报错

使用yarn启动项目报错 解决方法&#xff1a; 1.点击“开始”菜单搜索找到 Windows PowerShell ISE并以管理员身份运行(注&#xff1a;不是以管理员的身份直接运行cmd) 2. 输入 set-ExecutionPolicy RemoteSigned 回车 3.输入&#xff08;选择全是&#xff09; 4.再输入get-Exe…

生成小程序二维码、小程序码

微信自定义生成二维码 使用微信云开发生成自定义二维码、小程序码话不多说&#xff0c;我们先来看最终的展示效果生成码有三种方式操作步骤1. 云环境的初始化2. 在页面上开辟一个容器来展示二维码&#xff08;包括预览和保存到相册的按钮&#xff09;3. 创建云函数4. 生成二维码…

RabbitMQ的6种工作模式

RabbitMQ的6种工作模式 官方文档&#xff1a; http://www.rabbitmq.com/ https://www.rabbitmq.com/getstarted.html RabbitMQ 常见的 6 种工作模式&#xff1a; 1、simple简单模式 1)、消息产生后将消息放入队列。 2)、消息的消费者监听消息队列&#xff0c;如果队列中…

在Raspberry Pi 4上安装Ubuntu 20.04 + ROS noetic(不带显示器)

在Raspberry Pi 4上安装Ubuntu 20.04 ROS noetic&#xff08;不带显示器&#xff09; 1. 所需设备 所需设备&#xff1a; 树莓派 4 B 型 wifi microSD 卡&#xff1a;最小 32GB MicroSD 转 SD 适配器 &#xff08;可选&#xff09;显示器&#xff0c;鼠标等 2. 树莓派…

机器学习---概述(二)

文章目录 1.模型评估1.1 分类模型评估1.2 回归模型评估 2. 拟合2.1 欠拟合2.2 过拟合2.3 适当拟合总结&#xff1a; 3.深度学习3.1层次&#xff08;Layers&#xff09;&#xff1a;3.2 神经元&#xff08;Neurons&#xff09;&#xff1a;3.3 总结 1.模型评估 模型评估是机器学…

【Linux操作系统】Vim:提升你的编辑效率

Vim是一款功能强大的文本编辑器&#xff0c;它具有高度可定制性和灵活性&#xff0c;可以帮助程序员和文本编辑者提高编辑效率。本文将介绍Vim的基本使用方法、常用功能和一些实用技巧。 文章目录 1. Vim的基本使用方法&#xff1a;2. 常用功能&#xff1a;2.1 文件操作&#…

Qt应用开发(基础篇)——时间类 QDateTime、QDate、QTime

一、前言 时间类QDateTime、QDate、QTime、QTimeZone保存了Qt的时间、日期、时区信息&#xff0c;常用的时间类部件都会用到这些数据结构&#xff0c;常用概念有年、月、日、时、分、秒、毫秒和时区&#xff0c;时间和时区就关系到时间戳和UTC的概念。 UTC时间&#xff0c;又称…

Baumer工业相机堡盟工业相机如何通过BGAPI SDK获取相机当前数据吞吐量(C#)

Baumer工业相机堡盟工业相机如何通过BGAPISDK里函数来获取相机当前数据吞吐量&#xff08;C#&#xff09; Baumer工业相机Baumer工业相机的数据吞吐量的技术背景CameraExplorer如何查看相机吞吐量信息在BGAPI SDK里通过函数获取相机接口吞吐量 Baumer工业相机通过BGAPI SDK获取…