3

可能重复:
是否已添加事件处理程序?

首先,我知道有许多类似的问题,但我无法让它们适应我的情况。

我希望能够找出为对象上的特定事件分配了哪个事件处理程序。因此,在树视图项上,我将为扩展事件分配一个处理程序。然后,我希望以后能够将分配的事件处理程序拉出并将其分配给另一个 treeviewitems 扩展事件,以便它们都在扩展事件上调用相同的处理程序。

这可能吗?

这就是我想要做的......

private void duplicateHandler( TreeViewItem existingItem )
{
    TreeViewItem tvi = new GX3TreeViewItem();

    tvi.AddHandler(TreeViewItem.ExpandedEvent, existingItem.ExpandedEventHandler);
}
4

2 回答 2

3
  1. 创建一个新的 WPF 应用程序
  2. 在主窗口中放置一个名为“tree1”的树视图
  3. 复制粘贴下面的代码以查看它的运行情况

基本上,您需要继承TreeViewItem并构建一种机制来跟踪哪些处理程序被添加到哪个节点:event不幸的是,没有关于已注册处理程序的信息供您检索。

您还需要完全依赖新的继承来构建节点,以使事情正常工作。这意味着,您不能再引用TreeViewItem,而必须引用TreeNode(这是我为自定义类选择的名称,请随意更改)。

承诺的代码如下,它所做的是将“rootNode”节点添加到树中,在扩展时将创建一个兄弟节点,该节点会将相同的处理程序带到自身(因此它也会在扩展时创建一个兄弟节点,并且很快)。

namespace WpfApplication1
{
    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();

            TreeNode root = new TreeNode();
            root.Header = "root";

            tree1.Items.Clear();

            // add node to tree before adding handlers, or you'll get
            // a StackOverflowException
            tree1.Items.Add(root);

            root.AddHandler(TreeNode.ExpandedEvent, new RoutedEventHandler(expandedHandler));

        }

        private void expandedHandler(object sender, RoutedEventArgs e) { newNodeCopyExpandedHandlers(sender as TreeNode); }

        private void newNodeCopyExpandedHandlers(TreeNode node)
        {
            TreeNode newNode = new TreeNode();
            newNode.Header = "nuovo!";

            // add node to tree before adding handlers, or you'll get
            // a StackOverflowException
            tree1.Items.Add(newNode);

            foreach (Delegate d in newNode.GetHandlers(node, TreeNode.ExpandedEvent))
                newNode.AddHandler(TreeNode.ExpandedEvent, d);
        }
    }

    public class TreeNode : TreeViewItem
    {
        private Dictionary<RoutedEvent, List<Delegate>> handlersList = new Dictionary<RoutedEvent, List<Delegate>>();

        public new void AddHandler(RoutedEvent e, Delegate d)
        {
            if (!handlersList.ContainsKey(e)) handlersList.Add(e, new List<Delegate>());
            handlersList[e].Add(d);

            base.AddHandler(e, d);
        }
        public new void RemoveHandler(RoutedEvent e, Delegate d)
        {
            if (!handlersList.ContainsKey(e)) handlersList.Add(e, new List<Delegate>());
            if (handlersList[e].Contains(d)) handlersList[e].Remove(d);

            base.RemoveHandler(e, d);
        }

        public List<Delegate> GetHandlers(TreeNode n, RoutedEvent e)
        {
            if (n.handlersList.ContainsKey(e)) return n.handlersList[e];
            else return null;
        }
    }
}
于 2012-12-11T10:29:59.683 回答
-1

是的,当然可以,您可以浏览代码,直到找到事件分配:

event +=  myEventHandler

然后,您可以使用相同的方法myEventHandler订阅其他树上的事件。这是问题还是我误解了这个问题?

于 2012-12-11T09:34:53.620 回答