Blend是WPF/SL開發人員的利器, 你可以在美工板上繪制形狀、路徑和控件,然后修改其外觀和行為,你也可以導入圖像、視頻和聲音等等。 今天我給大家演示如何用Blend中提供的ControlStoryboardAction行為來控制Storyboard(情節提要)。環境為Blend3+win7.
1.打開Blend, 創建wpf工程,默認為WpfApplication1. 如下圖:
[](http://hi.csdn.net/attachment/201006/22/1278723_1277187306Kfab.png)
2.利用Blend創建一個簡單的動畫
> 1>首先把Blend的工作區選為“動畫”, 切換快捷鍵為F6,打開方式“窗口/工作區/動畫”。 如下圖:
> ?[](http://hi.csdn.net/attachment/201006/22/1278723_1277187308MffY.png)
> 2>在“工具”中選擇“橢圓形”, 或者在“資產”中點擊左邊的”控件“后選擇”橢圓形“。如下圖:
> ?[](http://hi.csdn.net/attachment/201006/22/1278723_1277187309D4Vd.png)
> 3>向美工板拖入2個橢圓形,將其中一個橢圓的填充為紅色。如下圖:
> ?
> 4>選擇空白的橢圓, 然后右擊, 選擇”路徑/轉換為運動路徑“。如下圖:
> ?[](http://hi.csdn.net/attachment/201006/22/1278723_1277187311bbbZ.png)
> 5>這時Blend彈出”轉換為運動路徑“對話框,選擇紅色的橢圓, 點擊確定。Blend就會為我們生成一個情景提要Storyboard1. 點擊”play”可以立即看到動畫效果。 如下圖:
> [](http://hi.csdn.net/attachment/201006/22/1278723_1277187316JtGX.png)
> 6>關閉Storyboard1情節提要,如下圖:
> [](http://hi.csdn.net/attachment/201006/22/1278723_127718731872Z1.png)
> 7>在“資產”中點擊“行為”, 選擇“ControlStoryborardAction”, 拖動到“對象和時間線”中紅色橢圓的節點下。 如下圖:
> [](http://hi.csdn.net/attachment/201006/22/0_1277189925h81Q.gif)
> 8>點擊添加的行為“ControlStoryboardAciton”, 選擇“屬性”, 如下圖:
> [](http://hi.csdn.net/attachment/201006/22/1278723_1277187320uffL.png)
> 9>SourceName為事件的觸發對象, 此演示中即為紅色橢圓;EventName為觸發事件的名稱,此演示中為單擊鼠標左鍵;ControlStoryboardOption為情節提要的控制,有Play/Stop等等, 此演示中為Play;Storyboard為要控制的storyboard, 此演示中選擇為我們剛剛創建好的Storyboard1. 總的來說就是單擊紅色橢圓,開始播放情節提要Storyboard1,也就是讓紅色橢圓開始轉動。
> 10>F5運行,單擊紅色橢圓就可以看到大家想要的效果了。 如下圖:
> [](http://hi.csdn.net/attachment/201006/22/1278723_12771873220Lll.png)
> (p.s.大家肯定發現程序一啟動,動畫就開始播放了, 原因是剛剛Blend為我們創建Storyboard1時,也在MainWindow.xaml創建了觸發事件, 可以刪掉此代碼, 如下:
~~~
<Window.Triggers>
<EventTrigger RoutedEvent="FrameworkElement.Loaded">
<BeginStoryboard Storyboard="{StaticResource Storyboard1}"/>
</EventTrigger>
</Window.Triggers>
~~~
[](http://11011.net/software/vspaste)
OK,通過此次演示, 相信大家都會了如何在Blend中用ControlStoryboardAction控制storyboard。
參考文獻:[Control Storyboards Easily using Behaviors](http://blogs.msdn.com/b/expression/archive/2010/05/25/control-storyboards-easily-using-behaviors.aspx)
工程Demo:[SourceCode](http://d.download.csdn.net/down/2475753/muzizongheng)
- 前言
- win32與WPF的混合編程
- WPF: 一個可以用StoryBoard動態改變Grid行寬/列高的類
- MFC中調用WPF教程
- Expression Blend操作: 使用behavior來控制Storyboard
- WPF DatePicker 的textbox的焦點
- WPF 使用MultiBinding ,TwoWay ,ValidationRule ,需要注意的事項
- WPF TreeView 后臺C#選中指定的Item, 需要遍歷
- WPF GridViewColumn Sort DataTemplate
- DataGridColum的bug
- WPF Get Multibinding Expression, Update Source,
- WPF 后臺觸發 Validate UI‘s Element
- WPF ValidationRule 觸發ErrorTemplate 的注意事項
- WPF DelegateCommand CanExecute
- WPF TextBox PreviewTextInput handle IME (chinese)
- No overload for &#39;OnStartup&#39; matches delegate &#39;System.Windows.StartupEventHandler&#39;
- WPF error: does not contain a static &#39;Main&#39; method suitable for an entry point
- WPF GridView中的CellTemplate失效的原因
- DataGrid 顯示選中的item
- 如何得到WPF中控件綁定的EventTrigger
- 選中DataGrid的Cell而不是row
- ContextMenu的自定義
- 輸入框只能輸入英文
- TextBox的OnTextboxChanged事件里對Text重新賦值帶中文, 導致崩潰
- DataGrid當列寬超出當前寬度時,沒有數據也恒有滾動條
- wpf如何獲取control template里的元素
- Set connectionId threw an exception.
- WPF中Visible設為Collapse時,VisualTreeHelper.GetChildrenCount為0
- XAML 編碼規范 (思考)
- 如何為現有控件的DependencyProperty添加Value Changed事件?
- TreeView滾動TreeViewItem
- 為BindingList添加Sort
- WPF Background的設置有坑
- 自定義Panel中添加依賴屬性需要注意的問題
- TextBlock截斷字符顯示為....
- DataGrid 支持字符截斷顯示
- TreeView控件實踐
- WPF如何更改系統控件的默認高亮顏色 (Highlight brush)
- ViewModel中C# Property自動添加OnPropertyChanged處理的小工具, 以及相應Python知識點
- WPF中Xaml編譯正常而Designer Time時出錯的解決辦法
- 關于Snoop的用法
- wpf中為DataGrid添加checkbox支持多選全選
- WPF中DataGrid控件的過濾(Filter)性能分析及優化
- wpf控件提示Value ‘’ can not convert
- DropShadowEffect導致下拉框控件抖動
- 再論WPF中的UseLayoutRounding和SnapsToDevicePixels
- WPF案例:如何設計歷史記錄查看UI
- WPF案例:如何設計搜索框(自定義控件的原則和方法)
- WPF基本概念入門
- WPF開發中Designer和碼農之間的合作
- 聊聊WPF中的Dispatcher
- 聊聊WPF中字體的設置
- Bug:DataGridCell的顯示不完整
- WPF中ToolTip的自定義
- WPF中ItemsControl綁定到Google ProtocolBuffer的結構體時的性能問題
- TreeView的性能問題
- Xaml中string(字符串)常量的定義以及空格的處理
- 依賴屬性
- WPF中的CheckBox的_ (underscore / 下劃線)丟失
- WPF錯誤:必須使“Property”具有非 null 值。
- WPF中ItemsControl應用虛擬化時找到子元素的方法
- WPF毫秒級桌面時鐘的實現-C#中Hook(鉤子)的應用
- KB2464222導致IsNonIdempotentProperty方法找不見
- WPF中PreviewMouseDownEvent的系統處理:TabItem的PreviewMouseDown 事件彈框后不切換的問題調查
- WPF文字渲染相關的問題及解決
- wpf中的默認右鍵菜單中的復制、粘貼、剪貼等沒有本地化的解決方案
- WPF內部DeliverEvent讀鎖和PrivateAddListener寫鎖導致死鎖
- Windbg調試WPF的依賴屬性
- WPF 后臺Render線程崩潰, Exception from HRESULT: 0x88980406
- WPF中DependencyObject與DependencyProperty的源碼簡單剖析
- 禁用WPF中DataGrid默認的鼠標左鍵拖動多選行的效果
- wpf工程中在Xaml文件下添加多個cs文件
- ScrollViewer滾動到底來觸發加載數據的Behavior