最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-27 22:35:55
文档

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

WPF实现slide控件拖动完成后改变变量值:WPF中使slide控件拖动完成后改变变量值这个问题一开始觉得还是挺简单的,网上也看到不少解决方案。 首先一个最简单最直接的方案就是自定义一个名为FinalValue的依赖属性。随后重载OnThumbDragCompleted函数,在Thumb控件完成拖动时改写FinalValue
推荐度:
导读WPF实现slide控件拖动完成后改变变量值:WPF中使slide控件拖动完成后改变变量值这个问题一开始觉得还是挺简单的,网上也看到不少解决方案。 首先一个最简单最直接的方案就是自定义一个名为FinalValue的依赖属性。随后重载OnThumbDragCompleted函数,在Thumb控件完成拖动时改写FinalValue


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实现slide控件拖动完成后改变变量值

WPF实现slide控件拖动完成后改变变量值:WPF中使slide控件拖动完成后改变变量值这个问题一开始觉得还是挺简单的,网上也看到不少解决方案。 首先一个最简单最直接的方案就是自定义一个名为FinalValue的依赖属性。随后重载OnThumbDragCompleted函数,在Thumb控件完成拖动时改写FinalValue
推荐度:
标签: 实现 控件 拖动
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top