关于Unity 动画绘制原理

本文详细阐述了游戏动画绘制的原理,通过加载资源、设置帧动画和利用GUI组件实现小鸟角色的移动与动画播放,提供了游戏开发中关键的动画处理技术。

动画绘制的原理:现在屏幕中确定动画的显示区域,然后将动画中的每一帧图片按固定的时间在这个区域中按顺序切换,从而实现动画的效果。建立文件夹Textures,里面放上图片,此处我截了三张图,风怒的小鸟图片放在该文件夹下,运行结果如下图,点击相关按钮小鸟做相关移动,脚本如下:

 private var anim:Object[];//动画数组

private var nowFram:int;//帧序列

private var mFrameCount:int;//动画帧总数

private var fps:float=5;//限制一秒多少帧

private var time:float=0;//限制帧的时间

var x:int;

var y:int;

var tex:Object[];

 

var bg:Texture2D;//背景图片

function Start () {

    anim=Resources.LoadAll("Textures");//得到帧动画中所有图片资源

    mFrameCount=anim.Length;//得到动画有多少帧

    bg=Resources.Load("next_bg");

}

 

function Update () {

 

}

function OnGUI(){

   //绘制背景图片

   GUI.DrawTexture(Rect(0,0,Screen.width,Screen.height),bg,ScaleMode.StretchToFill,true,0);

   

   //调用DrawAnimation,参数一:动画数组,参数二:动画显示区域

   DrawAnimation(anim,Rect(x,y,32,48));//全局变量x,y确定主角的方向

   if(GUILayout.RepeatButton("up"))

   {

      y-=2;

      tex=anim;

   }

   if(GUILayout.RepeatButton("down"))

   {

      y+=2;

      tex=anim;

   }

   if(GUILayout.RepeatButton("left"))

   {

      x-=2;

      tex=anim;

   }

   if(GUILayout.RepeatButton("right"))

   {

      x+=2;

      tex=anim;

   }

}

 

 

function DrawAnimation(tex:Object[],rect:Rect)

{

   GUILayout.Label("当前动画播放:地"+nowFram+"");

   GUI.DrawTexture(rect,anim[nowFram],ScaleMode.StretchToFill ,true,0);//绘制动画数组

   //计算限制帧时间

   time+=Time.deltaTime;

   if(time>=1.0/fps)

   {

      nowFram++;//帧切换

      time=0;//切换后限制帧的时间归零,从新计算

      if(nowFram>=mFrameCount)

      {

          nowFram=0;//若当前帧到达最后一帧,那么在从第0帧开始播放

      }

   }

}

 

转载于:https://www.cnblogs.com/niguang/archive/2012/11/21/2781469.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值