WPF冒泡事件和隧道事件

 

冒泡事件: MouseMove, 触发控件事件的顺序:从上层到底层

隧道事件: PreviewMouseMove,触发控件事件的顺序:从底层到上层

 

冒泡事件: MouseMove

<Border x:Name="greenBorder" Background="Green" Width="300" HorizontalAlignment="Right" MouseMove="greenBorder_MouseMove">
      <Border x:Name="redBorder" Background="Red" Width="120" Height="120" MouseMove="redBorder_MouseMove"></Border>
</Border>

后台代码:

        private void LowerBorder_MouseMove(object sender, MouseEventArgs e)
        {
            if (e.LeftButton == MouseButtonState.Pressed)
            {
                text1.Text += "Lower Border x:" + e.GetPosition(this).X + "     y:" + e.GetPosition(this).Y + "\r\n";
            }
        }

        private void TopBorder_MouseMove(object sender, MouseEventArgs e)
        {
            if (e.LeftButton == MouseButtonState.Pressed)
            {
                text1.Text += "Top Border x:" + e.GetPosition(this).X + "     y:" + e.GetPosition(this).Y + "\r\n";

                //设置Handled=true, 阻止执行LowerBorder_MouseMove事件
                e.Handled = true;
            }
        }
View Code

 

 

隧道事件:PreviewMouseMove

<Border x:Name="LowerBorder" Background="Green" Width="300" HorizontalAlignment="Right" PreviewMouseMove="LowerBorder_PreviewMouseMove">
      <Border x:Name="TopBorder" Background="Red" Width="120" Height="120" PreviewMouseMove="TopBorder_PreviewMouseMove"></Border>
</Border>

//先执行LowerBorder事件
        private void LowerBorder_PreviewMouseMove(object sender, MouseEventArgs e)
        {
            if (e.LeftButton == MouseButtonState.Pressed)
            {
                text1.Text += "Lower Border x:" + e.GetPosition(this).X + "     y:" + e.GetPosition(this).Y + "\r\n";
            }
        }

        //后执行TopBorder事件
        private void TopBorder_PreviewMouseMove(object sender, MouseEventArgs e)
        {
            if (e.LeftButton == MouseButtonState.Pressed)
            {
                text1.Text += "Top Border x:" + e.GetPosition(this).X + "     y:" + e.GetPosition(this).Y + "\r\n";
            }
        }
View Code

 

转载于:https://www.cnblogs.com/wangbc/p/4121594.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值