Silverlight-애니메이션

애니메이션을 사용하면 진정한 동적 사용자 인터페이스를 만들 수 있습니다. 예를 들어 아이콘 위로 이동할 때 커지는 아이콘, 회전하는 로고, 스크롤되는 텍스트 등의 효과를 적용하는 데 자주 사용됩니다.

때때로 이러한 효과는 지나치게 현란한 것처럼 보입니다. 적절하게 사용하면 애니메이션은 여러 가지 방법으로 응용 프로그램을 향상시킬 수 있습니다. 이를 통해 응용 프로그램이보다 반응적이고 자연스럽고 직관적 인 것처럼 보일 수 있습니다.

예를 들어, 클릭 할 때 슬라이드되는 버튼은 다른 회색 사각형이 아니라 실제 물리적 버튼처럼 느껴집니다. 애니메이션은 또한 중요한 요소에주의를 끌고 사용자에게 새로운 콘텐츠로의 전환을 안내 할 수 있습니다.

Silverlight의 애니메이션 접근 방식은 프레임 애니메이션 시퀀스에 초점을 맞추지 않고 선언적입니다.

애니메이션 정의

애니메이션은 일반적으로 리소스 섹션에서 정의됩니다. 사실, 그것들은 일반적으로 스토리 보드 요소로 둘러싸여 있으며, 곧 자세히 살펴볼 것입니다.

  • Begin () 메서드를 제공하므로 코드에서 애니메이션을 호출 할 수 있습니다.

  • 애니메이션은 컨트롤 템플릿의 시각적 상태 요소 안에 넣을 수도 있습니다.

선언적 애니메이션

Silverlight의 애니메이션은 선언적입니다. 그들은 일어나고 싶은 일을 설명합니다. 어떻게해야할지 Silverlight에 맡기십시오. 따라서 애니메이션은 일반적으로 Silverlight에 변경하려는 내용을 알려주는 패턴을 따릅니다.

이것은 항상 일부 명명 된 요소의 일부 속성입니다. TargetNameTargetProperty.

<DoubleAnimation 
   Storyboard.TargetName = "myRectangle" 
   Storyboard.TargetProperty = "Opacity" 
   From = "0" To = "1" 
   Duration = "0:0:5"  
/>
  • 이 경우 해당 속성이 어떻게 변경되기를 원하는지 말하며 불투명도를 0에서 1로 변경합니다. 즉, 대상 요소가 불투명에서 투명으로 사라지는 것을 좋아합니다.

  • 마지막으로이 작업에 걸리는 시간을 말합니다.이 경우 5 초가 걸립니다.

  • 이 double 애니메이션에서 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(); 
      } 
   } 
}

위의 코드가 컴파일되고 실행되면 다음과 같은 출력이 표시됩니다.

반복 및 반전

애니메이션은 자동으로 반복되는 일부 속성과 모든 리버스 애니메이션을 제공합니다.

  • 반복 동작 속성을 시간 스팸으로 설정하면 지정된 시간이 경과 할 때까지 애니메이션이 반복적으로 반복되거나 반복 할 횟수를 지정할 수 있습니다.

  • 소수점을 지원하므로 4 번 반을 반복 할 수 있습니다.

  • 영원히 반복 할 수 있으며 애니메이션이 끝까지 도달하면 처음부터 역순으로 실행되어야한다고 말할 수도 있습니다.

키 프레임 애니메이션

종종 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(); 
      } 
   } 
}

위의 코드가 컴파일되고 실행되면 다음과 같은 출력이 표시됩니다.

웹 페이지를 클릭하면 공이 움직이기 시작하는 것을 볼 수 있습니다.