![](/img/trans.png)
[英]WPF DataGrid TargetType=“DataGridRow” not working for Event=“MouseDoubleClick”
[英]WPF DataGrid DataGridRow override ItemsPanel breaks tab order
我正在一个WPF项目中,该项目需要一个2D网格,该网格需要在窗口内扩展和收缩。 为此,我用UniformGrids替换了DataGrid中的ItemsPanels。 当我这样做时,控件将正确展开和收缩。
不幸的是,由于某种原因,这破坏了DataGrid中的选项卡顺序。 如果按Tab键,它将下拉一行,而不是跳到下一列。 当选项卡到达行尾时,它将转到下一列的顶部并继续向下。 左,右,上,下箭头键均按预期工作,受影响的唯一功能是按Tab键顺序。 如果删除DataGridRow样式,则制表符顺序将自行更正,但行不会随窗口扩展。
这个问题似乎并没有孤立到UniformGrid上,因为StackPanel也会产生相同的选项卡症状。
有谁知道我应该怎么寻找或寻找解决此选项卡问题的方法,或者可能是使网格根据需要扩展和收缩的另一种方法?
XAML示例:
<Window x:Class="SODatagridSample.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">
<Window.Resources>
<Style TargetType="{x:Type DataGridRow}">
<Setter Property="ItemsPanel">
<Setter.Value>
<ItemsPanelTemplate>
<UniformGrid IsItemsHost="True" Rows="1" />
</ItemsPanelTemplate>
</Setter.Value>
</Setter>
</Style>
</Window.Resources>
<ScrollViewer HorizontalScrollBarVisibility="Auto" VerticalScrollBarVisibility="Auto">
<Grid>
<DataGrid x:Name="datagrid" ItemsSource="{Binding Values}" SelectionMode="Extended" SelectionUnit="Cell" ColumnWidth="*" HeadersVisibility="None"
CanUserAddRows="False" CanUserDeleteRows="False">
<DataGrid.ItemsPanel>
<ItemsPanelTemplate>
<UniformGrid Columns="1"></UniformGrid>
</ItemsPanelTemplate>
</DataGrid.ItemsPanel>
</DataGrid>
</Grid>
</ScrollViewer>
后面的示例代码:
using System.ComponentModel;
using System.Data;
using System.Windows;
namespace SODatagridSample
{
public partial class MainWindow : Window, INotifyPropertyChanged
{
public DataTable Values
{
get { return _Values; }
set
{
_Values = value;
OnPropertyChanged(nameof(Values));
}
}
private DataTable _Values;
public MainWindow()
{
Values = new DataTable();
for (int i = 0; i < 15; i++)
Values.Columns.Add(i.ToString(), typeof(double));
for (int i = 0; i < 10; i++)
Values.Rows.Add(Values.NewRow());
for (int x = 0; x < 10; x++)
for (int y = 0; y < 15; y++)
Values.Rows[x][y] = x * 15 + y;
DataContext = this;
InitializeComponent();
}
public event PropertyChangedEventHandler PropertyChanged;
public void OnPropertyChanged(string name)
{
PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(name));
}
}
}
解决方法非常简单。 反映出DataGridCellPanel之后,我注意到它具有以下静态构造函数:
static DataGridCellsPanel()
{
KeyboardNavigation.TabNavigationProperty.OverrideMetadata(typeof(DataGridCellsPanel), new FrameworkPropertyMetadata((object)KeyboardNavigationMode.Local));
}
所需要做的就是扩展UniformGrid以添加该静态构造函数,或者只是向DataGridRow样式的UniformGrid中添加附加属性KeyboardNavigation.TabNavigation =“ Local”:
<Style TargetType="{x:Type DataGridRow}">
<Setter Property="ItemsPanel">
<Setter.Value>
<ItemsPanelTemplate>
<UniformGrid KeyboardNavigation.TabNavigation="Local" IsItemsHost="True" Rows="1"/>
</ItemsPanelTemplate>
</Setter.Value>
</Setter>
</Style>
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.