手机
当前位置:查字典教程网 >网页设计 >Flash教程 >Flash AS3对单个图片进行角色动作化处理
Flash AS3对单个图片进行角色动作化处理
摘要:大家肯定看过大型游戏一张各个人物动作图片继承在一张位图上的程序吧~现在看看这个!我今天在蓝色论坛里看到一个有关"BitmapData类"的问...

大家肯定看过大型游戏一张各个人物动作图片继承在一张位图上的程序吧~现在看看这个!

我今天在蓝色论坛里看到一个有关"BitmapData类"的问题,我觉得用BitmapData类是可以实现里说的C 处理图片功能,再加我好久没写AS3的程序,都快生锈了!就当练练手吧!我查了一下Flash帮助文件,整理一下思路花了中午时间写出下面document类文件;这个功能比较适合做Flash游戏开发了。我加了键盘事件,用来控制角色移动方向。如果在对类代码中使用的类对象不清楚的话,请看Flash帮助文件吧!

提问者提供一个角色动作图片,我也就在就直接用这图片了!

Flash AS3对单个图片进行角色动作化处理1

演示处理运行效果(如果看不到,请更新你的Flash Player播放器吧!你可以使用方向键,改变角色移动方向)

Flash效果

GameSprite类:

package{ importflash.display.*; importflash.net.*; importflash.utils.Timer; importflash.events.*; importflash.geom.*; publicclassGameSpriteextendsSprite{ privatevartimer:Timer; privatevarsWidth:uint; privatevarsHeight:uint; privatevarsStep:uint; privatevarsDirection:uint; privatevarloader:Loader; privatevarmaps:Array; privatevarpointer:uint; privatevarmap:Bitmap; functionGameSprite(){ //角色大小; sWidth=100; sHeight=100; //角色移动方向; sDirection=0; //角色步数; sStep=1; //角色动作数组; maps=newArray(); //初始化角色动作运行指针; pointer=0; //初始化time; timer=newTimer(100); timer.addEventListener(TimerEvent.TIMER,timerHandler); //图片加载对象; loader=newLoader(); loader.contentLoaderInfo.addEventListener(Event.COMPLETE,completeHandler); loader.contentLoaderInfo.addEventListener(IOErrorEvent.IO_ERROR,errorHandler); loader.load(newURLRequest("/download/sprite.png")); stage.addEventListener(KeyboardEvent.KEY_DOWN,keyDownHandler); } //错误处理事件; privatefunctionerrorHandler(event:IOErrorEvent):void{ trace("IOErrorEvent"); } //键盘事件,通过方向键更改角色移动方向; privatefunctionkeyDownHandler(event:KeyboardEvent):void{ switch(event.keyCode){ case40: sDirection=0; break; case38: sDirection=3; break; case37: sDirection=1; break; case39: sDirection=2; break; } } //定时器运行事件; privatefunctiontimerHandler(event:Event):void{ //删除旧的角色动作图像; if(map!=null){ removeChild(map); } //显示新的角色动作图像; map=newBitmap(maps[sDirection][pointer]); addChild(map); //角色动作循环处理; if(pointer<sStep-1){ pointer ; }else{ pointer=0; } } //加载图片完成处理事件; privatefunctioncompleteHandler(event:Event):void{ //根据图片的大小初始化BitmapData; /* *注意如果你要保留原来的图片的透明度的话,必将transparent设置为true,同时设置填充色值的前两位为00; */ varsBmd:BitmapData=newBitmapData(loader.width,loader.height,true,0x00FFFFFF); sBmd.draw(loader); //计算移动步数; sStep=Math.floor(loader.width/sWidth); for(varj:uint=0;j<Math.floor(loader.height/sHeight);j ){ vararr:Array=newArray(); for(vari:uint=0;i<sStep;i ){ varbmd:BitmapData=newBitmapData(sWidth,sHeight,true,0x00FFFFFF); //获取单个角色的BitmapData对象; bmd.copyPixels(sBmd,newRectangle(sWidth*i,sHeight*j,sWidth,sHeight),newPoint(0,0)); arr.push(bmd); } //放入角色数组里; maps.push(arr); } //释放sBmd资源; sBmd.dispose(); //开始运行角色动作; timer.start(); } } }

载入外部png图片,然后使用BitmapData类非常理想,最大的问题是:从表面上看图片是透明的,但是其实图片是一个矩形,所以这个矩形区域会遮住它下面的内容,所以当你用鼠标点击这个矩形区域时,你的鼠标是在矩形区域上而不是它下面的内容(其实这就好比你把一个 movieClip的alhpa值设为0,看上去什么都没有,但是它却实实在在地存在)。所以如果你的人物是通过鼠标来操作它的行走,这个时候可能会有一些问题了。

【Flash AS3对单个图片进行角色动作化处理】相关文章:

Flash嵌入字体的进阶方法

Flash AS3教程:ByteLoader类

Flash AS3.0代码编写好看的荷塘涟漪动画

Flash制作摇动的卡通头像

flash AS打造图片滚动效果

Flash入门实例教程:无停顿不间断图片滚动的动画效果制作

FLASH绘制三角形方法

Flash如何制作旋转动画效果

flash中嵌入字体实现原理及代码

Flash AS3简单制作美女图片缓动特效gif动画

精品推荐
分类导航