首页 > 解决方案 > WPF如何在按下Shift键时更慢地移动滑块拇指

问题描述

我有一个滑块,当我按下 Shift 键并拖动拇指时,我希望在单击滑块轨道上的任何位置时拇指移动到准确的位置,并且移动得更慢。我知道如何检测何时按下 shift 键,但我不知道如何减慢拇指的速度。任何帮助,将不胜感激!

这是xaml代码:

<Grid>
    <Slider x:Name="m_Slider" IsMoveToPointEnabled="True" Orientation="Vertical" 
            Height="200" Width="30" Minimum="0" Maximum="20" HorizontalAlignment="Center" 
            Thumb.DragStarted="Slider_ShiftDrag"/>
</Grid>

这是代码隐藏:

void Slider_ShiftDrag(object sender, DragStartedEventArgs e)
{
    if (e != null && (Keyboard.IsKeyDown(Key.LeftShift) || Keyboard.IsKeyDown(Key.RightShift)))
    {
        //What should I do here?
    }
}

标签: c#wpfxaml

解决方案


预览

我写了一个假滑块来实现你的目标。我不使用本机Thumb,因为本机捕获鼠标并始终跟随鼠标。所以我写了一个Rectangle而不是Thumb做拖动。

这是 XAML:

<Grid Width="400" Height="32">
    <Rectangle x:Name="Tracker" Height="2" Fill="Gray" />
    <Rectangle x:Name="Thumb" Width="8" Height="32" Margin="-4 -16" Fill="DarkGray" HorizontalAlignment="Left" VerticalAlignment="Center"
               MouseDown="Thumb_MouseDown" MouseMove="Thumb_MouseMove" MouseUp="Thumb_MouseUp" LostMouseCapture="Thumb_LostMouseCapture">
        <UIElement.RenderTransform>
            <TranslateTransform x:Name="ThumbTranslation" />
        </UIElement.RenderTransform>
    </Rectangle>
</Grid>

这是代码隐藏:

private Point? _lastPoint;

private void Thumb_MouseDown(object sender, MouseButtonEventArgs e)
{
    _lastPoint = e.GetPosition(Tracker);
    Thumb.CaptureMouse();
}

private void Thumb_MouseMove(object sender, MouseEventArgs e)
{
    if (_lastPoint != null)
    {
        var currentPoint = e.GetPosition(Tracker);
        var offset = currentPoint - _lastPoint.Value;
        _lastPoint = currentPoint;
        if (Keyboard.Modifiers.HasFlag(ModifierKeys.Shift))
        {
            offset *= 0.2;
        }
        SetThumbTranslation(offset.X);
    }
}

private void Thumb_MouseUp(object sender, MouseButtonEventArgs e)
{
    _lastPoint = null;
    Thumb.ReleaseMouseCapture();
}

private void Thumb_LostMouseCapture(object sender, MouseEventArgs e)
{
    _lastPoint = null;
}

private void SetThumbTranslation(double offsetX)
{
    var x = ThumbTranslation.X + offsetX;
    x = Math.Max(x, 0);
    x = Math.Min(x, Tracker.ActualWidth);
    ThumbTranslation.X = x;
}

推荐阅读