作者:Carmack
H7 [* V2 E8 l. U. u) n
3 h! c% D0 ?7 [8 P9 O 关于阿凡提...
$ J6 t: P- I E$ j6 ?
# \. d P& o8 s8 C. z6 C: h 制作一个像阿凡提这样的角色前,通常要了解一下他的历史... "阿凡提"并不是人名,而是一种称号,他源自于突厥语:"Efcndi"(由于音译,可能拼法会有不同)。意为"先生"、"老师",是对有学问、有知识人的尊称。他的本名是"纳斯尔丁(Nasreddin)"。纳斯尔丁·阿凡提究竟是真实的历史人物,还是一个流传于民间的虚构人物,众说纷纭。关于他的国籍,似乎也未有定论,维吾尔族朋友说他十二世纪出生在中国新疆的喀什,乌兹别克人说他出生在乌兹别克斯坦的布哈拉,阿拉伯人说他出生在伊拉克的巴格达,土耳其人则说他出生在土耳其西南部的阿克谢海尔城…不过可以肯定的是,阿凡提现在已经成为了一个世界性的人物形象,他的故事在世界各地广为流传…好像扯远了,呵~~ 在国内,大众对阿凡提这个形象的了解认识可能大都源于上海美术电影制片厂于七、八十年代拍摄的木偶系列片《阿凡提的故事》。
0 h" a8 t2 v6 B# e+ F
5 d# G7 F+ N! f y ![]()
, V7 P( N- X7 |! I9 e2 c4 v
) b. i7 s. J1 d' X/ X: E, n, A5 X0 m 在做之前,我先从网上DOWN了一些片子,虽然清晰度很低,但做参考素材还是基本可以了。DOWN下来后,首先把片子通看几遍,找找感觉。同时从片中截取了大量的图片(如上)。看完后把截取下来的图片进行分类,以便于日后制作时方便查找5 U& u. \4 q" W ]& F& C# K0 v
" y# T) D9 Q3 Y1 Z7 X! P- v 接下来就进入实际制作阶段7 I; v) L: H$ e( D- ]% H% J/ \
. [7 k) l! S! {& N. t/ |9 v" v 模型部分$ f8 Q$ U/ r2 v7 m6 }2 Q4 K
& d4 R# ?0 w4 n 首先是建筑,我从众多截取下来的图片中选中了几个我认为是片中比较有特色的,有代表性的建筑。由于考虑到最后的场景可能比较大,所以没有集中到一起建模,而是采取各自单独建立模型,最后合并场景的方法。(如图)是我建的各种场景模型(当然,他们的样子看起来可能与原系列片会有些小的区别。),每个模型在建立时随手都赋予了相应的材质,但大都没有进行精细的调节。因为场景还没有合并,灯光也还没有建立,此时进行过细的材质设定没有意义。3 z* ]9 b% Y% M5 [0 Y4 |" b# b& H
8 p7 v& y/ v$ r W3 c
7 v1 v( n, _0 B2 i; O
! T% Z7 ~4 {: ?3 O7 | 制作初期时还做了一张预告图放到CDV,HXSD内部论坛里。~~呵
7 C5 F4 c! \7 G" I
& C. g4 A3 F) z R, f' h% i) B ![]()
# x8 f# ~* `3 ~# W- O# [' p' J) O( f, w5 z* @; ?- W# N" I
继续..上面的那些模型并不复杂,在此不做详叙~大部分都是多边形建模,有些个别的(比如罐子)使用了NURBS。 在建模过程中我使用了一个MAYA小MEL插件:Randomize Points v1.6 它可以对选择的模型的点做随机变形,在这幅作品的建模程中我大量的使用了这个插件,给建模节省了不少时间
: w% \: |/ x# Y$ B
% r1 |8 `: A# g. A+ v 9 ~9 b+ g% r9 l" r ~. w0 S. _ V4 R
) j) J- P* p1 M" M4 w
模型建完后,开始将大部分主要的建筑及物品合并成为一个场景。(图)是当时对场景的初步布局。
+ }! y/ F# v0 C+ l3 ? t p$ }" g" D# c/ \ p& k: _
& q* o1 f5 v! L0 [0 ^4 J0 Y
" O3 @ A4 W( X. m
关于角色,经过仔细考虑,选择了这个阿凡提常用的经典动作,歪着头,手里拿一根小草在他那头驴的头顶晃来晃去… 因为没有打算做动画,所以模型是直接建成这种姿势的。/ i" k l8 w- P! s
; N) s" w. U) W K: _; P# P
4 } E. _! Q3 Y) g+ C3 ]
% M2 Q7 \2 M5 L9 Q& a$ J* O
灯光部分& F( [$ | a" `' {& ^/ p, L
8 L8 x D3 l C- |9 T
在灯光方面,我也使用了一个MAYA的插件:GI_Joe。它通过灯光阵列的方式模拟GI效果,很方便的让我们可以用较快的时间模拟出不错的天空光效。1 D! ~& E; t) s# L9 h6 k' W9 u" F
# Y: B% @3 U( t$ i; t! k8 `/ u$ r
GI_joe提供了多种数量的灯光阵列选择,考虑到渲染速度的问题,我选择了16/16的模式(也就是Skylight与Groundlight各16盏灯,一共32盏灯来做阵列): N3 D" ^+ f2 H- ?5 y6 b m, w2 ^9 e+ b
5 l4 ?7 B* ]: j, U% m ![]()
. S5 S- [1 ]6 `- a9 i8 W, r
8 M9 ` c0 v$ H( a' j: O4 I 4 A3 [" n! T9 q/ K# @2 z
! Y1 u7 S6 Q2 Z
除了用GI_Joe建造的灯光阵列外,场景中还自己手工设了一些灯光。 (如上图)就是场景中所有灯光的示意图,我用英文字母给每一盏灯做了标记,下边依次解释一下他们的作用。3 J1 E$ T( l2 l2 l5 P4 E6 S" c
1 _8 I; X. H7 e( l) f- ^ ![]()
1 O7 {: x, k2 l7 R6 s0 L! _5 I! C& s/ N$ \( V, y; c
(A).这盏灯是模拟场景中的太阳光直射,并生成阴影。是场景中主光源。(光源类型为Directional Light)
& R( i* {6 g+ y8 q; V) K7 ?4 K) X; X) {8 o& `
(B).灯光照射角度与A几乎一致,是一盏聚光灯(Spot Light),此灯并不参与照明,而是主要用来生成灯光雾,用来模拟环境中的大气效果。以此来加强场景的空间感。' K( P: R; r( e
X, Z' i! N, c7 }2 i( o
(C).此聚光灯(Spot Light)通过对其Color属性进行帖图,来模拟类似于树阴的光影效果,来丰富地面的变化。1 E3 v7 o) j2 ~4 Q' C
# v [3 ?! _- A3 T; R: \
(D).是一个面光灯(Area Light),用来加强伞下石头的漫反射效果,使其不至于显得太飘。关于这一点,可能大家不太明白。在后边我会做具体的解释。
8 w& \5 M- A! t" c2 i4 N) @, P) |: @' ^
(E).此灯与D是类似的作用。# o5 K' I1 L2 N
7 G( O. r4 J% [! v3 f. A/ X
(F).这是一盏体积灯(Volume Light),此灯的亮度为负值,功能是给尖顶房子的大门内部面降低亮度,这里使用体积灯是因为它的光照范围可以很容易控制。% ]5 x+ a. ~* K6 W, ]" V2 \
2 H L' y$ h: a& P- \& C
(G)与F类似,主要是给楼梯下面的小储藏室降低亮度。0 w! X) b7 y5 L$ R7 M3 k1 r8 K& E& N- l. m
" r2 o1 t7 r/ K0 C5 W% f4 f
(H)(I)(J)(K)(L)这几盏灯都是为角色单独提供照明用的。其实有的灯并不产生实际的照明,而只是产生高光。比如大家可以注意观察一下阿凡提的靴子,会发现在阿凡提的靴子上有着丰富的高光(这也是能够体现靴子质感最重要的部分)(如图),另外阿凡提的眼睛的高光点也由单独的灯光生成。
' s# o& j, b' k7 f; e& Q9 W" y. M& g" S! _ E4 ^
(M)GI_Joe生成的灯光阵列。主要模拟场景中的漫反射效果。; ^9 I0 ]7 _( f
M8 n: _) `4 J
![]()
+ Q4 k' c M b# b- e2 f( i! l+ D( s2 `" g1 i2 x8 I K
为了使大家可以更清楚的认识以上灯光的用处。我特意将GI_Joe的照明效果与自定义灯光的照明效果各自单独生成一张图。大家可以比较一下。其实把这两张图叠加起来,就是渲染的最终效果了。(如图,上图是自定义灯光的单独照射效果,下图是GI_Joe的单独照射效果)7 x- O1 U9 r8 l4 E; e
9 A0 L4 K# N3 Q1 z2 n$ Z, y
( t' D9 U# V! O' E
" t* E0 W) P9 x9 t1 [3 ^6 |
下面回过头我再谈谈(D)(E)两盏灯的作用。前边我们提到了,场景中用GI_Joe生成的灯光阵列进行漫反射照明。它是依靠阵列中每盏灯的深度帖图阴影组合在一起来体现漫反射效果的。而深度帖图阴影的特点,是他会随着场景的复杂程度不同而不同。比如在深度帖图尺寸固定的情况下,场景越是复杂,效果就越模糊。反之就越锐利。所以如果想在比较复杂的场景中产生较清晰的漫反射效果就需要把阴影帖图尺寸设得足够高。 举例说明比较容易理解,如(图)所示。这是一个较简单的场景,场景中是一些碎石块儿。使用16/16的阵列来照明。图中红框框住的地方就是GI_Joe的深度帖图的尺寸设置。默认是128,图A就是在这种设置下的渲染效果。可以发现效果很不错。再看图B,图B是我在场景中加入其它建筑物品之类的东西后渲染的(当然,那些建筑并不在摄影机范围内),大家会发现由于新加入的建筑等物品都会分配掉有限的深度帖图资源,这使得分配给石头的帖图尺寸变小,从渲染效果上来看,就是漫射效果更模糊化,对于一些体积非常小的石块儿来说,漫反射效果几乎看不到了。石块儿像是从地面漂浮起来一样。失去了真实的感觉。可能有朋友会讲,按照前面的说法,将刚才那个帖图的尺寸值"128"提高不就可以解决这个问题了吗!,理论上是这样的。不过对于非常复杂的场景,想要使如此细小的石子都看得出漫反射效果,要把这个值提到很高才可以。暂不管GI_Joe是否可以无限制的提高帖图尺寸值。我们可以先想像一下,这个值实际上是同时对32盏灯起作用,一但提得太高会使渲染时间和内存占用成几十倍的增长,所以这并不是一个好办法。 我采用的是另一种方法。在石头的上方垂直建立一盏灯(作品中实际用的面光灯Area Light,而这里的演示场景我使用的是方向灯Directional Light)并打开阴影。这样就可以生成类似于A的效果(效果如图C),虽然效果上可能会比A来差一些,但渲染时间却几乎没有增加。控制起来也很方便,不会影响场景的其它部分。 为了使新加入的垂直方向的灯不至于影响当前的已经设置好的光照效果,可将其亮度值设得很低(比如0.001),而后将阴影亮度值以同样的比例调低。或者也可以在同样的位置再建立一盏同样类型的灯(但不开阴影),把灯亮度值调整为互相抵消状态(比如原灯亮度为1,那么此灯亮度设置为-1),这样,事实上灯光对场景的影响就消失了。只留下了我们需要的阴影效果。
0 R& Q4 K$ I- W- P2 v; D# L) q& N a/ W: J+ r
![]()
- V4 e- `* ?; o9 t, E( Y H% D
" z2 A- d: e8 o 类似的问题,有些地方我用了另一种方法。我想这张图可能大家都看得明白,就不多说了。(如图)所示
& N5 Y5 i9 _. U, u2 C- D9 `
( x' ^0 Q2 n5 r5 c; ~9 |7 z : T/ e6 S. F" ^% E/ }+ a
: [; L2 D5 K6 L, v2 g6 i6 M 材质部分
# `8 W) R! r' `3 I$ m5 F" ]0 I; y8 {- l: |4 N* g: @! k0 f
下面讨论一下材质方面的问题。 上图是场景中的材质球总图! y/ @2 _- l+ [7 D0 A
) h5 h: I; |0 ~9 D i" L0 z
![]()
1 I1 l5 ]: O2 ^7 {; v. \2 H1 ]
# w* ? ~9 d/ S 是场景中的纹理帖图总图(包括位图纹理、2D程序纹理、3D程序纹理)。 在此幅作品的纹理设置中,除了非常不起眼的物品外,绝大部分物品我都使用了多层帖图(Layered Texture),因为我觉得这样会留下很大的调整余地,当然,这也会影响渲染速度
- I O" s2 ~0 L+ v( i. \/ N, K9 N* b0 H# b( Y$ k5 V
![]()
9 i {# ]# h" D5 I% N; J8 v
# D _5 n# z% `) g2 ` 从以上两张图可以看出,场景中使用了大量的材质球和纹理帖图。我们看一下纹理总图。不过如果仔细观察就不难发现有一种类型的帖图纹理我反复使用了很多次。这就是MAYA的2D程序纹理:Ramp
- I+ g: B6 U9 _1 k' f* b8 P- Z
, Z3 ^4 \0 I) J; _ ![]()
0 Z8 e/ b* D& i" ^& ^; ?& h, L$ v/ O! h$ P' F4 k
这个看似不太起眼的纹理在场景中的应用得十分广泛,可以说遍布了场景中的各个角落。下面举一个最简单的例子(如图):两个完全一样的多边形立方体,左边的使用了Maya默认的Lambert材质,右边的则在Lambert材质的基础上对Color属性帖了一个Ramp纹理(注意红框中的Ramp纹理参数设置)。我们会发现,右边加了Ramp纹理的立方体的质感变得强烈起来了。
2 M9 t8 |3 C; k( R7 s' X1 M
, J; O/ U9 I- {3 `% v4 w- x ![]()
2 t) ]8 W3 o7 z& ^% G. _6 R7 T9 g
0 J. a' {# x! A- `3 b z1 h: S 为了便于大家理解,我再从场景中提出其中一个尖顶的小屋来做为例子说明一下Ramp的用处。(如图),这个建筑非常具有典型性,因为它几乎每一个元素都使用到了Ramp这个纹理。我们可以看一下在同样光照的状态,使用了Ramp纹理(上图)和不使用Ramp纹理(下图)他们的对比渲染效果。图中以房体的材质为例,展示了Ramp的用处。如图所示,房体使用的是Layered Texture,也就是通过两层或两层以上的纹理的叠加来表现复杂的效果(叠加模式可以自选,这有些类似于PHOTOSHOP中图层之间的叠加模式)。相类似的,此建筑中每一个元素都是这样。/ r, s7 _4 U* n
1 E6 S5 B' M! C" U: l, j2 c% {
![]()
- m0 ^9 _7 R8 K. p
: o' s9 s+ l1 f, @; s 同样的问题,场景中有些物品由于其形状的特殊性,用Ramp达不到很好的效果,所以我直接制作了专门的帖图,用帖图来代替Ramp模拟这种效果。(如图)所示
7 y6 X6 z5 [; t2 M1 W/ F
/ A( V8 v; Y& g% H ![]()
* _9 G; ~2 \6 B7 v& C5 t4 U8 t- c& Q( ~
关于地面,最初本来打算使用多层程序纹理配合高密集的置换来制作,(如图)所示,就是我在开始时做的测试。效果是比较满意的: G+ ~, \# C( P
' x/ \& J+ _; p/ K
! f2 X4 y8 C3 i, z
5 N( ]. Z# ?$ m$ o- w2 j: m9 s- t- b
但后来在实际使用时发现,由于场景中的地面面积非常大,如此高密集的置换所带来的计算量实在无法接受,而且经常出错。(maya渲染器的置换功能一直是被人抱怨的热点),最后只能放弃了全局置换而改为局部置换。(图)是最终的地面材质节点网和地面的顶视图渲染图。
4 s, R& }( ^; x6 s4 {; V! _0 R
' G8 h/ k; {" m# ~ # O1 z( R, a; s i1 t
5 {: h3 S8 L4 Y) U7 W 只在近景需要更多细节表现的水塘处使用了置换。(如图)所示,因为水与地面的衔接处显得太光滑了,缺欠细节。而加了置换之后效果就不同。水塘变得更加真实可信。
4 ?& {1 e" ]5 m4 s7 ^# @
! v& K/ m' }- t, D, M; \- r0 ^; y # D6 \; G! C: v. g0 F Y, z
. U9 Y7 G: r- B3 d
除了水塘外,水面也做了比较细致的加工,因为是近景,所以要多花些心思。 主要给水面加了波纹和由罐子里流出的奶迹等细节~。 水面只是一个NURBS平面,波纹并不是置换或直接建模得来的,而是向水面材质的Bump属性添加帖图而得的,帖图是由一张水纹照片经过在PHOTOSHOP中去色变形得到。(如图)所示,图中是水面的材质节点网和用到的两张帖图。注意,节点网中的纯白色的纹理其实是一张比较混沌的位图,用来表现水中牛奶的混沌效果。由于我调高了它的亮度值,所以在节点视图中显示为了全白色)
- x3 Z* b7 G; I+ _9 k
) A. @& p1 Y. Y, L' i. R9 S% o, i! @ ![]()
0 ^2 W$ o6 M V* B. M1 A; a1 D" K1 X6 N" d+ A
水塘最终效果!, u; E# Z, }. A; V
' G' L# P5 L' s& k! k7 T3 B5 Q
4 k- j' G/ e9 e) a* m0 J7 ]
. B5 p# Q" ]3 R% G, j 石头的材质是场景中为数不多的完全由程序纹理组成的材质之一(图)。大家看一下它的节点网,完全由3D程序纹理生成。同时一个2D Ramp纹理将石头分成上下两种颜色(如果注意观察一下就会发现石头的上半部分要比下半部分颜色来得浅),这其实是模拟石头浸在水中时的效果。(观察"水塘最终效果"中的石头也可以发现这一点)
D, I. U, @+ k
# x" {2 Z# B+ R" p ! r1 q2 S0 i( x: ]
+ N9 [4 h7 ]$ B2 E3 Z 本来想在网上找一些新疆传统花纹,可实在资料太少,Google搜了半天一无所获。于是我就自己制作了一些花纹,但总觉得不太地道,所以也没敢用得太多。(图) ^4 o' L2 O, \: H; \! x
7 P9 ^: y! ?4 A ![]()
, r8 k K) q0 ~4 ~1 J- b6 Y' T" H$ w7 n8 e6 f9 q" |. Y
角色方面,材质的设定也不是很复杂。以驴的身体材质为例。可能大家都会觉得驴子的身体有一种毛绒绒的感觉。这其实是使用了MAYA自4.5版后新加入的Ramp Shader材质,它可因灯光或摄影机角度的不同而使材质显现出不同的效果。(如图)所示,左侧为没有毛绒效果,右侧为有毛绒效果。大家仔细观察可以发现他们在参数设置上的差异造成的在实际效果上的不同点。当然,也可以自己手工连一个节点来实现类似的效果) q7 _% U) l3 c- M4 E
W* l6 l4 o8 W- J ![]()
5 X7 s; S+ h6 T S3 R9 }
! P" p/ b8 z, E 同样使用这种方法的还有场景中竖立着的伞及其它一些物品及房屋等: a6 a I$ C3 `2 X* x4 p
, D! S1 F$ P9 j7 s ~7 l) O 4 _' E/ P a$ N3 F% B7 G! V8 V
# F S" J( N: {/ T( v1 E
阿凡提的衣服及脸部手部都体现出一种布料的质地。在MAYA中主要通过2D Cloth这个程序纹理来模拟。; \& |1 l! U, }& S
& X$ \4 W& W5 r, X z$ q: \
. C( o1 l; c k$ c1 J
# ^) G/ E# L' b9 z# j) m$ p( |( s8 \
是阿凡提脸部的材质节点网。其它衣服之类的材质与之类似。0 ^( d6 W! N$ i+ B/ D
/ q& Q1 d) k: n/ ^ ![]()
% c6 f3 L0 j. ^% ?$ Y; ~$ V: N4 J3 H& d
天空在一张现成的图片基础上加工得到,帖在一个环境球上+ H t7 ^$ P/ o: G2 Y4 @$ W" w4 p8 I# ~
- X# a7 A9 o! E7 ?1 }$ |+ i1 D; {
![]()
! p/ i4 p3 M4 s7 C" ~9 X! {* ]. ^: K& a# A
屋顶烟囱冒出的烟雾使用了particleIllusion 3.0,它的2D粒子可以很方便的生成真实的烟雾效果。从中抓出几帧,到Photoshop里合成一下即可。 其实,加上烟雾也好,给水面加波纹也好,都是为了使场景"活"起来,不至于显得太死气沉沉的。
& e8 u" `0 E! P! P6 J1 c6 S6 z0 Z7 p( B$ Y. O' q }' u* I
![]()
2 U* E$ R! [! ~6 q: N
Q! |4 m% {; C. R 后期润色6 } j/ k. k. r$ F" s$ D
3 T" o* k$ S0 Z 我个人很注重后期的作用,对于静帧作品,后期软件当然是非Photoshop莫数了!直接由3D软件render出来的图或多或少都会有不满意的地方,比如整体的颜色可能会不太好啦,对比度或许也有问题…等等。有的朋友可能认为只有不用后期,直接由3D软件渲染出好图的才算高手。其实想一想,这些人可能是钻了牛角尖儿了。我以前也有同样的想法,不过现在我觉得,只要能达到满意的效果,我不在乎使用任何手段。况且在绝大多数情况下,在后期里解决问题要比去3D中修改、重新渲染效率要高得多。
. p9 P3 c9 m2 [$ A1 J7 R- B- p$ \2 k; [
现单就此图说说我对其进行润色的方法(注意:每幅作品情况都不相同,没有什么固定的操作模式,主要靠感觉): (如图)在Photoshop中将原始图层进行复制,对复制的位于上层的图层应用Gaussian Blur滤镜,将图层叠加模式改为"Soft Light",之后两图层结合为一个图层。此时图像可能会显得有些模糊,锐化一下,然后调一调色(比如改变一下色调,或饱和度等),大概就是这样。(如果你认为有必要的话,还可以单独生成Z通道,Alpha通道进行更细的调节),我当时制作时好像还做了些别的操作,但具体我记不清楚了,主要靠感觉..4 [( J6 K3 s. }, c3 |1 ]
( N) l/ M8 ?& E8 V: M" S9 q
![]()
$ m4 b, T. ]8 r. ~( C* x# o% K
$ k4 z/ |" d6 W" y2 _ Maya原始渲染图与经过Photoshop后期润色图的对比
L$ H- ? ?7 f$ f5 F' V" l
: n* i7 p0 ]* ^* D- D5 M; S: I ![]()
- g# u" `0 i1 `2 b# j$ t+ c2 _. g3 W8 B) l; m
左上角好像有点儿空,加上文字刚刚好!!
/ B- `& {1 B5 c2 m! ]
: a9 O1 f5 I4 U ![]()
2 a3 U' K r" b& D* S6 B W( O R' r4 a4 M4 k& F+ g
如果嫌上面的对比不够大的话,这是我以前作品润色前和润色后的对比,从中可以体会出后期的重要性(只是调了颜色,其它未做修改)
* d: \. p! J4 J1 w% I/ e
. f/ s7 h8 K2 U 3 x. ]1 j: y/ P) y. p9 l/ d
% i) I K9 f% t* i
在制作过程中,用PS随手调的几种效果~~
% u3 @7 n% `0 i# a) w5 `8 z0 Q3 z# t3 s' G$ i: d5 v
![]() |