WPF-라우트 된 이벤트

routed event이벤트를 발생시킨 객체뿐만 아니라 요소 트리의 여러 리스너에서 핸들러를 호출 할 수있는 이벤트 유형입니다. 기본적으로 Routed Event 클래스의 인스턴스에서 지원하는 CLR 이벤트입니다. WPF 이벤트 시스템에 등록됩니다. RoutedEvents에는 다음과 같은 세 가지 주요 라우팅 전략이 있습니다.

  • 직접 이벤트
  • 버블 링 이벤트
  • 터널 이벤트

직접 이벤트

직접 이벤트는 이벤트가 시작된 요소에 의해 발생하는 Windows 양식의 이벤트와 유사합니다.

표준 CLR 이벤트와 달리 직접 라우트 된 이벤트는 클래스 처리를 지원하며 사용자 지정 컨트롤 스타일 내에서 이벤트 설정 기 및 이벤트 트리거에서 사용할 수 있습니다.

직접 이벤트의 좋은 예는 MouseEnter 이벤트입니다.

버블 링 이벤트

버블 링 이벤트는 이벤트가 시작된 요소로 시작됩니다. 그런 다음 시각적 트리에서 시각적 트리의 맨 위 요소로 이동합니다. 따라서 WPF에서 최상위 요소는 대부분 창입니다.

터널 이벤트

요소 트리 루트의 이벤트 처리기가 호출 된 다음 이벤트가 시작된 요소에 도달 할 때까지 이벤트가 시각적 트리에서 모든 자식 노드로 이동합니다.

버블 링 이벤트와 터널링 이벤트의 차이점은 터널링 이벤트는 항상 미리보기로 시작된다는 것입니다.

WPF 애플리케이션에서 이벤트는 종종 터널링 / 버블 링 쌍으로 구현됩니다. 따라서 미리보기 MouseDown과 MouseDown 이벤트가 있습니다.

다음은 일부 속성 및 이벤트를 사용하여 단추와 세 개의 텍스트 블록이 생성되는 Routed 이벤트의 간단한 예입니다.

<Window x:Class = "WPFRoutedEvents.MainWindow" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   Title = "MainWindow" Height = "450" Width = "604" ButtonBase.Click  = "Window_Click" >
	
   <Grid> 
      <StackPanel Margin = "20" ButtonBase.Click = "StackPanel_Click">
		
         <StackPanel Margin = "10"> 
            <TextBlock Name = "txt1" FontSize = "18" Margin = "5" Text = "This is a TextBlock 1" /> 
            <TextBlock Name = "txt2" FontSize = "18" Margin = "5" Text = "This is a TextBlock 2" /> 
            <TextBlock Name = "txt3" FontSize = "18" Margin = "5" Text = "This is a TextBlock 3" /> 
         </StackPanel> 
			
         <Button Margin = "10" Content = "Click me" Click = "Button_Click" Width = "80"/> 
      </StackPanel> 
   </Grid> 
	
</Window>

다음은 Button, StackPanel 및 Window에 대한 Click 이벤트 구현에 대한 C # 코드입니다.

using System.Windows; 
 
namespace WPFRoutedEvents { 
   /// <summary> 
      /// Interaction logic for MainWindow.xaml 
   /// </summary>
	
   public partial class MainWindow : Window { 
	
      public MainWindow() { 
         InitializeComponent(); 
      }  
		
      private void Button_Click(object sender, RoutedEventArgs e) { 
         txt1.Text = "Button is Clicked"; 
      } 
		
      private void StackPanel_Click(object sender, RoutedEventArgs e) { 
         txt2.Text = "Click event is bubbled to Stack Panel"; 
      } 
		
      private void Window_Click(object sender, RoutedEventArgs e) { 
         txt3.Text = "Click event is bubbled to Window"; 
      }
		
   } 
}

위의 코드를 컴파일하고 실행하면 다음과 같은 창이 생성됩니다.

버튼을 클릭하면 아래와 같이 텍스트 블록이 업데이트됩니다.

특정 수준에서 라우트 된 이벤트를 중지하려면 e.Handled = true를 설정해야합니다.

변경하자 StackPanel_Click 아래와 같이 이벤트-

private void StackPanel_Click(object sender, RoutedEventArgs e) { 
   txt2.Text = "Click event is bubbled to Stack Panel"; 
   e.Handled = true; 
}

버튼을 클릭하면 클릭 이벤트가 창으로 라우팅되지 않고 스택 패널에서 중지되고 세 번째 텍스트 블록이 업데이트되지 않는 것을 볼 수 있습니다.

사용자 지정 라우팅 이벤트

.NET Framework에서는 사용자 지정 라우트 된 이벤트도 정의 할 수 있습니다. C #에서 사용자 지정 라우트 된 이벤트를 정의하려면 아래 단계를 따라야합니다.

  • 시스템 호출 RegisterRoutedEvent를 사용하여 라우트 된 이벤트를 선언하고 등록하십시오.

  • 라우팅 전략 (예 : 버블, 터널 또는 직접)을 지정합니다.

  • 이벤트 핸들러를 제공하십시오.

사용자 지정 라우트 된 이벤트에 대해 더 자세히 이해하기 위해 예를 들어 보겠습니다. 아래 단계를 따르십시오-

  • WPFCustomRoutedEvent를 사용하여 새 WPF 프로젝트 만들기

  • 솔루션을 마우스 오른쪽 단추로 클릭하고 추가> 새 항목 ...을 선택하십시오.

  • 다음 대화 상자가 열리면 이제 Custom Control (WPF) 이름을 MyCustomControl.

  • 클릭 Add 버튼을 클릭하면 두 개의 새 파일 (Themes / Generic.xaml 및 MyCustomControl.cs)이 솔루션에 추가되는 것을 볼 수 있습니다.

다음 XAML 코드는 Generic.xaml 파일에서 사용자 지정 컨트롤의 스타일을 설정합니다.

<ResourceDictionary 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   xmlns:local = "clr-namespace:WPFCustomRoutedEvent">
	
   <Style TargetType = "{x:Type local:MyCustomControl}"> 
      <Setter Property = "Margin" Value = "50"/> 
      <Setter Property = "Template"> 
         <Setter.Value> 
            <ControlTemplate TargetType = "{x:Type local:MyCustomControl}">
				
               <Border Background = "{TemplateBinding Background}" 
                  BorderBrush = "{TemplateBinding BorderBrush}" 
                  BorderThickness = "{TemplateBinding BorderThickness}"> 
                  <Button x:Name = "PART_Button" Content = "Click Me" /> 
               </Border> 
					
            </ControlTemplate> 
         </Setter.Value> 
      </Setter> 
   </Style> 
	
</ResourceDictionary>

다음은 C # 코드입니다. MyCustomControl class 에서 상속받은 Control class 사용자 지정 컨트롤에 대해 사용자 지정 라우트 된 이벤트 Click이 생성됩니다.

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

namespace WPFCustomRoutedEvent { 

   public class MyCustomControl : Control { 
	
      static MyCustomControl() { 
         DefaultStyleKeyProperty.OverrideMetadata(typeof(MyCustomControl), 
            new FrameworkPropertyMetadata(typeof(MyCustomControl))); 
      } 
		
      public override void OnApplyTemplate() { 
         base.OnApplyTemplate();
			
         //demo purpose only, check for previous instances and remove the handler first 
         var button  =  GetTemplateChild("PART_Button") as Button; 
         if (button ! =  null) 
         button.Click + =  Button_Click;  
      } 
		
      void Button_Click(object sender, RoutedEventArgs e) { 
         RaiseClickEvent(); 
      } 
		
      public static readonly RoutedEvent ClickEvent  =  
         EventManager.RegisterRoutedEvent("Click", RoutingStrategy.Bubble, 
         typeof(RoutedEventHandler), typeof(MyCustomControl)); 
			
      public event RoutedEventHandler Click { 
         add { AddHandler(ClickEvent, value); } 
         remove { RemoveHandler(ClickEvent, value); } 
      } 
		
      protected virtual void RaiseClickEvent() { 
         RoutedEventArgs args = new RoutedEventArgs(MyCustomControl.ClickEvent); 
         RaiseEvent(args); 
      }
		
   } 
}

다음은 사용자가 클릭하면 메시지 상자를 표시하는 C #의 사용자 지정 라우트 된 이벤트 구현입니다.

using System.Windows;  

namespace WPFCustomRoutedEvent { 
   // <summary> 
      // Interaction logic for MainWindow.xaml
   // </summary> 
	
   public partial class MainWindow : Window { 
	
      public MainWindow() { 
         InitializeComponent(); 
      }  
		
      private void MyCustomControl_Click(object sender, RoutedEventArgs e) { 
         MessageBox.Show("It is the custom routed event of your custom control"); 
      } 
		
   } 
}

다음은 라우트 된 이벤트 Click으로 사용자 지정 컨트롤을 추가하는 MainWindow.xaml의 구현입니다.

<Window x:Class = "WPFCustomRoutedEvent.MainWindow" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   xmlns:local = "clr-namespace:WPFCustomRoutedEvent"
   Title = "MainWindow" Height = "350" Width = "604"> 
	
   <Grid> 
      <local:MyCustomControl Click = "MyCustomControl_Click" /> 
   </Grid> 
	
</Window>

위의 코드가 컴파일되고 실행되면 사용자 정의 컨트롤이 포함 된 다음 창이 생성됩니다.

사용자 지정 컨트롤을 클릭하면 다음 메시지가 생성됩니다.