Flash关于游戏制作研究之在场景中移动(二)_Flash教程

编辑Tag赚U币
教程Tag:暂无Tag,欢迎添加,赚取U币!

推荐:Flash使用bitmapData打造随机凹凸拼图效果
下午没事做,就弄了个随机切拼图效果,还没做判定,只是个切法的计算,稍后整理下就应该是个成品,嘿嘿~原理主要就是用bitmap进行切图,以前都是用遮照做太占资源.效

  自从那篇游戏场景移动之一后,现在我们制作另一种场景移动的方式。这次我们要做的形式就是当游戏角色超出一定范围后才滚动场景。

这种方式需要我们先给出一个角色可以移动的范围,只要游戏角色一超出这个范围地图就开始移动。知道相关的东西后我们就开始编写脚本把,其实我们不用再重新写一遍这个脚本,只要用我在第一篇提供的源码上作修改就能够轻易地得出这种方式的场景移动了,那我们现在来看源代码吧:
import flash.geom.Rectangle;
//引入矩形类包

var rect:Rectangle = new Rectangle(50, 50, Stage.width-100, Stage.height-100);
var speed:Number = 3;
this.onEnterFrame = function() {
if (Key.isDown(Key.UP)) {
if (curPoint._y<=rect.top) {
if (map._y>=0) {
//到达上边界
map._y = 0;
curPoint._y -= speed;
} else {
map._y = speed;
}
} else {
curPoint._y -= speed;
}
}
if (Key.isDown(Key.DOWN)) {
if (curPoint._y>=rect.bottom) {
if (map._y<=-(map._height-Stage.height)) {
map._y = -(map._height-Stage.height);
curPoint._y = speed;
} else {
map._y -= speed;
}
} else {
curPoint._y = speed;
}
}
if (Key.isDown(Key.LEFT)) {
if (curPoint._x<=rect.left) {
if (map._x>=0) {
map._x = 0;
curPoint._x -= speed;
} else {
map._x = speed;
}
} else {
curPoint._x -= speed;
}
}
if (Key.isDown(Key.RIGHT)) {
if (curPoint._x>=rect.right) {
if (map._x<=-(map._width-Stage.width)) {
map._x = -(map._width-Stage.width);
curPoint._x = speed;
} else {
map._x -= speed;
}
} else {
curPoint._x = speed;
}
}
};

分享:FlashActionscript学习:MovieClipLoader深入研究
使用moviecliploader下载过多的位图会带来计算机网络连接的拥塞,即使使用unloadClip方法取消下载,仍然不会有好转,引起这个现象的原因与这个类的实现细节有关

/所属分类:Flash教程/更新时间:2008-03-05
相关Flash教程