大家好,我是RUSH ROVER的开发者Radio,我挑选了游戏开发过程中一些有价值的经验并记录下来与大家分享,希望对各位开发者也有所启发。这篇日志将向大家介绍Rush Rover中,闪烁特效的制作思路。因为我使用的开发工具是Game maker stuido(以下简称GMS)。这个工具好像在国内不是太主流,外加自己表述能力不是太好,所以具体代码我就不详细解释了。这里着重给大家讲解下效果制作的思路,相信大家也能够在自己的的引擎中找到制作方法。
首先我们先来看下效果:
最初这个效果,我想用帧动画来实现,不过这样有个缺点就是闪烁残影的随机性不强,而且sprite数量一多,工作量还是不少的。所以还是交给代码来处理吧。
接下来分析下思路:
为了表现闪烁残影的效果,视觉上一般都会带有些动态模糊,外加些亮光效果。而我这个游戏美术风格属于像素风格。所以动态模糊方面的表现也就相对的“栅格”化一些。
这里有使用了1张图片作为闪烁的素材,其他图片分别是正常状态和爆炸时黑白闪光的图片。
这里以着陆特效为例,来分析下代码绘制的大体思路:
1.分析特效,为表现快速着陆效果,一般都会在纵向上使用动态模糊特效,以体现速度感。使用最后一张带闪光的图片,横向(X轴)随机分割成若干部分。
2.将这些分割后的图片在纵向(Y轴)进行随机的缩放拉升。
3.调整图片的位置,使图片看起来向朝一个方向做运动的感觉,做一些随机抖动的效果。
4.加入一些粒子效果。
在游戏中每一帧(GMS里游戏运行的每一帧叫做STEP)让代码绘制上述的特效。这个效果就实现了。
扩展下思路,按照同样的方法,使用一张闪光图片配合其他的sprite,你就可以制作出喷射,能量护盾等更多的特效来。
以下是GMS中的代码,如果你使用GMS开发游戏,也许能直接COPY使用,但是如果其他引擎,那就按照上面的介绍自己整个。
在GMS中有一个绘制函数draw_sprite_part_ext(sprite, subimg, left, top, width, height, x, y, xscale, yscale, colour, alpha);
我利用这个函数扩展写了个SCRPIT,用于绘制着陆效果。
///draw_body_flash(spr,ind,x,y,dir,ss); var spr, ind, xx, yy, ss, ff, fd, dd, sw, sh, tw, th, nw; spr = argument0; //绘制的精灵图片 ind = argument1; //需要绘制的帧 xx = argument2; //绘制的X坐标 yy = argument3; //绘制的Y坐标 dd = argument4; //绘制的方向 ss = argument5; //随机抖动种子 sw = sprite_get_width(spr); sh = sprite_get_height(spr); nw = 0; tw = 0; th = 0; ff = image_xscale; fd = 1; if dd == 270{ fd = 1; } else if dd == 90{ fd = -1; }do { tw = ceil(sw / 8) + irandom(8); if tw + nw >= sw{ tw = sw - nw }; th = random_range(1, ss); draw_sprite_part_ext(spr, ind, 0 + nw, 0, tw, sh, xx - sw / 2 * ff + nw * ff, yy + sh / 2 * fd - irandom_range(0, 32) * fd - th * sh * fd, ff, th, c_white, choose(0.9, 1)); nw += tw; } until(nw >= sw)
效果很不错啊。我也用过 GMS,回头就试试你这个写法。:)
最近由 craft 修改于:2016-05-06 12:10:01edit:加入一些例子效果 那里有错别字吧2333
@craft:谢谢啊,拼音输入法,没注意输错了。谢谢提醒。
@craft:有了edit功能之后到处炫耀和示范 :p
@ayame9joe:我还在后台给偷偷加了代码高亮
最近由 eastecho 修改于:2016-05-06 20:00:05@radio:刚才重读又发现一个小 typo,script 拼错了。/捂脸
拜谢,虽然不用 GMS,但是一样有启发
都没看过瘾啊,太短了!方法和实现出的效果确实很牛逼!
效果真棒啊!
细节方面的研究和分享很有价值,而且效果拔群。
这个效果大赞啊,美工方面是用什么软件制作的?稍稍有点美术功底的,能不能做出这么炫的效果啊?PS:暴走的开发团队有多少人呐?
@llq:用ps画像素图,特效在游戏引擎里实现。美术多看多积累,练习。这游戏目前就我一个人开发。
图片链接有问题了,看不见 T^T
@llq:可以看的
@Humble Ray:文章里面的图片是引用我空间的,空间有点不稳定,稍后我传份到INDIENOVA
真正的大佬,从来都是这么的有姿势水平!