步骤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; 

//同上 

};

这个是效果:点击这里下载源文件