UnityVR--组件5--Animation动画

这篇具有很好参考价值的文章主要介绍了UnityVR--组件5--Animation动画。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

新建动画Animation

Animation组件解释

应用举例1:制作动画片段

应用举例2:添加动画事件

Animator动画控制器

应用举例3:在Animator中设置动画片段间的跳转


本篇使用的API:Animation、Animator以及Animator类中的SetFloat、SetInteger、SetBool等,以及短小动画片段的制作

新建动画Animation

  必须选择一个对象来建立动画,选择Window->Animation->Animation,在弹出窗口中点击“创建”

UnityVR--组件5--Animation动画

UnityVR--组件5--Animation动画  UnityVR--组件5--Animation动画

创建完成后,Animation中就出现了动画帧,同时在放置动画的文件夹中会自动添加一个动画控制器Animator,并在添加动画的物体上挂载Animator组件:

UnityVR--组件5--Animation动画

 Animation组件解释

  可以制作位置移动、旋转或缩放等类型的动画,点击对应的+号,就可以在时间轴上创建相关的帧:

UnityVR--组件5--Animation动画 UnityVR--组件5--Animation动画

 应用举例1:制作动画片段

 1. 按上面的步骤创建Animation后,点击“AddProperty”选择Transform中的Position,先制作一个移动的动画。点击“录制”按钮开始录制动画:

UnityVR--组件5--Animation动画

   2. 这里是动画初始的状态,然后将帧的指针拖到下一个状态的位置,比如0:10的位置。同时也将动画人物放置到下一个位置,Animation会自动新建关键帧。:

UnityVR--组件5--Animation动画  UnityVR--组件5--Animation动画

   3. 以此类推,不断将指针移动到关键帧位置,并相应地设置动画人物到各个位置,完成后关闭录制按钮:

 UnityVR--组件5--Animation动画

  4. 点击“播放”按钮,可以预览动画的效果:

 UnityVR--组件5--Animation动画

应用举例2:添加动画事件

  在动画播放的过程中,有时候需要触发一些事件的回调,比如人物跳着跳着撒出一些金币,或者走着走着说了一句话,这就需要在动画中添加一个事件。

  1. 将指针拖到需要事件回调的位置,点击按钮“AddEvent”:

UnityVR--组件5--Animation动画

   2. 编辑脚本:这里写一个测试脚本Test.cs,并挂载在动画物体上:

public class Test : MonoBehaviour
{
    public void TestAnime()
    {
        Debug.Log("跳啊跳啊");
    }
}

  3. 点击动画上的事件,在下拉菜单中就能看到这个测试的函数:

UnityVR--组件5--Animation动画

   4. 运行一下场景,每当动画执行到这个事件时,就会调用TestAnime()这个函数:

UnityVR--组件5--Animation动画

 Animator动画控制器

  Animator是一个动画的控制器,在创建动画Animation时,自动会创建。它管理动画人物在什么状态下应该播放什么动画片段,这样就可以简单地使用设置来控制不同动画播放,而不用写代码。

  Animator组件就默认挂在动画人物上:

UnityVR--组件5--Animation动画

  同时还创建了一个Animator控制器,例如上面创建的动画“HeroAnimation”,它的Animator控制器“Hero”(默认在同一文件夹中),双击它就能打开控制界面:

UnityVR--组件5--Animation动画

   其中AnyState、Entry和Exit三个节点是默认的,目前只有一个HeroAnimation动画片段。单击HeroAnimation动画,可以在Inspector窗口中看到它的属性:

UnityVR--组件5--Animation动画

  如果需要添加第二段动画,可以在状态机的空白处点右键新建,并且添加跳转箭头到新的动画上:

UnityVR--组件5--Animation动画  UnityVR--组件5--Animation动画

   单击跳转箭头,可以看到右边的Inspector中的跳转条件设置:

UnityVR--组件5--Animation动画UnityVR--组件5--Animation动画

  这里的跳转条件由Animator中设置的参数控制:

UnityVR--组件5--Animation动画

应用举例3:在Animator中设置动画片段间的跳转

  1. 先制作两个简单的动画片段Animation:站立动画HeroIdle(Scale上的变化),跳跃动画HeroJump

UnityVR--组件5--Animation动画  UnityVR--组件5--Animation动画

  2. 将两个动画片段拖入Animator:

UnityVR--组件5--Animation动画

   3. 建立动画过渡,在HeroIdle上点右键->MakeTransition,建立从HeroIdle到HeroJump的转场:

UnityVR--组件5--Animation动画   UnityVR--组件5--Animation动画

   4. 反向也建立一条:

UnityVR--组件5--Animation动画

   5. 在Animator的参数页,建立一个Float类型的参数,取名为changeFloat:

UnityVR--组件5--Animation动画 UnityVR--组件5--Animation动画

   6. 点击向下的专场箭头,在Inspector中为它建立转场的条件:

UnityVR--组件5--Animation动画

  在Conditions下方点“+”号,添加一个转场条件,在其中选择刚刚建立的这个浮点数changeFloat,设置条件,当它的值大于1时,动画跳转到HeroJump,而它的初始值是0:

UnityVR--组件5--Animation动画

   7. 测试代码,挂在Hero身上。这里使用API"SetFloat"就可以访问到转场的参数:

public class AnimeSwitch : MonoBehaviour
{
    private Animator animator;
    void Start()
    {
        animator= GetComponent<Animator>();//获取主角身上的Animator组件        
    }
    void Update()
    {
        if(Input.GetKey(KeyCode.Space))
        {//当按下Space按键时,把changeFloat值改为大于1
            animator.SetFloat("changeFloat", 1.1f);
        }
        else animator.SetFloat("changeFloat", 0f );//不按的时候改回0
    }
}

 8. 效果:平时播放站立动画,按下Space按键就跳一下。

UnityVR--组件5--Animation动画

   状态机中的表现,按下space的时候跳转到Jump动画,然后跳转回来:

 UnityVR--组件5--Animation动画文章来源地址https://www.toymoban.com/news/detail-474985.html

到了这里,关于UnityVR--组件5--Animation动画的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Unity Animation -- 导入动画

            尽管Unity中的动画工具已经比较强大了,但对于非常复杂的或很长的动画,通常是由外部DCC创建。特别是对于角色动画来说,需要在动画过程中进行复杂的控制。因此我们通常需要将外部制作的动画导入到Unity中。         对于复杂的动画,制作过程会非常耗时。动

    2024年02月12日
    浏览(51)
  • css的animation动画

    创建动画序列,需要使用 animation 属性或其子属性,该属性允许配置动画时间、时长以及其他动画细节,但该属性不能配置动画的实际表现,动画的实际表现是由 @keyframes 规则实现 属性 描述 animation-name 指定由 @keyframes 描述的关键帧名称 animation-duration 设置动画一个周期的时长

    2024年02月06日
    浏览(82)
  • animation动画

    通过 CSS3,我们能够创建动画 如果要在 CSS3 中创建动画,需要使用 @keyframes 规则 animation属性是复合属性 检索或设置对象所应用的动画特效 @keyframes 创建动画 语法: @keyframes 动画名{ 具体关键样式变化 } @-webkit-keyframes 动画名{ 具体关键样式变化 } // @keyframes 动画名{ fro

    2024年02月01日
    浏览(31)
  • Unity老动画系统Animation

    1、创建老动画系统 给要制作动画的GameObeject添加Animation组件 2、Animation参数 Animation:默认播放的动画 Animations:该动画组件可以控制的所有动画 Play AutoMatically:是否一开始就自动播放默认动画 Animate Physics:动画是否与物理交互 Culling Type:决定什么时候不播放动画     Alwa

    2024年02月06日
    浏览(40)
  • Unity Animation动画时间设置

    遇到一个需求,需要给角色添加一个翻滚动作,在翻滚同时无敌且可穿越敌人。 目前已有翻滚的动画,是使用Sprite制作的动画剪辑。如何匹配动画时间和脚色无敌时间?做到在翻滚结束时同时结束无敌与无碰撞设置。 在Animation设置窗口中,有Samples字段,可设置动画的采样帧

    2024年02月01日
    浏览(51)
  • css动画(animation)常用属性

                               1.animation-name:动画名称                                       2.@keyframes:动画定义,后面跟动画名称                                      3.animation-duration:动画持续时长,单位(s)                         

    2023年04月27日
    浏览(48)
  • CSS animation动画使用详解

    目录 一、animation动画的使用步骤 第一步:定义动画 第二步:使用动画 二、animation的复合属性 三、animation的拆分属性 四、动画属性 animation:动画名称 动画时长 速度曲线 延迟时间 重复次数 动画方向 执行完毕时的状态 逐帧动画(配合精灵图使用) animation-timing-function:step(N) N为将动

    2024年02月16日
    浏览(39)
  • Unity Animation -- 改进动画效果

          在上一篇笔记中(Unity Animation -- Overview_亦枫Leonlew的博客-CSDN博客),我们制作了简单的小球弹跳的动画,但这个动画看起来很不自然,小球的弹跳看起来就像是不受重力影响的物体,没有加速度的影响。要让小球的弹跳动画看起来更自然(不使用物理引擎,只使用动画

    2023年04月12日
    浏览(78)
  • CSS中animation动画-详解

    1、animation有什么组成? Animations由两部分组成:css动画的配置,以及一系列的keyframes(用来描述动画的开始、过程、结束状态)。不需要了解任何Js技术即可完成动画的制作 2、关键帧应该怎么表示? 0%表示动画的初始时间,也可以通过from表示。100%表示动画的结束时间

    2024年02月01日
    浏览(32)
  • 小程序动画 animation 的常规使用

    公司小程序项目比较多,最近正好有时间看一下小程序的动画,同时记录一下我的学习过程;看到这个文章的,我建议你直接去小程序后台:https://developers.weixin.qq.com/miniprogram/dev/api/ui/animation/wx.createAnimation.html 1、使用 duration:持续时间 timingFunction:动画效果 delay:延迟时间

    2024年02月13日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包