亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

WPF實(shí)現(xiàn)動(dòng)畫(huà)效果(五)之關(guān)鍵幀動(dòng)畫(huà)

 更新時(shí)間:2022年06月23日 11:18:00   作者:天方  
這篇文章介紹了WPF實(shí)現(xiàn)動(dòng)畫(huà)效果之關(guān)鍵幀動(dòng)畫(huà),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

WPF動(dòng)畫(huà)效果系列

WPF實(shí)現(xiàn)動(dòng)畫(huà)效果(一)之基本概念

WPF實(shí)現(xiàn)動(dòng)畫(huà)效果(二)之From/To/By 動(dòng)畫(huà)

WPF實(shí)現(xiàn)動(dòng)畫(huà)效果(三)之時(shí)間線(TimeLine)

WPF實(shí)現(xiàn)動(dòng)畫(huà)效果(四)之緩動(dòng)函數(shù)

WPF實(shí)現(xiàn)動(dòng)畫(huà)效果(五)之關(guān)鍵幀動(dòng)畫(huà)

WPF實(shí)現(xiàn)動(dòng)畫(huà)效果(六)之路徑動(dòng)畫(huà)

WPF實(shí)現(xiàn)動(dòng)畫(huà)效果(七)之演示圖板

正文

與 From/To/By 動(dòng)畫(huà)類似,關(guān)鍵幀動(dòng)畫(huà)以也可以以動(dòng)畫(huà)形式顯示目標(biāo)屬性值。 和From/To/By 動(dòng)畫(huà)不同的是, From/To/By 動(dòng)畫(huà)只能控制在兩個(gè)狀態(tài)之間變化,而關(guān)鍵幀動(dòng)畫(huà)則可以在多個(gè)狀態(tài)之間變化,例如,對(duì)于前面那個(gè)改變按鈕寬度的例子,如果我們要實(shí)現(xiàn)如下效果:

  • 在2秒時(shí)將寬度從 0變?yōu)?50

  • 在7秒時(shí)將寬度變?yōu)?0

  • 在9秒的時(shí)候?qū)⑵鋵挾茸優(yōu)?00

雖然我們可以用三個(gè)From/To/By 動(dòng)畫(huà)組合實(shí)現(xiàn)類似效果,但是這樣一來(lái)麻煩,二來(lái)要感知?jiǎng)赢?huà)完成事件,不方便在XAML中使用。此時(shí)我們則可以使用關(guān)鍵幀動(dòng)畫(huà)來(lái)快速實(shí)現(xiàn)這一過(guò)程。

    var widthAnimation = new DoubleAnimationUsingKeyFrames();
    var keyFrames = widthAnimation.KeyFrames;

    keyFrames.Add(new LinearDoubleKeyFrame(0, TimeSpan.FromSeconds(0)));
    keyFrames.Add(new LinearDoubleKeyFrame(350, TimeSpan.FromSeconds(2)));
    keyFrames.Add(new LinearDoubleKeyFrame(50, TimeSpan.FromSeconds(7)));
    keyFrames.Add(new LinearDoubleKeyFrame(200, TimeSpan.FromSeconds(9)));

    button.BeginAnimation(WidthProperty, widthAnimation);

可以看出,關(guān)鍵幀動(dòng)畫(huà)將每一個(gè)狀態(tài)制定為一個(gè)關(guān)鍵幀,關(guān)鍵幀動(dòng)畫(huà)時(shí)間線自動(dòng)連接各個(gè)關(guān)鍵幀,并計(jì)算過(guò)渡狀態(tài),完成動(dòng)畫(huà)。因此,某種程度上,我們也可以把From/To/By 動(dòng)畫(huà)看成是只有兩個(gè)狀態(tài)的特殊關(guān)鍵幀動(dòng)畫(huà)。

內(nèi)置的關(guān)鍵幀動(dòng)畫(huà)

與 From/To/By 動(dòng)畫(huà)一樣,在名字空間System.Windows.Media.Animation 下也內(nèi)置了大量關(guān)鍵幀動(dòng)畫(huà),它們的命名規(guī)則是:    

<類型> AnimationUsingKeyFrames

例如這兒使用的DoubleAnimationUsingKeyFrames,其它類型請(qǐng)參看MSDN:關(guān)鍵幀動(dòng)畫(huà)概述,這里就不列舉了。

插值算法

在關(guān)鍵幀動(dòng)畫(huà)中,我們除了定義關(guān)鍵幀外,還需要定義兩個(gè)關(guān)鍵幀之間的插值算法,這樣系統(tǒng)才能根據(jù)關(guān)鍵幀和插值算法生成中間狀態(tài)。WPF系統(tǒng)內(nèi)置四種插值算法:

  • 線性:兩個(gè)關(guān)鍵幀之間均勻變化

  • 離散:兩個(gè)關(guān)鍵幀之間突變(到達(dá)時(shí)間點(diǎn)的時(shí)候硬切換,沒(méi)有過(guò)渡效果)

  • 樣條:使用貝塞爾曲線實(shí)現(xiàn)更精確的加速和減速控制

  • 緩動(dòng):使用緩動(dòng)函數(shù)曲線實(shí)現(xiàn)彈性變化

綜上來(lái)看,線性算法最常用,樣條算法能實(shí)現(xiàn)精準(zhǔn)加速和減速控制。離散的這種硬切換的效果雖然看起來(lái)沒(méi)有什么動(dòng)畫(huà)效果,但用于連接關(guān)鍵幀還是比較常用的。另外在一些硬過(guò)渡的地方也是能用到的,例如實(shí)現(xiàn)閃爍效果。

這幾種算法的具體效果這里就不做更多的介紹了,感興趣的朋友可以看看如下兩個(gè)鏈接中的描述和例子:

值得一提的是,并不是所有關(guān)鍵幀動(dòng)畫(huà)都支持這幾種算法的,具體支持情況請(qǐng)參看MSDN:關(guān)鍵幀動(dòng)畫(huà)概述。 當(dāng)然,對(duì)于不支持的也是可以自己手動(dòng)實(shí)現(xiàn)的。

關(guān)鍵幀(IKeyFrame)

前面已經(jīng)介紹過(guò),一個(gè)關(guān)鍵幀主要有時(shí)間點(diǎn)和插值算法兩部分組成,在WPF中,不同的關(guān)鍵幀動(dòng)畫(huà)對(duì)應(yīng)著同的關(guān)鍵幀對(duì)象,它們都繼承自IKeyFrame接口,其命名規(guī)則為:

<類型> KeyFrame

例如,DoubleAnimationUsingKeyFrames對(duì)應(yīng)的是DoubleKeyFrame,但由于這個(gè)類并沒(méi)有制定插值算法,它只是一個(gè)抽象基類,再加上插值算法后對(duì)應(yīng)的關(guān)鍵幀類命名規(guī)范為:

<插值算法><類型> KeyFrame

例如,DoubleKeyFrame對(duì)應(yīng)的幾種插值算法的關(guān)鍵幀為:LinearDoubleKeyFrame、DiscreteDoubleKeyFrame、SplineDoubleKeyFrame、EasingDoubleKeyFrame。這些關(guān)鍵幀對(duì)象使用的方式都比較類似,這里就不多介紹了。

關(guān)鍵幀的時(shí)間點(diǎn)(KeyTime)

關(guān)鍵幀的時(shí)間點(diǎn)由IKeyFrame.KeyTime屬性指定。它是一個(gè)KeyTime類型,它有如下幾種取值類型:

  • 時(shí)間點(diǎn)TimeSpan:靠TimeSpan直接決定時(shí)間點(diǎn),可以通過(guò)函數(shù)KeyTime.FromTimeSpan()創(chuàng)建,也可以直接用TimeSpan隱式轉(zhuǎn)換。

  • 相對(duì)時(shí)間Percent:指定的是百分比,通過(guò)時(shí)間線的Duration來(lái)聯(lián)合決定對(duì)應(yīng)的時(shí)間點(diǎn)。通過(guò)函數(shù)KeyTime.FromPercent()創(chuàng)建。

  • 特殊值Uniform:時(shí)間線平均分布每個(gè)關(guān)鍵幀所需要的時(shí)間。通過(guò)函數(shù)KeyTime.Uniform創(chuàng)建。

  • 特殊值Paced:間線按固定的幀率分配所需時(shí)間,這種情況下,變化大的關(guān)鍵幀分配時(shí)間長(zhǎng),變化小的關(guān)鍵幀分配時(shí)間段。通過(guò)函數(shù)KeyTime.Paced創(chuàng)建。

用代碼創(chuàng)建的方式這兒就不舉例了,這里就僅僅列舉一下如何在XAML中表示這幾種時(shí)間:

    <LinearDoubleKeyFrame Value="100" KeyTime="0:0:3" />
    <LinearDoubleKeyFrame Value="100" KeyTime="30%" />
    <LinearDoubleKeyFrame Value="100" KeyTime="Uniform" />
    <LinearDoubleKeyFrame Value="100" KeyTime="Paced" />

參考資料:

關(guān)鍵幀動(dòng)畫(huà)概述

到此這篇關(guān)于WPF實(shí)現(xiàn)動(dòng)畫(huà)效果之關(guān)鍵幀動(dòng)畫(huà)的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C#實(shí)現(xiàn)將程序運(yùn)行信息寫(xiě)入日志的方法

    C#實(shí)現(xiàn)將程序運(yùn)行信息寫(xiě)入日志的方法

    這篇文章主要介紹了C#實(shí)現(xiàn)將程序運(yùn)行信息寫(xiě)入日志的方法,可實(shí)現(xiàn)將程序運(yùn)行信息寫(xiě)入日志并存儲(chǔ)在Debug目錄下的"/Log/PRG"下的功能,涉及C#針對(duì)日志的相關(guān)寫(xiě)入技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-08-08
  • C#實(shí)現(xiàn)導(dǎo)入CSV文件到Excel工作簿的方法

    C#實(shí)現(xiàn)導(dǎo)入CSV文件到Excel工作簿的方法

    這篇文章主要介紹了C#實(shí)現(xiàn)導(dǎo)入CSV文件到Excel工作簿的方法,涉及C#針對(duì)office組件的相關(guān)操作技巧,需要的朋友可以參考下
    2015-06-06
  • C# 調(diào)用騰訊即時(shí)通信 IM的示例

    C# 調(diào)用騰訊即時(shí)通信 IM的示例

    這篇文章主要介紹了C# 調(diào)用騰訊即時(shí)通信 IM的示例,幫助大家更好的理解和使用c#,感興趣的朋友可以了解下
    2020-11-11
  • 詳解c#中Array,ArrayList與List<T>的區(qū)別、共性與相互轉(zhuǎn)換

    詳解c#中Array,ArrayList與List<T>的區(qū)別、共性與相互轉(zhuǎn)換

    本文詳細(xì)講解了c#中Array,ArrayList與List<T>的區(qū)別、共性與相互轉(zhuǎn)換,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-12-12
  • C#中的const和readonly關(guān)鍵字詳解

    C#中的const和readonly關(guān)鍵字詳解

    本文詳細(xì)講解了C#中的const和readonly關(guān)鍵字,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-08-08
  • 利用C#開(kāi)發(fā)瀏覽器擴(kuò)展的全過(guò)程記錄

    利用C#開(kāi)發(fā)瀏覽器擴(kuò)展的全過(guò)程記錄

    做web開(kāi)發(fā)的同學(xué),經(jīng)常會(huì)用到各種chrome瀏覽器插件,那么我們寄幾怎么開(kāi)發(fā)一個(gè)插件呢(其實(shí)是瀏覽器擴(kuò)展)?這篇文章主要給大家介紹了關(guān)于利用C#開(kāi)發(fā)瀏覽器擴(kuò)展的相關(guān)資料,需要的朋友可以參考下
    2021-07-07
  • Unity3D實(shí)現(xiàn)鼠標(biāo)控制視角轉(zhuǎn)動(dòng)

    Unity3D實(shí)現(xiàn)鼠標(biāo)控制視角轉(zhuǎn)動(dòng)

    這篇文章主要為大家詳細(xì)介紹了Unity3D實(shí)現(xiàn)鼠標(biāo)控制視角轉(zhuǎn)動(dòng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-02-02
  • C#二叉搜索樹(shù)插入算法實(shí)例分析

    C#二叉搜索樹(shù)插入算法實(shí)例分析

    這篇文章主要介紹了C#二叉搜索樹(shù)插入算法,實(shí)例分析了C#二叉樹(shù)操作的相關(guān)技巧,需要的朋友可以參考下
    2015-04-04
  • C#設(shè)計(jì)模式之職責(zé)鏈模式示例詳解

    C#設(shè)計(jì)模式之職責(zé)鏈模式示例詳解

    這篇文章主要給大家介紹了關(guān)于C#設(shè)計(jì)模式之職責(zé)鏈模式的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • 一文帶你吃透C#中面向?qū)ο蟮南嚓P(guān)知識(shí)

    一文帶你吃透C#中面向?qū)ο蟮南嚓P(guān)知識(shí)

    這篇文章主要為大家詳細(xì)介紹了C#中面向?qū)ο蟮南嚓P(guān)知識(shí),文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)C#有一定的幫助,需要的小伙伴可以參考一下
    2023-02-02

最新評(píng)論