WPF 单击双击互斥事件

这篇博客介绍了如何在WPF应用中通过XAML和C#代码实现按钮的单击加0.1/减0.1以及双击加1/减1的功能。通过为按钮绑定MouseLeftButtonDown事件,并使用计时器判断单击和双击,实现了数值的精确变化。此外,展示了相关的UI布局和事件处理代码。
摘要由CSDN通过智能技术生成

前言

在这里插入图片描述

近日有个需求,单击加0.1(减0.1),双击加1,(减1)

实现

1、xaml部分

<Grid>
	<Grid.ColumnDefinitions>
    	<ColumnDefinition/>
      	<ColumnDefinition/>
   	</Grid.ColumnDefinitions>
    <DockPanel Grid.Column="0" HorizontalAlignment="Center">
        <hc:NumericUpDown x:Name="numer" Height="300" FontSize="50" DecimalPlaces="1" />
    </DockPanel>
   	<StackPanel Grid.Column="1" Margin="20" HorizontalAlignment="Center" Orientation="Vertical">
        <Button x:Name="plus_btn"  Style="{StaticResource GlassButton}"  Width="150" Height="150" Background="#1afa29"  Margin="2">
        	<Image Width="50" Height="50" Source="/img/plus.png"/>
        </Button>
        <Button x:Name="minus_btn"  Style="{StaticResource GlassButton}" Width="150" Height="150" Background="#d81e06"  Margin="2">
        	<Image Width="50" Height="50" Source="/img/minus.png"/>
       </Button>
    </StackPanel>
</Grid>

2、cs代码

按键事件绑定

 plus_btn.AddHandler(Button.MouseLeftButtonDownEvent, 
                new MouseButtonEventHandler(Grid_MouseLeftButtonDown),true);
minus_btn.AddHandler(Button.PreviewMouseLeftButtonDownEvent,
                new MouseButtonEventHandler(Grid_MouseLeftButtonDown),true);

事件

        int i = 0;
        bool 有双击 = false;
        private void Grid_MouseLeftButtonDown(object sender, MouseButtonEventArgs e)   //MouseLeftButtonDown事件
        {
            i += 1;
            DispatcherTimer timer = new DispatcherTimer();
            timer.Interval = new TimeSpan(0, 0, 0, 0, 200);
            timer.Tick += (s, e1) => { timer.IsEnabled = false; i = 0; 单击(((Button)sender).Name); 有双击 = false; };
            timer.IsEnabled = true;
            if (i % 2 == 0)
            {
                timer.IsEnabled = false;
                i = 0;
                有双击 = true;
                //判断点击的是哪个按键    
                if (((Button)sender).Name.Equals("plus_btn"))
                {

                    numer.Value ++;
                }
                else {
                     numer.Value--;
                }
               
                //双击时执行的代码
                //MessageBox.Show("DoubleClick!");
            }
        }
        private void 单击(string name)
        {
            if (!有双击)
            {
                double d = numer.Value;
               
                //单击时执行的代码
                if (name.Equals("plus_btn"))
                {

                    numer.Value = d + 0.1;
                }
                else
                {
                    numer.Value = d - 0.1;
                }
            }
     	}    
        

结语

​ 如果您发现文章中有哪些问题,请联系我并指导我改正,或者您有更好的写法,麻烦您指点一二,本人万分感谢,

WPF中,可以通过使用命令和交互行为来实现DataGrid的双击事件。首先,在XAML文件中导入命名空间`xmlns:i="http://schemas.microsoft.com/expression/2010/interactivity"`。然后,在DataGrid下面添加以下代码: ```xml <DataGrid ItemsSource="{Binding DeviceInfos}"> <i:Interaction.Triggers> <i:EventTrigger EventName="MouseDoubleClick"> <i:InvokeCommandAction Command="{Binding Path=DoubleClickItem}" CommandParameter="{Binding ElementName=da1,Path=SelectedItem}"/> </i:EventTrigger> </i:Interaction.Triggers> </DataGrid> ``` 这段代码将DataGrid的`MouseDoubleClick`事件与一个命令`DoubleClickItem`绑定起来。当双击DataGrid中的某一项时,命令将被执行,并将选中的项作为参数传递给命令。这样就实现了DataGrid的双击事件。\[2\]\[3\] #### 引用[.reference_title] - *1* [wpf datagrid 行双击事件](https://blog.csdn.net/dieruowan6112/article/details/101202876)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [WPF datagrid双击事件获取双击的对象或值MVVM](https://blog.csdn.net/weixin_38083655/article/details/109187564)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值