Я использую ScrollView в своем приложении UWP.И он поддерживает сенсорную прокрутку, но не поддерживает мышь wheel scroll and drag scroll
.
После некоторых исследований я обнаружил, что, определяя событие PointerWheelChanged
, оно может работать.
Код XAML:
PointerWheelChanged="ScrollViewer_PointerWheelChanged"
Код C #:
private void ScrollViewer_PointerWheelChanged(object sender, PointerRoutedEventArgs e)
{
var scv = (ScrollViewer)sender;
scv.ScrollToHorizontalOffset(scv.HorizontalOffset - e.Delta);
e.Handled = true;
}
Но я получил сообщение об ошибке:
PointerRoutedEventArgs 'не содержит определения для «Delta», и ни один доступный метод расширения «Delta», принимающий первый аргумент типа «PointerRoutedEventArgs», не можетбыть найденным
Как это решить?Спасибо!
Я приложил все коды XAML и C # для вашей справки, любой мог проверить это в вашей VS.
Я вижу горизонтальную полосу прокрутки и перетаскиваю ее, чтобы перемещать кнопки.Я могу использовать сенсорный для перемещения кнопок.Но я не могу использовать колесо мыши или перетаскивать кнопки мышью.
<Page
x:Class="App1.MainPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:App1"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"
Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">
<Grid>
<Canvas>
<ScrollViewer
Width="400"
Height="150"
PointerWheelChanged="ScrollViewer_PointerWheelChanged"
HorizontalScrollMode="Enabled"
HorizontalScrollBarVisibility="Visible"
VerticalScrollBarVisibility="Hidden">
<StackPanel Orientation="Horizontal">
<Button Width="200">Data 1
</Button>
<Button Width="200">Data 2
</Button>
<Button Width="200">Data 3
</Button>
<Button Width="200">Data 4
</Button>
<Button Width="200">Data 5
</Button>
<Button Width="200">Data 6
</Button>
<Button Width="200">Data 7
</Button>
<Button Width="200">Data 8
</Button>
<Button Width="200">Data 9
</Button>
<Button Width="200">Data 10
</Button>
</StackPanel>
</ScrollViewer>
<Rectangle
Width="200"
Height="135"
Canvas.Left="200"
Fill="Transparent"
Stroke="Red"
StrokeThickness="2"/>
</Canvas>
</Grid>
C # код:
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.IO;
using System.Linq;
using System.Runtime.InteropServices.WindowsRuntime;
using Windows.Foundation;
using Windows.Foundation.Collections;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
using Windows.UI.Xaml.Controls.Primitives;
using Windows.UI.Xaml.Data;
using Windows.UI.Xaml.Input;
using Windows.UI.Xaml.Media;
using Windows.UI.Xaml.Navigation;
// The Blank Page item template is documented at https://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409
namespace App1
{
/// <summary>
/// An empty page that can be used on its own or navigated to within a Frame.
/// </summary>
public sealed partial class MainPage : Page
{
public MainPage()
{
this.InitializeComponent();
}
private void ScrollViewer_PointerWheelChanged(object sender, PointerRoutedEventArgs e)
{
//ScrollViewer scv = (ScrollViewer)sender;
//scv.ScrollToHorizontalOffset(scv.HorizontalOffset - e.Delta);
//e.Handled = true;
Debug.WriteLine("wheel changed................");
}
}
}