博客
关于我
unity5.0的StateMachineBehaviours
阅读量:77 次
发布时间:2019-02-25

本文共 1426 字,大约阅读时间需要 4 分钟。

作用:Unity中在人物播放某个动画时往往伴随着动画音效的播放,或则是人物打击的粒子特效播放

旧方法:Animation(Ctrl+6)动画中添加Event事件,然后填写注册的方法名,Unity会在挂载该动画的物体上查找该方法,在动画播放到定义事件的那一帧时,会执行该方法。使用StateMachineBehaviours明显会方便很多

例子:在人物攻击时播放攻击特效,攻击动画结束关闭攻击特效

首先类继承StateMachineBehaviour,然后重写OnStateEnter,OnStateExit方法

override public void OnStateEnter (Animator animator, AnimatorStateInfo stateInfo, int layerIndex){   }

Animator动画参数是特定的animator ,是这个状态机行为的引用。

· AnimatorStateInfo 是状态机的行为是对state 的当前信息。相当于writing animator.GetCurrentStateInfo(layerIndex);

· LayerIndex 是状态机行为状态的layer 层。例如,0为基底图层,1用于第一个 等等。

步骤:将特效物体放在人物下成为子物体

在这里插入图片描述

AttackSMB.cs

using System.Collections;using System.Collections.Generic;using UnityEngine;public class AttackSMB : StateMachineBehaviour{       public int index;    Transform effect;    public override void OnStateEnter(Animator animator, AnimatorStateInfo animatorStateInfo, int layerIndex)    {           //显示武器        //animator.transform.GetComponent
().ShowWeapon(); //获取特效 effect= animator.transform.Find("TrailEffect/Ellen_Staff_Swish0" + index); //显示特效 effect.gameObject.SetActive(false); effect.gameObject.SetActive(true); } public override void OnStateExit(Animator animator, AnimatorStateInfo animatorStateInfo, int layerIndex) { //animator.transform.GetComponent
().HideWeapon(); //隐藏特效 effect.gameObject.SetActive(false); }}

最后在对应动画上添加AttackSMB脚本,修改index值即可

在这里插入图片描述

转载地址:http://uex.baihongyu.com/

你可能感兴趣的文章
Mysql学习总结(53)——使用MySql开发的Java开发者规范
查看>>
Mysql学习总结(54)——MySQL 集群常用的几种高可用架构方案
查看>>
Mysql学习总结(55)——MySQL 语句大全再温习
查看>>
Mysql学习总结(56)——MySQL用户管理和权限设置
查看>>
Mysql学习总结(57)——MySQL查询当天、本周、本月、上周、本周、上月、距离当前现在6个月数据
查看>>
Mysql学习总结(58)——深入理解Mysql的四种隔离级别
查看>>
Mysql学习总结(59)——数据库分库分表策略总结
查看>>
Mysql学习总结(5)——MySql常用函数大全讲解
查看>>
Mysql学习总结(60)——并发量大、数据量大的互联网业务数据库设计规范总结
查看>>
Mysql学习总结(61)——MySQL优化之DBA级优化整理汇总
查看>>
Mysql学习总结(62)——MySQL连接com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link问题
查看>>
Mysql学习总结(63)——Mysql数据库架构方案选择与分析
查看>>
Mysql学习总结(64)——Mysql配置文件my.cnf各项参数解读
查看>>
Mysql学习总结(65)——项目实战中常用SQL实践总结
查看>>
Mysql学习总结(66)——设置MYSQL数据库编码为UTF-8
查看>>
Mysql学习总结(67)——MYSQL慢查询日志
查看>>
Mysql学习总结(68)——MYSQL统计每天、每周、每月、每年数据 SQL 总结
查看>>
Mysql学习总结(69)——Mysql EXPLAIN 命令使用总结
查看>>
Mysql学习总结(6)——MySql之ALTER命令用法详细解读
查看>>
Mysql学习总结(70)——MySQL 优化实施方案
查看>>