Silverlight - ภาพเคลื่อนไหว

แอนิเมชั่นช่วยให้คุณสร้างอินเทอร์เฟซผู้ใช้แบบไดนามิกได้อย่างแท้จริง มักใช้เพื่อใช้เอฟเฟกต์เช่นไอคอนที่ขยายใหญ่ขึ้นเมื่อคุณเลื่อนไปมาโลโก้ที่หมุนข้อความที่เลื่อนเข้าไปในมุมมองและอื่น ๆ

บางครั้งเอฟเฟกต์เหล่านี้ดูเหมือนจะเป็นประกายมากเกินไป หากใช้อย่างเหมาะสมภาพเคลื่อนไหวสามารถปรับปรุงแอปพลิเคชันได้หลายวิธี พวกเขาสามารถทำให้แอปพลิเคชันดูตอบสนองเป็นธรรมชาติและใช้งานง่ายมากขึ้น

ตัวอย่างเช่นปุ่มที่เลื่อนเข้ามาเมื่อคุณคลิกปุ่มจะให้ความรู้สึกเหมือนเป็นปุ่มจริงไม่ใช่แค่สี่เหลี่ยมผืนผ้าสีเทาอื่น ภาพเคลื่อนไหวยังสามารถดึงดูดความสนใจไปยังองค์ประกอบที่สำคัญและแนะนำผู้ใช้ผ่านการเปลี่ยนไปยังเนื้อหาใหม่

แนวทางของ Silverlight ในการสร้างภาพเคลื่อนไหวนั้นมีการเปิดเผยแทนที่จะมุ่งเน้นไปที่ลำดับของภาพเคลื่อนไหวแบบเฟรม

การกำหนดภาพเคลื่อนไหว

โดยทั่วไปแล้วภาพเคลื่อนไหวจะถูกกำหนดไว้ในส่วนทรัพยากร ในความเป็นจริงพวกเขามักจะห่อด้วยองค์ประกอบของกระดานเรื่องราวซึ่งเราจะได้เห็นในรายละเอียดในไม่ช้า

  • มีวิธีการเริ่มต้น () ดังนั้นจึงสามารถเรียกภาพเคลื่อนไหวจากโค้ดได้

  • คุณยังสามารถใส่ภาพเคลื่อนไหวภายในองค์ประกอบสถานะภาพในเทมเพลตการควบคุม

แอนิเมชั่นที่เปิดเผย

ภาพเคลื่อนไหวใน Silverlight มีการเปิดเผย พวกเขาอธิบายถึงสิ่งที่ต้องการให้เกิดขึ้น ฝากไว้ที่ Silverlight เพื่อหาวิธีทำให้เกิดขึ้น โดยทั่วไปแล้วภาพเคลื่อนไหวจะเป็นไปตามรูปแบบที่เราบอก Silverlight ว่าเราต้องการเปลี่ยนแปลงอะไร

นี่คือคุณสมบัติบางอย่างในองค์ประกอบที่มีชื่อบางอย่างเสมอเช่น TargetName และ TargetProperty.

<DoubleAnimation 
   Storyboard.TargetName = "myRectangle" 
   Storyboard.TargetProperty = "Opacity" 
   From = "0" To = "1" 
   Duration = "0:0:5"  
/>
  • เราบอกว่าเราต้องการให้คุณสมบัตินั้นเปลี่ยนแปลงอย่างไรในกรณีนี้เรากำลังเปลี่ยนความทึบจากค่าศูนย์เป็นค่าหนึ่ง กล่าวอีกนัยหนึ่งคือเราต้องการให้องค์ประกอบเป้าหมายจางลงจากทึบแสงเป็นโปร่งใส

  • สุดท้ายเราบอกว่าเราต้องการให้ใช้เวลานานแค่ไหนในกรณีนี้จะใช้เวลาห้าวินาที

  • ความสำคัญของ double ในแอนิเมชั่นคู่นี้คือกำหนดเป้าหมายคุณสมบัติที่มีประเภท double ดังนั้นค่าทศนิยม

  • หากคุณต้องการทำให้คุณสมบัติที่เป็นตัวแทนของสีเคลื่อนไหวให้ใช้ภาพเคลื่อนไหวสีแทน

ให้เราดูตัวอย่างง่ายๆของแอนิเมชั่นคู่ ระบุด้านล่างนี้คือรหัส XAML ซึ่งมีปุ่มสองปุ่ม, หนึ่งสี่เหลี่ยมผืนผ้าและสองกระดานเรื่องราวที่เพิ่มเข้ามา

<UserControl x:Class = "DoubleAnimationExample.MainPage" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"  
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"  
   xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"  
   mc:Ignorable = "d" d:DesignWidth = "640" d:DesignHeight = "480">
   
   <UserControl.Resources> 
	
      <Storyboard x:Name = "fadeDown"> 
         <DoubleAnimation  
            Storyboard.TargetName = "myRectangle" 
            Storyboard.TargetProperty = "Opacity" 
            From = "1" To = "0" 
            Duration = "0:0:5" /> 
      </Storyboard> 
		
      <Storyboard x:Name = "fadeUp"> 
         <DoubleAnimation 
            Storyboard.TargetName = "myRectangle" 
            Storyboard.TargetProperty = "Opacity" 
            From = "0" To = "1" 
            Duration = "0:0:5" /> 
      </Storyboard> 
		
   </UserControl.Resources> 
	
   <Grid x:Name = "LayoutRoot"> 
      <Rectangle x:Name = "myRectangle" 
         Fill = "Blue" Width = "300" Height = "100"  
         HorizontalAlignment = "Center" 
         VerticalAlignment = "Top" Margin = "0,30" /> 
			
      <Button x:Name = "fadeUpButton" Content = "Up" Width = "80"  
         Height = "30" HorizontalAlignment = "Left" 
         VerticalAlignment = "Top" Margin = "50,140,0,0"  
         Click = "fadeUpButton_Click" /> 
			
      <Button x:Name = "fadeDownButton" Content = "Down"  
         Width = "80" Height = "30" HorizontalAlignment = "Left" 
         VerticalAlignment = "Top" Margin = "50,180,0,0"  
         Click = "fadeDownButton_Click" />
			
   </Grid>
	
</UserControl>

นี่คือการนำไปใช้สำหรับเหตุการณ์ต่างๆใน C #

using System.Windows; 
using System.Windows.Controls;  

namespace DoubleAnimationExample { 

   public partial class MainPage : UserControl { 
	
      public MainPage() { 
         InitializeComponent(); 
      } 
	  
      private void fadeUpButton_Click(object sender, RoutedEventArgs e) { 
         fadeUp.Begin(); 
      }
	  
      private void fadeDownButton_Click(object sender, RoutedEventArgs e) { 
         fadeDown.Begin(); 
      } 
   } 
}

เมื่อโค้ดด้านบนถูกคอมไพล์และดำเนินการคุณจะเห็นผลลัพธ์ต่อไปนี้

การทำซ้ำและการย้อนกลับ

ภาพเคลื่อนไหวมีคุณสมบัติบางอย่างในการทำซ้ำโดยอัตโนมัติและภาพเคลื่อนไหวย้อนกลับทั้งหมด

  • หากคุณตั้งค่าคุณสมบัติการทำงานซ้ำเป็นสแปมไทม์แอนิเมชั่นจะวนซ้ำจนกว่าจะครบระยะเวลาที่กำหนดหรือคุณสามารถบอกได้ว่าคุณต้องการให้เล่นซ้ำกี่ครั้ง

  • สิ่งนี้รองรับจุดทศนิยมเพื่อให้คุณทำซ้ำได้สี่ครั้งครึ่ง

  • คุณสามารถทำซ้ำได้ตลอดไปและคุณยังสามารถบอกแอนิเมชั่นได้ด้วยว่าเมื่อถึงจุดสิ้นสุดแล้วควรจะทำงานย้อนกลับไปที่จุดเริ่มต้น

ภาพเคลื่อนไหวคีย์เฟรม

บ่อยครั้งที่แอนิเมชั่นธรรมดาจาก A ถึง B นั้นเรียบง่ายเกินไป ตัวอย่างเช่นคุณต้องการสร้างภาพเคลื่อนไหวให้ลูกบอลกระดอนจากพื้น นี่ไม่ใช่การเคลื่อนไหวแบบชี้จุดง่ายๆ ลูกบอลลดลงเร่งขึ้นทีละน้อยแล้วกลับทิศทางเมื่อกระทบด้านล่าง ช้าลงอีกครั้งเมื่อกลับมาถึงจุดสูงสุดของการเดินทาง

ให้เราดูตัวอย่างง่ายๆของ Key Frame animation.

ด้านล่างคือรหัส XAML ซึ่งประกอบด้วยวงรีและภาพเคลื่อนไหวคู่พร้อมคีย์เฟรม

<UserControl x:Class = "LinearKeyFrames.MainPage" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"  
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   xmlns:d = "http://schemas.microsoft.com/expression/blend/2008" 
   xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"  
   mc:Ignorable = "d" 
   Width = "400" Height = "300">
   
   <UserControl.Resources> 
	
      <Storyboard x:Name = "ballAnim" SpeedRatio = "0.2"> 
         <DoubleAnimation From = "0" Duration = "00:00:03" To = "96" 
            Storyboard.TargetName = "ellipse" 
            Storyboard.TargetProperty = "(Canvas.Left)" />
				
         <DoubleAnimationUsingKeyFrames  
            Storyboard.TargetName = "ellipse" 
            Storyboard.TargetProperty = "(Canvas.Top)"> 

            <LinearDoubleKeyFrame KeyTime = "00:00:00"   Value = "0"/> 
            <LinearDoubleKeyFrame KeyTime = "00:00:00.5" Value = "16" /> 
            <LinearDoubleKeyFrame KeyTime = "00:00:01"   Value = "48"/> 
            <LinearDoubleKeyFrame KeyTime = "00:00:01.5" Value = "112"/> 
            <LinearDoubleKeyFrame KeyTime = "00:00:02"   Value = "48"/> 
            <LinearDoubleKeyFrame KeyTime = "00:00:02.5" Value = "16"/> 
            <LinearDoubleKeyFrame KeyTime = "00:00:03"   Value = "0"/> 
				
         </DoubleAnimationUsingKeyFrames> 
			
      </Storyboard>
		
   </UserControl.Resources>
	
   <Grid x:Name = "LayoutRoot" Background = "White"> 
      <Canvas> 
         <Ellipse x:Name = "ellipse" Fill = "Aqua" Width = "50" Height = "50" /> 
      </Canvas> 
   </Grid> 
	
</UserControl>

นี่คือการใช้งานสำหรับ mouse left เหตุการณ์ปุ่มลงซึ่งจะเริ่มเคลื่อนไหวเมื่อผู้ใช้กดปุ่มซ้ายของเมาส์ลงบนหน้าเว็บ

using System.Windows.Controls; 
using System.Windows.Input; 
 
namespace LinearKeyFrames { 

   public partial class MainPage : UserControl {
	
      public MainPage() { 
         InitializeComponent();  
         this.MouseLeftButtonDown += new MouseButtonEventHandler(Page_MouseLeftButtonDown); 
      } 
	  
      void Page_MouseLeftButtonDown(object sender, MouseButtonEventArgs e) { 
         ballAnim.Begin(); 
      } 
   } 
}

เมื่อโค้ดด้านบนถูกคอมไพล์และดำเนินการคุณจะเห็นผลลัพธ์ต่อไปนี้

เมื่อคุณคลิกที่หน้าเว็บคุณจะเห็นว่าลูกบอลเริ่มเคลื่อนที่