WPF:使用C#代碼讓ColorAnimation為Brush加動畫

來源:互聯網
上載者:User

加動畫一般在XAML中,但是在某些時刻需要動態得用C#去寫動畫邏輯。

 

使用Storyboard.Begin

第一個方法比較簡單,比如有這樣一個Rectangle已經定義在XAML中:

<Rectangle Name="rectangle" />

 

我們把Rectangle的顏色從紅色變為綠色:

var storyboard = new Storyboard();

Storyboard.SetTarget(storyboard, rectangle);

Storyboard.SetTargetProperty(storyboard, new PropertyPath("Fill.Color"));

 

var colorAnm = new ColorAnimation(Colors.Red, new Duration(TimeSpan.FromSeconds(1)));

colorAnm.From = Colors.Green;

storyboard.Children.Add(colorAnm);

 

storyboard.Begin();

注意Storyboard的SetTargetProperty需要一個PropertyPath對象,這裡通過這個PropertyPath去指定Fill屬性的Color屬性。

 

使用Animatable.BeginAnimation

如果直接使用Animatable.BeginAnimation,那麼我們只能使用SolidColorBrush的BeginAnimation方法。由於XAML上直接定義的控制項Freezable.IsFrozen為True。所以這種方法,我們只能手動建立需要動畫的對象,然後設定自己的沒有被封凍(Freezable.IsFrozen=false)的SolidColorBrush,最後使用這個SolidColorBrush的BeginAnimation開始動畫。

 

代碼:

var solid = new SolidColorBrush(Colors.Green);

//建立Rectangle

var rec = new Rectangle() { Fill = solid };

//添加Rectangle到介面上

grid.Children.Clear();

grid.Children.Add(rec);

 

var colorAnm = new ColorAnimation(Colors.Red, new Duration(TimeSpan.FromSeconds(1)));

colorAnm.From = Colors.Green;

 

solid.BeginAnimation(SolidColorBrush.ColorProperty, colorAnm);

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.