共用方式為


HOW TO:加入路由事件的類別處理

路由事件可在路由中的任何指定節點上由類別處理常式或執行個體處理常式進行處理。 類別處理常式會先叫用,而且類別實作可用它來防止事件進行執行個體處理,或在基底類別擁有的事件上引入其他事件特定行為。 本範例將說明兩種密切相關的類別處理常式實作技術。

範例

這個範例會使用以 Canvas 面板為基礎的自訂類別。 應用程式的基本前提是,自訂類別會在子項目類別或其上的任何執行個體處理常式叫用之前,先在其子項目上引入行為,包括攔截任何滑鼠左鍵按選事件並標示為已處理。

UIElement 類別會公開虛擬方法,只要覆寫事件就能在 PreviewMouseLeftButtonDown 事件上啟用類別處理。 如果類別的階層架構有此虛擬方法,這就是實作類別處理最簡單的方式。 下列程式碼顯示衍生自 Canvas 的 "MyEditContainer" 中的 OnPreviewMouseLeftButtonDown 實作。 此實作會在引數中將事件標示為已處理,然後加入一些程式碼,以提供來源項目基本的可見變更。

    Protected Overrides Sub OnPreviewMouseRightButtonDown(ByVal e As System.Windows.Input.MouseButtonEventArgs)
        e.Handled = True 'suppress the click event and other leftmousebuttondown responders
        Dim ec As MyEditContainer = CType(e.Source, MyEditContainer)
        If ec.EditState Then
            ec.EditState = False
        Else
            ec.EditState = True
        End If
        MyBase.OnPreviewMouseRightButtonDown(e)
    End Sub
protected override void OnPreviewMouseRightButtonDown(System.Windows.Input.MouseButtonEventArgs e)
{
    e.Handled = true; //suppress the click event and other leftmousebuttondown responders
    MyEditContainer ec = (MyEditContainer)e.Source;
    if (ec.EditState)
    { ec.EditState = false; }
    else
    { ec.EditState = true; }
    base.OnPreviewMouseRightButtonDown(e);
}

如果基底類別上沒有虛擬方法,或該特定方法並非虛擬,類別處理可直接使用 EventManager 類別的公用程式方法 RegisterClassHandler 加入。 此方法只能從加入類別處理之類別的靜態初始設定中呼叫。 這個範例會加入 PreviewMouseLeftButtonDown 的另一個處理常式,這次的註冊類別是自訂類別。 相反地,當使用虛擬方法時,註冊類別其實是 UIElement 基底類別。 在基底類別和子類別個別註冊類別處理的情況下,子類別處理常式會先叫用。 在應用程式中的行為就是,首先這個處理常式會顯示其訊息方塊,然後再顯示虛擬方法的處理常式中的可見變更。

    Shared Sub New()
      EventManager.RegisterClassHandler(GetType(MyEditContainer), PreviewMouseRightButtonDownEvent, New RoutedEventHandler(AddressOf LocalOnMouseRightButtonDown))
    End Sub
    Friend Shared Sub LocalOnMouseRightButtonDown(ByVal sender As Object, ByVal e As RoutedEventArgs)
      MessageBox.Show("this is invoked before the On* class handler on UIElement")
      'e.Handled = True //uncommenting this would cause ONLY the subclass' class handler to respond
    End Sub
static MyEditContainer()
{
  EventManager.RegisterClassHandler(typeof(MyEditContainer), PreviewMouseRightButtonDownEvent, new RoutedEventHandler(LocalOnMouseRightButtonDown));
}
internal static void LocalOnMouseRightButtonDown(object sender, RoutedEventArgs e)
{
  MessageBox.Show("this is invoked before the On* class handler on UIElement");
  //e.Handled = true; //uncommenting this would cause ONLY the subclass' class handler to respond
}

請參閱

工作

HOW TO:處理路由事件

參考

EventManager

概念

將路由事件標記為已處理以及類別處理

路由事件概觀