其他分享
首页 > 其他分享> > Unity.TimeLine

Unity.TimeLine

作者:互联网

链接:https://blog.csdn.net/beihuanlihe130/article/details/79233320

以下为旧版本TimeLine,新版本功能介绍可以看这里

Timeline是Unity2017版本中新加入的功能,可以非常方便的进行场景动画的创建和修改,包括物体、声音、粒子、动画、特效、自定义Playable以及子Timeline等多种资源进行整合,从而能够较方便的生成效果很棒的场景动画,同时可以通过Unity的Recorder资源包录制较为完整的视频并导出。
Unity官方提供的Recorder插件

1.Timeline界面简单介绍

Unity2017中,点击Window->Timeline即可调出Timeline面板。如下图所示:
Timeline功能面板
在该面板中,可以创建多种类型的片段,如果你导入AssetStore中的Default Playables资源包(其中预置了多个官方提供的简单Playable实例),其面板如下所示:
加入Default Playables资源包后可以创建的功能片段
其中常用的主要有

当我们创建了TimeLine后,会在指定位置生成TimeLine的文件*.playable,当选中该文件后,会在Inspector面板中看到其相应的属性,如下图所示:
Timeline文件属性设置
其中Frame Rate可以设置该Timeline每秒钟播放多少帧动画。Duration Mode分为Based On Clips和Fixed Length两种模式,Based On Clips模式为按照帧数来播放,当播放到最后一帧时结束播放,Fixed Length模式可以设置总共播放多长时间,当播放到指定时间是停止。Duration设置当前播放的秒数和帧数。

2.Timeline轨道简单介绍

2.1 Activation Track

Activation Track轨道
该轨道首先需要为其赋值一个GameObject,表示该轨道控制该物体的显示与隐藏,当在Timeline播放过程中,如果处于片段内部,则该物体显示,否则该物体隐藏。

当我们点击该轨道时,会在Inspector面板中看到可以设置的属性,如下所示:
Activation Track属性

2.2 Animation Track

Animation Track主要控制动画的播放,包括动画片段、帧动画等。当我们点击Animation Track时,可以设置其属性,如下图所示:
Animation Track属性面板

2.2.1 Animation Track 属性

2.2.2 动画轨道使用简介

1.添加Animation Clip
右击Animation Clip的空白处,选择Add From Animation Clip即可从已有的动画片段中选择。
添加Animation Clip
可以拖拽动画片段调整播放的时间,同时也可以将多个动画片段进行叠加来完成动画过渡效果。
动画片段
2.录制动画
可以在Animation Clip中点击红色按钮进行录制,通过设置不同的属性来为物体设置关键帧,从而完成不同类型的动画制作。
录制动画
3.设置曲线
录制的动画可以在动画窗口中打开,在动画窗口中可以通过关键帧点的方式进行控制,也可以通过曲线的方式进行控制。
曲线控制动画

2.3 Audio Track

Audio Track主要控制动画中的音效,可以设置声音的起始时间、结束时间、淡入时间、淡出时间、播放速度、不同音效间的混合效果、是否循环播放等。其属性如下所示:
音乐效果
2.4 Control Track

Control Track主要控制与时间有关的元素,如粒子效果、嵌套子Timeline等。
该轨道可以在指定的父物体下实例化一个Prefab,并对该Prefab中与时间有关的元素进行播放操作。
Control Track面板

2.5 Playable Track

Playable Track允许用户自定义相关动画效果,在Default Playables资源包中包含了一部分自定义的功能轨道,包括文字、时间、灯光、位置、寻路、淡入淡出等效果,用户也可以根据自己的需要进行定制化开发,以实现更加复杂的效果。
用户可以在代码中继承PlayableBehaviour和PlayableAsset两个类,在其中完成自定义的动画功能。

/// <summary>
///该类主要实现在TimeLine的PlayableTrack中显示我们定义的功能,并完成赋值
/// </summary>
public class PlayableBehaviourSample : PlayableAsset
{
	//使用ExposedReference进行赋值操作
    public ExposedReference<GameObject> ShowNumberText;

    private Text text;

    public int startNum;


    public override Playable CreatePlayable(PlayableGraph graph, GameObject owner)
    {
        var scriptPlayable = ScriptPlayable<PlayableTest>.Create(graph);
        //从ExposedReference中获取我们需要的控件
        text = ShowNumberText.Resolve(graph.GetResolver()).GetComponent<Text>();
        //对指定的PlayableBehaviour中的属性进行赋值
        scriptPlayable.GetBehaviour().ShowNumberText = text;
        scriptPlayable.GetBehaviour().StartNum = startNum;
        return scriptPlayable;
    }
}



/// <summary>
/// 读秒功能
/// </summary>
public class PlayableTest : PlayableBehaviour
{
	//显示文字的控件
    public Text ShowNumberText;
    public int StartNum;
    float time;
    int currentNum;
    /// <summary>
    /// 当该PlayableBehaviour的PlayableGraph启动时调用
    /// </summary>
    /// <param name="playable"></param>
    public override void OnGraphStart(Playable playable)
    {
        base.OnGraphStart(playable);
        Debug.Log("OnGraphStart Called");
        currentNum = StartNum;
        ShowNumberText.text = "Start Number Is " + StartNum;
        Debug.Log(ShowNumberText.text);
    }

    /// <summary>
    /// 当该PlayableBehaviour的PlayState转换为PlayState.Play时调用
    /// </summary>
    /// <param name="playable"></param>
    /// <param name="info"></param>
    public override void OnBehaviourPlay(Playable playable, FrameData info)
    {
        base.OnBehaviourPlay(playable, info);
        Debug.Log("OnBehaviourPlay Called");
    }

    /// <summary>
    /// 该函数与ProcessFrame函数功能相同,都是在该PlayableBehaviour播放的每一帧中调用,相当于Update函数的功能
    /// </summary>
    /// <param name="playable"></param>
    /// <param name="info"></param>
    public override void PrepareFrame(Playable playable, FrameData info)
    {
        base.PrepareFrame(playable, info);
        Debug.Log("PrepareFrame Called");
        time += Time.deltaTime;
        if (time > 1.0f)
        {
            currentNum++;
            ShowNumberText.text = "Current Number Is " + currentNum;
            Debug.Log(ShowNumberText.text);
            time -= 1.0f;
        }
    }

    /// <summary>
    /// 该函数与PrepareFrame函数功能相同,都是在该PlayableBehaviour播放的每一帧中调用,相当于Update函数的功能
    /// </summary>
    /// <param name="playable"></param>
    /// <param name="info"></param>
    /// <param name="playerData"></param>
    public override void ProcessFrame(Playable playable, FrameData info, object playerData)
    {
        base.ProcessFrame(playable, info, playerData);
        Debug.Log("ProcessFrame Called");
    }

    /// <summary>
    /// 该函数在PlayableBehaviour片段的PlayState转换为Delay时调用
    /// </summary>
    /// <param name="playable"></param>
    /// <param name="info"></param>
    public override void OnBehaviourDelay(Playable playable, FrameData info)
    {
        base.OnBehaviourDelay(playable, info);
        Debug.Log("OnBehaviourDelay Called");
    }

    /// <summary>
    /// 该函数在PlayableBehaviour片段的PlayState转换为Pause时调用
    /// </summary>
    /// <param name="playable"></param>
    /// <param name="info"></param>
    public override void OnBehaviourPause(Playable playable, FrameData info)
    {
        base.OnBehaviourPause(playable, info);
        Debug.Log("OnBehaviourPause Called");

        ShowNumberText.text = "End Number Is " + currentNum;
        Debug.Log(ShowNumberText.text);
    }

    /// <summary>
    /// 该函数在PlayableBehaviour片段停止播放时调用
    /// </summary>
    /// <param name="playable"></param>
    public override void OnGraphStop(Playable playable)
    {
        base.OnGraphStop(playable);
        Debug.Log("OnGraphStop Called");

    }

    /// <summary>
    /// 该函数在PlayableBehaviour片段创建时调用
    /// </summary>
    /// <param name="playable"></param>
    public override void OnPlayableCreate(Playable playable)
    {
        base.OnPlayableCreate(playable);
        Debug.Log("OnPlayableCreate Called");
    }

    /// <summary>
    /// 该函数在PlayableBehaviour片段销毁时调用
    /// </summary>
    /// <param name="playable"></param>
    public override void OnPlayableDestroy(Playable playable)
    {
        base.OnPlayableDestroy(playable);
        Debug.Log("OnPlayableDestroy Called");
    }

    /// <summary>
    /// 该函数在PlayableGraph的PrepareData阶段被调用
    /// </summary>
    /// <param name="playable"></param>
    /// <param name="info"></param>
    public override void PrepareData(Playable playable, FrameData info)
    {
        base.PrepareData(playable, info);
        Debug.Log("PrepareData Called");
    }
}

以下为运行后的调用顺序
调用顺序
以下为该Timeline设置的状态,主要部分为PlayableTrack。
Timeline状态
最终运行效果如下:
运行效果

该方法也可通过继承BasicPlayableBehaviour类完成,但是在未来的版本中该类可能会被PlayableBehaviour和PlayableAsset类取代(已经弃用)。

标签:Playable,动画,Track,TimeLine,Unity,Timeline,playable,public
来源: https://blog.csdn.net/Liumotor/article/details/113594263