光照模型
Lambert
粗糙的物体表面向各个方向等强度的反射光,这种等同地向各个方向散射的现象称为光的漫反射(diffuse reflection)。漫反射符合兰伯特定律(Lambert’s law):反射光线的强度与表面法线和光源方向之间的夹角成正比。这是一种理想的漫反射模型,也被称为兰伯特光照模型。
- 漫反射:
cdiffuse=(clight⋅mdiffuse)max(0,n⃗ ⋅l⃗ )
c
d
i
f
f
u
s
e
=
(
c
l
i
g
h
t
⋅
m
d
i
f
f
u
s
e
)
m
a
x
(
0
,
n
→
⋅
l
→
)
clight
c
l
i
g
h
t
:入射光线的颜色和强度。
mdiffuse
m
d
i
f
f
u
s
e
:材质的漫反射系数,
n⃗
n
→
:表面法线
l⃗
l
→
:光源方向(指向光源)
Half Lambert
使用Lambert漫反射光照模型有一个缺点:背光面明暗一样,看起来想一个平面一样,失去了模型细节。于是一种改善的技术提了出来:半兰伯特(Half Lambert)光照模型。
- 广义的半兰伯特光照模型公式:
cdiffuse=(clight⋅mdiffuse)(a(n⃗ ⋅l⃗ )+b)
c
d
i
f
f
u
s
e
=
(
c
l
i
g
h
t
⋅
m
d
i
f
f
u
s
e
)
(
a
(
n
→
⋅
l
→
)
+
b
)
绝大多是情况下a和b的值均为0.5。
Phong
早期的游戏引擎中往往只有一个光照模型,就是标准光照模型。标准光照模型只关心直接光照,也就是那些直接从光源发射出来照射到物体表面后经过物体表面的一次反射直接进入摄像机的光线。
因为裴祥风(Bui Tuong Phong)首先提出了使用漫反射和高光反射的和来对反射光照进行建模的基本思想,并且提出了基于经验的计算高光反射的方法。所以标准光照模型也被称为Phong光照模型。
它的计算方法是,把进入到摄像机内的光线分为4个部分,每个部分使用一种方法来计算它的贡献度:
-
自发光(emissive),用于描述当给定一个方向时,一个表面本身会向该方向发射多少辐射量。
cemissive=memissive
c
e
m
i
s
s
i
v
e
=
m
e
m
i
s
s
i
v
e
memissive是材质的自发光颜色。
-
高光反射(specular),用于描述当光线从光源照射到模型表面时,该表面会在完全镜面反射方向散射多少辐射量。
使用Phong模型计算高光反射, 图片来源
计算公式:
cspecular=(clight⋅mspecular)max(0,v⃗ ⋅r⃗ )mgloss
c
s
p
e
c
u
l
a
r
=
(
c
l
i
g
h
t
⋅
m
s
p
e
c
u
l
a
r
)
m
a
x
(
0
,
v
→
⋅
r
→
)
m
g
l
o
s
s
这就是Phong提出的基于经验的高光反射模型。其中:
clight
c
l
i
g
h
t
:入射光线的颜色和强度,
mspecular
m
s
p
e
c
u
l
a
r
:材质的高光反射颜色,
v⃗
v
→
:视角方向(指向摄像机) ,
r⃗
r
→
:光线反射方向,
mgloss
m
g
l
o
s
s
:材质的光泽度(gloss),也被称为反光度(shiness)。
反射方向
r⃗
r
→
计算方法:
r⃗ =2(n⃗ ⋅l⃗ )n⃗ −l⃗
r
→
=
2
(
n
→
⋅
l
→
)
n
→
−
l
→
- 漫反射(diffuse),用于描述当光线从光源照射到模型表面时,该表面会向每个方向散射多少辐射量。
即上面的Lambert定律:
cdiffuse=(clight⋅mdiffuse)max(0,n⃗ ⋅l⃗ )
c
d
i
f
f
u
s
e
=
(
c
l
i
g
h
t
⋅
m
d
i
f
f
u
s
e
)
m
a
x
(
0
,
n
→
⋅
l
→
)
- 环境光(ambient),用于描述其他所有的间接光照。
cambient=gambient
c
a
m
b
i
e
n
t
=
g
a
m
b
i
e
n
t
环境光gambient通常是一个全局变量,即场景中的所有物体都使用了这个环境光。
Blinn Phong
Blinn提出了一个简单的修改方法来得到与Phong高光反射模型类似的效果,它的基本思想是,避免计算反射方向
r⃗
r
→
。Blinn模型引入了一个新的矢量
h⃗
h
→
。计算方法为:
h⃗ =v⃗ +l⃗ |v⃗ +l⃗ |
h
→
=
v
→
+
l
→
|
v
→
+
l
→
|
然后使用
n⃗
n
→
和
h⃗
h
→
之间的夹角进行计算,而非
v⃗
v
→
和
r⃗
r
→
之间的夹角。
Blinn模型 图片来源
Blinn模型的公式:
cspecular=(clight⋅mspecular)max(0,n⃗ ⋅h⃗ )mgloss
c
s
p
e
c
u
l
a
r
=
(
c
l
i
g
h
t
⋅
m
s
p
e
c
u
l
a
r
)
m
a
x
(
0
,
n
→
⋅
h
→
)
m
g
l
o
s
s