[英]WPF - Handling custom attached events on custom controls
我有一個聲明的路由事件(名稱已被更改以保護無辜者):
public class DragHelper : DependencyObject {
public static readonly RoutedEvent DragCompleteEvent = EventManager.RegisterRoutedEvent(
"DragComplete",
RoutingStrategy.Bubble,
typeof(DragRoutedEventHandler),
typeof(DragHelper)
);
public static void AddDragCompleteHandler( DependencyObject dependencyObject, DragRoutedEventHandler handler ) {
UIElement element = dependencyObject as UIElement;
if (element != null) {
element.AddHandler(DragCompleteEvent, handler);
}
}
public static void RemoveDragCompleteHandler( DependencyObject dependencyObject, DragRoutedEventHandler handler ) {
UIElement element = dependencyObject as UIElement;
if (element != null) {
element.RemoveHandler(DragCompleteEvent, handler);
}
}
很標准的東西。 在XAML中,我有一個包含單個自定義控件的DataTemplate。 我試圖將此事件(以及一些其他附加屬性)附加到控件:
<DataTemplate ...>
<My:CustomControl
My:DragHelper.IsDragSource="True"
My:DragHelper.DragComplete="DragCompleteHandler" />
</DataTemplate>
這無法產生預期的結果。 具體來說,雖然調用了為DragComplete事件調用RaiseEvent()的代碼,但從不調用該處理程序。 事實上,它也不是連接到此XAML文件中其他位置的任何其他自定義路由事件的處理程序。
我嘗試更改路由事件的名稱,並嘗試將數據模板從具有DataType的模板轉換為具有x:Key的模板。 這沒有產生明顯的行為變化。
但是,如果我將My:CustomControl更改為任何內置的WPF控件(例如TextBlock),事件將完全按照我要求的方式觸發。 類似地,如果我將自定義控件替換為我的項目中的任何其他自定義UserControl子類,則行為將恢復為已損壞的無事件似乎處於獲取狀態。
這對我來說並不是很有意義。 為了讓這個場景有效,我需要做些什么嗎? 看起來應該沒關系。 我想有可能在我的所有自定義控件中都有一個特定的事情會導致事件處理中斷,但我在目前為止嘗試的三個或四個自定義控件中沒有看到任何常見的東西。
你沒有發布所有代碼,所以我不得不推斷並整理我自己的版本。 它適用於我。 也許比較和對比你的代碼:
Window1.xaml.cs :
using System.Windows;
using System.Windows.Controls;
namespace WpfApplication1
{
public partial class Window1 : Window
{
public Window1()
{
InitializeComponent();
}
private void DragCompleteHandler(object sender, RoutedEventArgs e)
{
MessageBox.Show("YEP");
}
}
public class CustomControl : TextBox
{
}
public class DragHelper : DependencyObject
{
public static readonly DependencyProperty IsDragSourceProperty = DependencyProperty.RegisterAttached("IsDragSource",
typeof(bool),
typeof(DragHelper),
new FrameworkPropertyMetadata(OnIsDragSourceChanged));
public static bool GetIsDragSource(DependencyObject depO)
{
return (bool)depO.GetValue(IsDragSourceProperty);
}
public static void SetIsDragSource(DependencyObject depO, bool ids)
{
depO.SetValue(IsDragSourceProperty, ids);
}
public static readonly RoutedEvent DragCompleteEvent = EventManager.RegisterRoutedEvent(
"DragComplete",
RoutingStrategy.Bubble,
typeof(RoutedEventHandler),
typeof(DragHelper)
);
public static void AddDragCompleteHandler(DependencyObject dependencyObject, RoutedEventHandler handler)
{
UIElement element = dependencyObject as UIElement;
if (element != null)
{
element.AddHandler(DragCompleteEvent, handler);
}
}
public static void RemoveDragCompleteHandler(DependencyObject dependencyObject, RoutedEventHandler handler)
{
UIElement element = dependencyObject as UIElement;
if (element != null)
{
element.RemoveHandler(DragCompleteEvent, handler);
}
}
private static void OnIsDragSourceChanged(DependencyObject depO, DependencyPropertyChangedEventArgs e)
{
(depO as TextBox).TextChanged += delegate
{
(depO as TextBox).RaiseEvent(new RoutedEventArgs(DragCompleteEvent, null));
};
}
}
}
Window1.xaml :
<Window x:Class="WpfApplication1.Window1"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="clr-namespace:WpfApplication1"
Title="Window1" Height="300" Width="300">
<Window.Resources>
<DataTemplate x:Key="Test">
<local:CustomControl
local:DragHelper.IsDragSource="True"
local:DragHelper.DragComplete="DragCompleteHandler" />
</DataTemplate>
</Window.Resources>
<ContentControl ContentTemplate="{StaticResource Test}"/>
</Window>
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.