接下来几章按帮助文档安排内容,分7步教你如何搭建一个场景,正如文档里所说,这是一个非常重要和复杂的工作。
2 {/ R& |: t1 e* L
- `0 s% `( f9 i9 a; H
. y5 ~+ U, e9 r/ y* g/ T首先打开ProjectMan并打开scene_tut.wpr这个工程(在WME DevKit\projects\scene_tut文件夹里),这是一个教学用的demo。1 w& N6 n$ C n
双击文件树中的scenes,可以看到许多制作好的场景,它们是按各个教学步骤制作的。你可以按F5体验一下。/ M4 @) [3 B8 }& w+ c
- u' a0 }9 q4 }) d2 A
; s6 i# u. K9 A3 \3 b我们将创建一个新的场景,首先在文件树中右键单击scenes,并选择添加场景命令。( \' d5 |) x0 x9 L4 @( i
- t5 J+ M7 J# z. ^
$ n3 c0 b) u7 G, w+ y& ?5 I9 L+ q3 A
/ a% G8 y+ p( I% c- @: L之后将出现一个模版选择窗口,选择Empty scene 800x600这个模版(图片是帮助文档里的,实际操作时总共有三个模版),并将场景名称改为MyScene(文档里说了,为了教学需要,你必须改成这个名字)。
+ `9 }$ p6 C" B! k$ @* G' ^: w- x' M; O n4 X- d
0 B9 ^) O# ]; W' E" I# K0 U& ]7 b3 u
# T. @. R2 `& ]1 M% {; H
P- J, W1 V4 f& F) x. j" |- _点击OK一个新场景就创建好了,你可以看到文件树里多出了一个文件夹。
. }# k r, m% B1 o( t* a接下来我们要为新场景载入背景图片,wme要求每个场景用到的图像必须放在这个场景本身的文件夹里。demo所在文件夹的data\tutorial\gfx里已经提供了所需的图像。
& }1 T- q3 X. U如图所示,右键单击Myscene文件夹并选择导入(import)--〉导入文件(import file(s)...),在data\tutorial\gfx中找到background.bmp并载入。PM会把图像拷贝到MyScene文件夹里,事实上,你打开文件夹使用复制粘贴也可以做同样的事,使用PM只是更直观而已。
& R# i2 }4 A' S/ b/ L6 T
$ d7 `) s9 k* J7 F) P$ P+ h
! D. O+ j8 M7 m5 H$ o# i/ y. A
& I; z, u x5 F7 @1 k2 l7 m6 F8 Q2 K, \2 J" D6 r( P
这样该场景就会自动应用这个背景,你可以按F5测试一下自己的Myscene场景。当然这时候场景跟一张图片没什么差别,我们接下来要做的就是慢慢完善。
0 C7 e; _$ W9 A& _+ j6 b: x9 ~$ d- c" [5 v9 f7 h
* W. t, j: h5 u Z1 c6 Z6 K; k3 V% S首先我们要实现场景的卷动。
7 M: m: v6 w; B在文件树中找到MyScene.scene这个文件双击它或者右键单击在选择编辑(Edit)。PM会帮你调用SceneEdit这个工具让你编辑场景。
- H; ~0 G8 M% S0 o4 Q6 l) ? y/ k4 B m
+ _" p; B2 ?0 [+ T( _' q
) U U. A! \$ `' `% l
/ e" c0 w* [9 |) t& R简单浏览一下,左边是工具栏,从上至下分别是层(初始是三个层),元素(node直译是节点,实际上就是每个层包含的东西),最底下是每个元素的信息,你可以随便点点看。
' y& o' w5 J4 ]) K# F- R9 e接下来是怎么让场景实现卷动。背景图片的尺寸是1000*716,而场景尺寸默认是800*600,我们只需要把场景尺寸改得和背景图片大小一样就可以了。, b4 D7 A& j5 g( J' e, U, \' m; W. w3 |! b
如图所示,在layer窗口选择main,并点击Layer properties,在弹出的窗口中将尺寸修改为1000*716。7 f \: j4 U6 U, S6 Z3 p. S
0 A) Q7 M4 B! r; N F! T" Z2 W- ?( j
a2 q, Q' h1 v' H; A6 v$ }- Q
8 ^, z- f; o( C7 a; ]/ b* `8 `" S( @& D( H! r( M6 C* E
- D j* y5 }" U) s1 a0 {+ ?9 V! }: Y0 ` @0 Z: t
这样由于场景尺寸大于窗口尺寸,引擎就会使场景可以卷动,在SceneEdit保存你的操作并回到PM按F5测试一下。% n$ K' u9 c& j$ a
1 A/ M' k% f' Z' ?1 r* o' h( u; H9 G! r0 ?& K8 e
接下来要做的是规定哪里能走哪里不能走。
Z Y: c1 O8 G: a7 J0 ?点击node栏里的floor,你可以看到中间的方框被红色高亮了,这个方框中间就是角色可以移动的范围。
+ i- s7 K$ B3 f0 P, O/ N拖动方框周围的四个小方块可以改变它的形状,我们要做的就是使这个红色框和地板重合,不让我们的角色能跑到墙上。% a" i7 l [+ G9 u0 Y' H
当然只是一个四边形的话估计不够,我们可以通过添加节点(也就是那些小方块)改变红色框的边数。
* Q2 v/ g' p5 z1 s9 r+ H
! ~" U5 v: ?3 ]* x: b" x; ?7 n! \% t. ^# n2 M$ J
& Z3 e$ A; t2 h+ r1 ~5 e
如图所示,选择floor后点击Add point,把鼠标移到右边的预览窗口,可以看到鼠标图案变成了两个加号,之后在那个红色框上的任一位置点击一下,框上多出了一个小方块,可以拖动以改变形状。7 J/ P q4 x& _6 @0 G0 o, e
! u; e- f1 E$ F& Z& d; T& y$ J3 P2 Z! } b
2 [2 y+ G% q0 w- f8 B% x点Remove point则可以删除一个节点。使用小键盘的加减号也可以添加、删除节点。
. T2 B3 @$ z" j. p& w5 U; B" l3 R: c9 e5 }" G. r( m
3 x, {3 J6 W8 O0 K% }之后你要做的就是把红色框的形状和地板整得一样,如果节点不够的话就多来几个。如图。; s l2 Y8 T. K$ X( t" r! v/ Y
8 o" g! ~; b( i9 d6 v& Z
$ {4 h( |' d; i; z% \7 H) [ ?+ Y1 L& @9 \3 r/ s+ a
$ ^9 k2 z* u0 u R9 S这样就规定好了角色能行走的范围,你可以测试一下。测试过程中发现的横穿桌子等一系列的问题在以后的教学里一步步解决。
( V' p/ S* F5 E8 h
5 p9 L8 H% u* V
/ Q5 l1 R8 N8 \) J+ n( i最后是一个小技巧,如果在调整红色框形状时不小心进行了错误的操作,比如不小心拖动了一个节点,如果你的鼠标左键还没放开的话,你可以点击一下鼠标右键,就会恢复原状。或者你可以在工具栏选择Edit-->Undo来撤销,ctrl+z也是有效的。
E9 ~9 \# s7 x6 b: Q
: J3 X% U4 c) ]6 {1 J$ u8 t9 ^
0 w# ~$ m7 J9 }- c4 h& N! up.s:为什么不可以使用草稿箱- - |