当前位置: 首页 > 编程笔记 >

WPF实现slide控件拖动完成后改变变量值

郎玮
2023-03-14
本文向大家介绍WPF实现slide控件拖动完成后改变变量值,包括了WPF实现slide控件拖动完成后改变变量值的使用技巧和注意事项,需要的朋友参考一下

WPF中使slide控件拖动完成后改变变量值这个问题一开始觉得还是挺简单的,网上也看到不少解决方案。

首先一个最简单最直接的方案就是自定义一个名为FinalValue的依赖属性。随后重载OnThumbDragCompleted函数,在Thumb控件完成拖动时改写FinalValue。代码如下

  public class SliderIgnoreDelta : Slider
  {
    public int FinalValue
    {
      get { return (int)GetValue(FinalValueProperty); }
      set { SetValue(FinalValueProperty, value); }
    }

    public static readonly DependencyProperty FinalValueProperty =
      DependencyProperty.Register(
        "FinalValue", typeof(int), typeof(SliderIgnoreDelta),
        new FrameworkPropertyMetadata(0,
          FrameworkPropertyMetadataOptions.BindsTwoWayByDefault, OnFinalValueChanged));

    private static void OnFinalValueChanged(DependencyObject sender, DependencyPropertyChangedEventArgs e)
    {
      int result;
      if (int.TryParse(e.NewValue.ToString(), out result))
      {
        if (((SliderIgnoreDelta) sender).Value != result)
        {
          ((SliderIgnoreDelta) sender).Value = result;
        }
      }
    }

    protected override void OnThumbDragCompleted(System.Windows.Controls.Primitives.DragCompletedEventArgs e)
    {
      base.OnThumbDragCompleted(e);
      FinalValue = (int)Value;
    }
  }

试着跑一下,似乎搞定了。等一下,左右键怎么不起作用了。看来还有问题。

跟了一下,发觉只需要重写OnValue这个函数就可以实现左右键的功能,但光改写这一步还不行,如果在OnValue中不停的更改FinalValue的值那和原本的Slide还有什么区别呢?所以还要同步修改OnThumbStart,设一个标志位。

最终代码如下

  public class SliderIgnoreDelta : Slider
  {
    public int FinalValue
    {
      get { return (int)GetValue(FinalValueProperty); }
      set { SetValue(FinalValueProperty, value); }
    }

    public static readonly DependencyProperty FinalValueProperty =
      DependencyProperty.Register(
        "FinalValue", typeof(int), typeof(SliderIgnoreDelta),
        new FrameworkPropertyMetadata(0,
          FrameworkPropertyMetadataOptions.BindsTwoWayByDefault, OnFinalValueChanged));

    private static void OnFinalValueChanged(DependencyObject sender, DependencyPropertyChangedEventArgs e)
    {
      int result;
      if (int.TryParse(e.NewValue.ToString(), out result))
      {
        if (((SliderIgnoreDelta) sender).Value != result)
        {
          ((SliderIgnoreDelta) sender).Value = result;
        }
      }
    }

    public bool IsDragging { get; protected set; }
    protected override void OnThumbDragCompleted(System.Windows.Controls.Primitives.DragCompletedEventArgs e)
    {
      IsDragging = false;
      base.OnThumbDragCompleted(e);
      OnValueChanged(Value, Value);
    }

    protected override void OnThumbDragStarted(System.Windows.Controls.Primitives.DragStartedEventArgs e)
    {
      IsDragging = true;
      base.OnThumbDragStarted(e);
    }

    protected override void OnValueChanged(double oldValue, double newValue)
    {
      if (!IsDragging)
      {
        base.OnValueChanged(oldValue, newValue);
        if (FinalValue != (int)Math.Round(Value, 0))
        {
          FinalValue = (int)Math.Round(Value, 0);
        }
      }
    }
  }

最后还有一点要注意,FinalValue需要反写回Value中,Thumb的位置本质上还是反映Value的值。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。

 类似资料:
  • 本文向大家介绍WPF实现控件拖动的示例代码,包括了WPF实现控件拖动的示例代码的使用技巧和注意事项,需要的朋友参考一下 实现控件拖动的基本原理是对鼠标位置的捕获,同时根据鼠标按键的按下、释放确定控件移动的幅度和时机。 简单示例: 在Grid中有一个Button,通过鼠标事件改编Button的Margin属性,从而改变Button在Grid中的相对位置。 为Button控件绑定三个事件:鼠标按下、鼠

  • 问题内容: 我有以下代码可以向服务器发出请求: 因此,我需要将返回的数据传递给一个像这样的变量: 在控制台上: 未定义 问题出在哪里,应该在完成后返回数据,但不是。 问题答案: 默认情况下,请求是异步的,因此通常会在请求完成之前返回对的调用。您可以改用回调函数。 如果绝对必要,则可以在中调用。

  • 本文向大家介绍jquery拖动改变div大小,包括了jquery拖动改变div大小的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了jquery拖动改变div大小的具体代码,供大家参考,具体内容如下 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。

  • 本文向大家介绍javascript实现鼠标拖动改变层大小的方法,包括了javascript实现鼠标拖动改变层大小的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了javascript实现鼠标拖动改变层大小的方法。分享给大家供大家参考。具体实现方法如下: 希望本文所述对大家的javascript程序设计有所帮助。

  •   - a - addr : rt_i2c_bus_device , rt_i2c_msg ai_addr : addrinfo ai_addrlen : addrinfo ai_canonname : addrinfo ai_family : addrinfo ai_flags : addrinfo ai_next : addrinfo ai_protocol : addrinfo ai_soc

  • 我正在尝试将集成测试添加到一个大型Maven项目中。以下是所需的事件顺序: 清理现有工件 解决依赖关系并生成项目 通过Surefire插件运行单元测试 Clover插件的分叉生命周期 ---使用Clover插件的仪器源 ---修改project.build。目录和project.build。Clover的最终名称 ---在新目录中构建Clover instrumented项目 ---通过Suref

  •   - y - y : rt_device_rect_info

  •   - x - x : rt_device_rect_info xfer : rt_spi_ops