今天我们一同研讨一下Flash游戏地图的显示技术。
步骤1:新建一个影片,场景多大没关系.
步骤2:新建一个空的影片剪辑,实体名称为allmc,然后拖到场景的左上角,x坐标为0,y坐标也为0.
步骤3:再新建一个影片剪辑,实体名称为smap,拖到场景任意位置.进到smap,在里面画个小地图背景(也就是一个色块吧),留意:如果注册点在左上角的话,那么这个色块的位置就要输入0,0,如果注册点在中心,那么色块的坐标就正好要是色块宽和高的一半.比如色块的宽是30,高是30,那么它的坐标就设置为15,15.弄好后把这个色块按F8转换为影片剪辑,命名实体名称为:smapmc.
步骤4,建立控制的mc和小地图显示的mc.建立一个mc,用来控制的 ,命名为box,再建立个mc,用在小地图中显示的,命名为cir.不要把它们拉进场景.只需求给它们做连接名.连接名称分别为box和cir.
步骤5:as部分,复制代码在主场景第一帧.
//////地图比例尺转换as,绝命时辰2007年4月3日///////
var sd:Number = 5;
//定义速度
var boxmc = allmc.attachMovie("box", "nbox", 1);
//把控制的元件动态载入影片剪辑allmc,并赋予变量boxmc
boxmc._x = Math.random()*Stage.width;
//boxmc里包含了nbox,如今定义它的X坐标,Stage.width是主场景的宽,让boxmc._x随机在主场景的任意X轴位置
boxmc._y = Math.random()*Stage.height;
//同上,不过这里是随机Y轴
var xpos:Number = boxmc._x;
//初始,把boxmc的X坐标显示出来,传递到动态文本筐xpos上
var ypos:Number = boxmc._y;
//同上,这里传递的是Y坐标
smap.attachMovie("cir", "cir", 1);
//动态载入cir这个元件,把它载入到smap这个影片剪辑中,它是显示在小地图里的mc
smap.cir._x = boxmc._x/10;
//定义cir在smap里面的X坐标,由于地图大小是以10倍的比例缩放的,所以行走的速度和位置都要/10
smap.cir._y = boxmc._y/10;
//同上,这里定义的是Y坐标
var sw:Number = Stage.width;
//把总场景的宽赋予变量sw
var sh:Number = Stage.height;
//把总场景的高赋予变量sw
smap.smapmc._width = sw/10;
//为了让smap.smapmc.宽按比例缩小放大(考虑到不管如何改变主场景大小都能自行按比例缩小小地图),所以也应该/10,也是为什么
//上两行代码要获取主场景的宽和高的缘由
smap.smapmc._height = sh/10;
//同上,这里是判断高
smap.smapmc._x = smap.smapmc._width/2;
//为了要让smap.smapmc不管放大还是缩小都永远保持在smap._x=0位置上,所以/本人的一半
smap.smapmc._y = smap.smapmc._height/2;
//同上,这里是定义Y坐标
onEnterFrame = function () {
xpos = boxmc._x;
//不断的把boxmc的X坐标传递给动态文本xpos
ypos = boxmc._y;
//同上,这里是传递Y坐标
if (Key.isDown(68)) {
boxmc._x += sd;
smap.cir._x += sd/10;
//boxmc每挪动10像素那么小地图里的mc就挪动1像素,所以就拿boxmc的速度/10,还是除于10,倍数
}
if (Key.isDown(65)) {
boxmc._x -= sd;
smap.cir._x -= sd/10;
//同上
}
if (Key.isDown(87)) {
boxmc._y -= sd;
smap.cir._y -= sd/10;
//同上
}
if (Key.isDown(83)) {
boxmc._y += sd;
smap.cir._y += sd/10;
//同上
}
};
这个是效果.:
点击这里下载源文件