1. 程式人生 > >Expression Blend實例動畫-大壩水位升高演示

Expression Blend實例動畫-大壩水位升高演示

group AR 自己 文字 ble exp 單個 blog lean

原文:Expression Blend實例動畫-大壩水位升高演示

Expression Blend是個很強大的東西,用它可以完成很多不好做的動畫效果。

動畫的主要元素:

  時間線(Timeline) :定義了值隨著時間的變化方式。有不同類型的時間線,可用於改變不同類型的值。所以時間線的基類都是Timeline。為了連續改變double,可以使用DoubleAnimation類。

  Timeline的主要屬性

  AutoReverse :使用該屬性,可以指定連續改變的值在動畫結束後是否返回初始值。

  SpeedRatio:使用該屬性,可以改變動畫的執行速度。在這個屬性中,可以定義父子元素的相對關系。默認值為1,將速率設為較小的值時,動畫的執行速度較慢。

  BeginTime:使用該屬性,可以指定從觸發事件開始到動畫開始之間的長度。

  Duration:指定動畫執行一次的時間長度。

  RepeatBehavior:定義動畫重復的次數或重復的時間。

  FillBehavior:如果父元素的時間線有不同的持續時間,則FillBehavior屬性就很重要。

  關於更多的Timeline類的屬性可以參考?MSDN:http://msdn.microsoft.com/zh-cn/library/system.windows.media.animation.timeline_properties%28VS.85%29.aspx

  情景板(Storyboard) :用於合並動畫。Storyboard類派生子基類TimelineGroup,TimelineGroup又派生自基類Timeline。

  情景板或者故事板繼承自基類Timeline,但是可以包含幾個時間線。StoryBoard類可以用於控制時間線。

  StoryBoard類的主要方法如下:

  Begin():啟動與情景板相關的動畫

  BeginAnimation():可以為一個依賴屬性啟動單個動畫

  CreateClock():返回一個Clock對象,用於控制動畫

  Pause()、Resume():暫停、恢復動畫

  Seek():使動畫移動到指定的時間處

  Stop():停止動畫

  觸發器(Trigger) :通過觸發器可以啟動和停止動畫。


我這裏用vs2013自帶的Blend工具來制作一個簡單的大壩水位升高的動畫演示:

技術分享圖片

1.打開Blend後新建一個Wpf項目:

技術分享圖片

2.用左側的“筆”工具畫出所需要的大壩及湖泊的大概形狀出來,用label或者textbox控件加入相應的文字信息,然後可以填充一下自己需要的顏色:

技術分享圖片

技術分享圖片

3.在對象菜單欄下面選擇“新建”按鈕,新建一個StoryBoard,擊“Ok”後,Objects and Timeline編輯框將載入剛剛創建的StoryBoard,在右邊出現了動畫控制按鈕,關鍵幀設置按鈕以及時間線顯示面板。
技術分享圖片

4.在設計主窗口,會看到一個紅色框,這代表著控件處於動畫錄制狀態:

技術分享圖片

5.在黃色進程線為“0:00:00”的位置,點擊添加一個KeyFrame關鍵幀:

技術分享圖片

6.移動黃色進程線到“0:01:000”位置:

技術分享圖片

7.最後拖動湖泊這個梯形向上拉即可:

技術分享圖片

8.如果想一直循環運行或者規定次數的話,可以在屬性進行設置,選擇AutoReverse和RepeatBehavior:

技術分享圖片

9.運行後效果如圖:

技術分享圖片


Expression Blend實例動畫-大壩水位升高演示