Animator & Timeline
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.Playables; public class Player : MonoBehaviour { private Animator anim;
//private int speedID = Animator.StringToHash("Speed"); //走
//private int isSpeedUPID = Animator.StringToHash("isSpeedUP"); //跑
//private int turnAroundID = Animator.StringToHash("TurnAround"); //转向 private int speedRotateID = Animator.StringToHash("SpeedRotate");
private int speedZID = Animator.StringToHash("SpeedZ"); private int isHoldLogID = Animator.StringToHash("isHoldLog");
private int slideID = Animator.StringToHash("Slide");
private int vaultID = Animator.StringToHash("Vault");
private Vector3 matchTarget = Vector3.zero; private CharacterController characterController;
private int colliderID = Animator.StringToHash("Collider"); public GameObject unityLog = null; //角色身上的木头
public Transform rightHand; //木头左右边的节点(空的gameobject)
public Transform leftHand;
public PlayableDirector playable; // Use this for initialization
void Start () {
anim = GetComponent<Animator>();
characterController = GetComponent<CharacterController>();
//unityLog = transform.Find("Reference/Hips/Unity_Log (1)").gameObject; //找到Log
} // Update is called once per frame
void Update () {
//2D混合树控制移动和旋转
anim.SetFloat(speedZID, Input.GetAxis("Vertical") * 4.1f);
anim.SetFloat(speedRotateID, Input.GetAxis("Horizontal") * 126f); ProcessVault();
ProcessSlide();
//if(anim.GetFloat(colliderID)>0.5f)
//{
// characterController.enabled = false;
//}
//else
//{
// characterController.enabled = true;
//}
//上面判断语句的简写
//滑动或翻墙时禁用角色控制器
characterController.enabled = anim.GetFloat(colliderID) < 0.05f; //走
//anim.SetFloat(speedID, Input.GetAxis("Vertical")*4.1f); ////转向
//anim.SetFloat(turnAroundID, Input.GetAxis("Horizontal"));
////跑
//if(Input.GetKeyDown(KeyCode.LeftShift))
//{
// anim.SetBool(isSpeedUPID, true);
//}
//if (Input.GetKeyUp(KeyCode.LeftShift))
//{
// anim.SetBool(isSpeedUPID, false);
//} } //翻墙
private void ProcessVault()
{
//翻墙
bool isVault = false;
//当Animator状态机在混合树“Motion”时判断,节省性能
if (anim.GetFloat(speedZID) > && anim.GetCurrentAnimatorStateInfo().IsName("Motion"))
{
RaycastHit hit;
if (Physics.Raycast(transform.position + Vector3.up * 0.3f, transform.forward, out hit, 4f))
{
if (hit.collider.tag == "Obstacle")
{
if (hit.distance > )
{
Vector3 point = hit.point;
//设定匹配位置
point.y = hit.collider.transform.position.y + hit.collider.bounds.size.y + 0.05f;
matchTarget = point;
isVault = true;
} }
}
}
anim.SetBool(vaultID, isVault); //匹配跳跃过程中左手与墙面的位置
if (anim.GetCurrentAnimatorStateInfo().IsName("Vault"))
{
anim.MatchTarget(matchTarget, Quaternion.identity, AvatarTarget.LeftHand, new MatchTargetWeightMask(Vector3.one, ), 0.32f, 0.4f);
} } //滑
private void ProcessSlide()
{
bool isSlide = false;
if (anim.GetFloat(speedZID) > && anim.GetCurrentAnimatorStateInfo().IsName("Motion"))
{
RaycastHit hit;
if (Physics.Raycast(transform.position + Vector3.up * 1.5f, transform.forward, out hit, 3f))
{
if (hit.collider.tag == "Obstacle")
{
if (hit.distance > )
{
Vector3 point = hit.point;
point.y = ;
matchTarget = point + transform.forward * ;
isSlide = true;
}
}
}
}
anim.SetBool(slideID,isSlide);
if (anim.GetCurrentAnimatorStateInfo().IsName("Slide"))
{
anim.MatchTarget(matchTarget, Quaternion.identity, AvatarTarget.Root, new MatchTargetWeightMask(new Vector3(,,), ), 0.17f, 0.67f);
}
} //检测碰撞
private void OnTriggerEnter(Collider other)
{
//木头
if(other.tag=="Log")
{
Destroy(other.gameObject);
CarryWood();
}
//镜头
if(other.tag=="Playable")
{
playable.Play();
}
} //扛木头
void CarryWood()
{
unityLog.SetActive(true);
anim.SetBool(isHoldLogID, true);
} //设置左右手IK到相应节点
//每帧都调用
private void OnAnimatorIK(int layerIndex)
{
//当layer层级为HoldLog
if(layerIndex==)
{
int weight = anim.GetBool(isHoldLogID) ? : ;
//左手
anim.SetIKPosition(AvatarIKGoal.LeftHand, leftHand.position);
anim.SetIKRotation(AvatarIKGoal.LeftHand, leftHand.rotation);
anim.SetIKPositionWeight(AvatarIKGoal.LeftHand, weight); //IK权重
anim.SetIKRotationWeight(AvatarIKGoal.LeftHand, weight); //右手
anim.SetIKPosition(AvatarIKGoal.RightHand, rightHand.position);
anim.SetIKRotation(AvatarIKGoal.RightHand, rightHand.rotation);
anim.SetIKPositionWeight(AvatarIKGoal.RightHand, weight);
anim.SetIKRotationWeight(AvatarIKGoal.RightHand, weight);
}
}
}
Player
Rig:
动画类型分为三类
1.Legacy:老版本的动画系统,一般都是单独做好的
2.Generic:骨骼动画,一般用在非人型生物上
3.Humanoid:骨骼动画,一般可通用在人形模型上面,只要骨骼节点设置相同
如果有些人物模型带有骨骼但是无法通用可选择:Create Form This Model -> Apply一下
->点击configure进行编辑确认后保存退出看下能不能用

Animation:
可进行动画的剪切与播放设置
1.Loop Pose让动画循环播放时衔接更顺滑(猜测是通过动画曲线开始与结束时的的陡峭程度进行插值运算)
2.Root Transform 下面的Bake into Pose勾选后动画播放后的位置就会被固定(有些动画播放时会有位移和转向)
3.Curves:设置曲线值,并且可以在Animator编辑器中添加相同名称的Parameters来控制触发条件

Animator状态机:
1.可以把动画拖进去设置然后通过相应的状态连接起来(点击连接箭头后如右边Inspector显示)
(1)Has Exit Time是否等当前动画播放完才跳转到下一个
(2)Conditions里可以设置Parameter里添加的各种条件参数

Blend Tree混合树:
在Animator里的BaseLayer层右键单击选择Creat State -> From New Blend Tree
如右边面板所示 (1)可选择1D/2D等混合树类型
(2)可以添加各个动画然后在图中拖动摆放各个动画并观察相互间的影响范围,也可以通过Compute Positions来按照特定条件计算摆放

AvatorMask:
通过Project中的Create -> AvatorMask创建
如图可以设置各个部位与Ik的禁用
通过新建一个Layer层设置Weight权重,Mask,Blending混合类型等可以在主动画播放时控制另一个动画也播放
如图中设置就能使第一个Layers里的动画播放时,第二个Layers动画中手部的动画状态覆盖掉第一个动画
(也就是说原本第一层动画是跑动时的动作(手会摆动),而第二层动画是原地站立举手的动作,如图中设置后就变成跑动时举手的动作了)


Timeline:
功能有点类似于视频编辑软件,主要通过Playable Director组件来控制
把相应的动画,物体,声音等直接拖入会显示创建类型,或者右键单击也可以看到有哪些类型可创建
1.可通过点击红色圆点进行动画的录制(改变position与rotation等)
2.右键单击相应轨道选择Add From Animation Clip可以生成模块,然后就能随意的拖动摆放或缩放播放内容了

点击相应的模块后可在inspector面板进行设置
1.Pre/Post - Extrapolate可以设置动画播放前/后的状态(暂时未发现这些设置对Post有何作用,因此那个“结束后”待定)
(1)None:在开始前/结束后,无,物体原始位置都会被设置为(0,0,0),动画开始的默认状态也不会有(以带有骨骼动画的人物为例,不会站立等,而是变成骨骼动画设置里的Muscle&Setting状态(苟起来)),直到播放动画为止
(2)Hold:在开始前/结束后,保持动画起始时的状态,直到播放动画为止
(3)Loop:同上,循环播放(起点 -> 终点, 起点 -> 终点。。这样一个状态),同上
(4)PingPong:同上,和循环对比的区别就是(起点 -> 终点 ->起点这一过程,不会瞬移),同上
(5)Continue:同上,在播放前会把动画播放一边然后一直等待到动画播放为止,如果动画前面部分被缩减掉一点,当放到此动画时依然会播放完整

Animator & Timeline的更多相关文章
- Unity User Group深圳站——Timeline & Cinemachine分享
报名说明:UUG深圳站,2月分享活动正式启动,1月29日中午12:00前报名可获赠Unity精美纪念礼物一份~ 关于Unity Unity 是一款多平台的综合型游戏开发工具,它的出现对蓬勃发展的全球游 ...
- Timeline高级扩展
转载于http://forum.china.unity3d.com/thread-32200-1-1.html通过demo讲解了timeline更加复杂的使用方式 Timeline是创建过场动画和影片 ...
- Timeline扩展功能实践指南
转载于http://forum.china.unity3d.com/forum.php?mod=viewthread&tid=32842,介绍了timeline的轨道扩展 Timeline功能 ...
- timeline bugs
timeline有个问题巨坑 修了很久 就是一个track控制character的position 另一个track控制同一个character的animaion 拖一段现成的动画进去 这种情况 会有 ...
- Chrome Developer Tools:Timeline Panel说明
一.Timeline panel 概况 Timeline工具栏可以详细检测出Web应用在加载过程中,时间花费情况的概览.这些应用包括下载资源,处理DOM事件, 页面布局渲染或者向屏幕绘制元素. 如下图 ...
- Animator Controller 继承关系
准备知识 对于Animator Controller中蜘蛛网一样的几十条连线,后续如果靠人工维护,那成本将是很大. AnimatorOverrideController组件的文档:https://do ...
- Unity Animator动画状态机 深入理解(二)IK控制
IK还是一个很神奇和实用的东西啊,起码可以用代码来控制人物骨骼位置还是很爽的.因为不是动画师~ 这篇可能跟Animator没啥关系了哈,都是代码层的. 看了一官方的案例,老的,有些问题,自己修改了一下 ...
- Unity Animator动画状态机 深入理解(一)
接触Unity以来就已经有了Animator,Animation用的少,不过也大概理解他俩之间的一个区别于联系. 图中其实就是Animator和Animation之间的区别于联系了,啊!你肯定会告诉我 ...
- Chrome 开发工具之Timeline
之前有说到Element,Console,Sources大多运用于debug,Network可用于debug和查看性能,今天的主角Timeline更多的是用在性能优化方面,它的作用就是记录与分析应用程 ...
随机推荐
- java 常用类2
1.1 日期时间类 时间戳(timestamp):距离特定时间的时间间隔. 计算机时间戳是指距离历元(1970-01-01 00:00:00:000)的时间间隔(ms). 计算机中时间2019-04- ...
- 学习使用 ARM 的 math 库,据说 速度比C标准库 自带的 快 几十倍 到几百倍
1.首先 添加 库 到 工程 ,路径 如下 C:\Keil\ARM\CMSIS\Lib\ARM 2.包含头文件以及在 工程里 添加 头文件 路径如下 C:\Keil\ARM\CMSIS\Includ ...
- MyBatis配置数据库连接
<environments default="default"> <environment id="default"> <tran ...
- JavaScript碎片———函数闭包(模拟面向对象)
经过这几天的博客浏览,让我见识大涨,其中有一篇让我感触犹深,JavaScript语言本身是没有面向对象的,但是那些大神们却深深的模拟出来了面向对象,让我震撼不已.本篇博客就是在此基础上加上自己的认知, ...
- PHP-----PHP程序设计基础教程----第三章函数
3.1 初识函数 3.1.1 函数的定义 语法: function 函数名([参数1,参数2,......]) { 函数体 } (1)function:在声明函数时必须使用的关键字 (2)函数名:创建 ...
- c3p0封装
配置文件 <?xml version="1.0" encoding="UTF-8"?> <c3p0-config> <defaul ...
- 学习ThinkPHP5的第一天(安装 连接数据库)
参考文档:thinkPHP5.0完全手册 一.安装 采用的是git安装方式: 应用项目:https://github.com/top-think/think 核心框架:https://github. ...
- laravel5.5源码阅读草稿——路由
laravel 里的路由是由RouteServiceProvider提供的,其中的boot方法为启动项,调用了父类的boot方法. RouteServiceProvider中的boot方法设置了自己与 ...
- [转]Python爬虫html解析工具beautifulSoup在pycharm中安装及失败的解决办法
原文地址:https://www.cnblogs.com/yysbolg/p/9040649.html 刚开始学习一门技术最麻烦的问题就是搞定IDE环境,直接在PyCharm里安装BeautifulS ...
- 在AI人工智能中如何巧妙学习大数据编程,成为五十万年薪的佼佼者
编辑 ai狗年 大数据和人工智能的关系,首先要说什么是大数据.这些年来,大数据先是被神化,继而又被妖魔化,到了今天,其实谁也不知道别人所谓的大数据指的是什么.我大数据从业者,建了一个大数据资源共享群1 ...