C# 带有嵌套ScrollViewer的ScrollIntoView
在我的应用程序中,我将画布包装在ScrollViewer中(画布比屏幕大)。在这个画布上,我放置了其他控件。画布上的一个元素包含一个虚拟化的DataGrid(有2000多行……因此还涉及到滚动)。现在我有了一个函数,它根据row元素的一些值(自动触发)在DataGrid中选择一行。选中该行后,我调用C# 带有嵌套ScrollViewer的ScrollIntoView,c#,wpf,datagrid,scroll,ui-virtualization,C#,Wpf,Datagrid,Scroll,Ui Virtualization,在我的应用程序中,我将画布包装在ScrollViewer中(画布比屏幕大)。在这个画布上,我放置了其他控件。画布上的一个元素包含一个虚拟化的DataGrid(有2000多行……因此还涉及到滚动)。现在我有了一个函数,它根据row元素的一些值(自动触发)在DataGrid中选择一行。选中该行后,我调用 uxDataGrid.ScrollIntoView(uxDataGrid.SelectedItems[0]); 什么是完美的工作。事实上,这是一条通往好的道路。我想要的是,选择DataGrid中的
uxDataGrid.ScrollIntoView(uxDataGrid.SelectedItems[0]);
什么是完美的工作。事实上,这是一条通往好的道路。我想要的是,选择DataGrid中的元素,然后DataGrid应该滚动到正确的位置。但我的Canvas scrolviewer也不知怎么地接受了这个请求,并在那里滚动
我已经尝试拦截ScrollChangedEvent并设置handled标志。但它不起作用
问题:
1) 如何将ScrollIntoView调用的效果限制到本地用户控件
2) 如果这是不可能的,我怎么能做自己的滚动?我需要计算scrollviewer的垂直偏移,但由于它是虚拟的,我不知道如何计算行高
有什么建议吗
我添加了一个快速示例来演示主要设置。当按下其中一个按钮时,我只希望DataGrid滚动,而不是滚动画布上的ScrollViewer
<Window x:Class="ScrollTest.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="MainWindow" Height="350" Width="525">
<DockPanel>
<StackPanel DockPanel.Dock="Bottom" Orientation="Horizontal">
<Button Click="Button1_Click">Scroll to 1</Button>
<Button Click="Button100_Click">Scroll to 100</Button>
<Button Click="Button200_Click">Scroll to 200</Button>
</StackPanel>
<ScrollViewer>
<Canvas Width="5000" Height="5000">
<DataGrid Name="uxDataGrid" ItemsSource="{Binding TestItems}" Width="500" Height="500"></DataGrid>
</Canvas>
</ScrollViewer>
</DockPanel>
滚动到1
滚动到100
滚动到200
公共类测试项
{
公共测试项目(int id)
{
Property1=id.ToString();
属性2=“B”;
}
公共字符串属性1{get;set;}
公共字符串属性2{get;set;}
}
///
///Interaktionslogik für MainWindow.xaml
///
公共部分类主窗口:窗口
{
公共IList测试项{get;set;}
公共主窗口()
{
TestItems=新列表();
对于(int i=0;i<300;i++)
{
增加(新的测试项目(i));
}
初始化组件();
DataContext=this;
}
私有无效按钮1\u单击(对象发送者,路由目标)
{
ScrollIntoView(TestItems[0]);
}
私有无效按钮100_单击(对象发送者,路由目标)
{
ScrollIntoView(TestItems[99]);
}
私有无效按钮200_单击(对象发送者,路由目标)
{
ScrollIntoView(TestItems[199]);
}
}
好的……经过一些研究,我找到了正确的事件:它被称为RequestBringIntoViewEvent
。截取该文件时,它将按预期工作:
public partial class MainWindow : Window
{
public MainWindow()
{
...
uxDataGrid.AddHandler( RequestBringIntoViewEvent, new RoutedEventHandler( HandleRequestBringIntoViewEvent ) );
}
private static void HandleRequestBringIntoViewEvent( object sender, RoutedEventArgs e )
{
e.Handled = true;
}
...
}
还没有。。。我得等两天
public partial class MainWindow : Window
{
public MainWindow()
{
...
uxDataGrid.AddHandler( RequestBringIntoViewEvent, new RoutedEventHandler( HandleRequestBringIntoViewEvent ) );
}
private static void HandleRequestBringIntoViewEvent( object sender, RoutedEventArgs e )
{
e.Handled = true;
}
...
}