关闭了RecognizesAccessKey的WPF DataGrid

时间:2013-08-14 09:12:49

标签: c# wpf xaml wpfdatagrid

我有一个非常基本的WPF应用程序,它附带一个MS SQL服务器作为数据源。我的datagrid声明如下:

<DataGrid HorizontalAlignment="Left" Margin="10,88,0,0" VerticalAlignment="Top" Height="456" Width="1018" ItemsSource="{Binding}" />

当我运行应用程序时,我看到数据从数据库加载到网格中,但列标题看起来很奇怪。最初包含下划线的每个标题都删除了此下划线:some_title转为sometitle

我发现这是因为下划线被识别为控制符号,可以将下一个符号转换为助记符。

如何禁用此行为?

我发现,如果您将单个下划线加倍,即some__title而不是some_title,则可以绕过此行为。但由于我的数据源是外部数据库,所以我不能影响它。或者可能使用转换器?

我认为最好的方法是将属性RecognizesAccessKey转换为false,但遗憾的是它无法以某种方式访问​​。

我是WPF的新手,谢谢你的帮助!

P.S。她是Snoop的照片(如果有帮助的话) DataGrid snooped

编辑我的目标框架是.net 4.5

4 个答案:

答案 0 :(得分:5)

即使这是一个老问题,我也解决了这个问题。这可能对某人有帮助。

9223372036854775808

答案 1 :(得分:3)

我能想出的最佳解决方案是拦截DataGrid事件AutoGeneratingColumn并用两个下划线替换所有下划线,如下所示:

private void DataGrid_AutoGeneratingColumn_1(object sender, DataGridAutoGeneratingColumnEventArgs e)
{
    string header = e.Column.Header.ToString();

    // Replace all underscores with two underscores, to prevent AccessKey handling
    e.Column.Header = header.Replace("_", "__");
}

根据我的理解,(遗憾的是)如果不重新定义整个控件模板,则无法覆盖基础RecognizesAccessKey的{​​{1}}的值。 在msdn论坛上查看此主题:How to set RecognizesAccessKey on labels without influencing other parameters?

答案 2 :(得分:1)

您可以使用自定义列,当您使用自定义列时,您可以根据需要定义列标题。

答案 3 :(得分:0)

要添加到接受的答案,如果要保持datagrid的原始样式,请执行以下操作,并将ContentPresenter的RecognizeAccessKey更改为False。

enter image description here

<Style TargetType="{x:Type DataGridColumnHeader}">
        <Setter Property="VerticalContentAlignment" Value="Center"/>
        <Setter Property="Template">
            <Setter.Value>
                <ControlTemplate TargetType="{x:Type DataGridColumnHeader}">
                    <Grid>
                        <Themes:DataGridHeaderBorder BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Background="{TemplateBinding Background}" IsClickable="{TemplateBinding CanUserSort}" IsPressed="{TemplateBinding IsPressed}" IsHovered="{TemplateBinding IsMouseOver}" Padding="{TemplateBinding Padding}" SortDirection="{TemplateBinding SortDirection}" SeparatorBrush="{TemplateBinding SeparatorBrush}" SeparatorVisibility="{TemplateBinding SeparatorVisibility}">
                            <ContentPresenter ContentTemplate="{TemplateBinding ContentTemplate}" Content="{TemplateBinding Content}" ContentStringFormat="{TemplateBinding ContentStringFormat}" HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" RecognizesAccessKey="False" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" VerticalAlignment="{TemplateBinding VerticalContentAlignment}"/>
                        </Themes:DataGridHeaderBorder>
                        <Thumb x:Name="PART_LeftHeaderGripper" HorizontalAlignment="Left">
                            <Thumb.Style>
                                <Style TargetType="{x:Type Thumb}">
                                    <Setter Property="Width" Value="8"/>
                                    <Setter Property="Background" Value="Transparent"/>
                                    <Setter Property="Cursor" Value="SizeWE"/>
                                    <Setter Property="Template">
                                        <Setter.Value>
                                            <ControlTemplate TargetType="{x:Type Thumb}">
                                                <Border Background="{TemplateBinding Background}" Padding="{TemplateBinding Padding}"/>
                                            </ControlTemplate>
                                        </Setter.Value>
                                    </Setter>
                                </Style>
                            </Thumb.Style>
                        </Thumb>
                        <Thumb x:Name="PART_RightHeaderGripper" HorizontalAlignment="Right">
                            <Thumb.Style>
                                <Style TargetType="{x:Type Thumb}">
                                    <Setter Property="Width" Value="8"/>
                                    <Setter Property="Background" Value="Transparent"/>
                                    <Setter Property="Cursor" Value="SizeWE"/>
                                    <Setter Property="Template">
                                        <Setter.Value>
                                            <ControlTemplate TargetType="{x:Type Thumb}">
                                                <Border Background="{TemplateBinding Background}" Padding="{TemplateBinding Padding}"/>
                                            </ControlTemplate>
                                        </Setter.Value>
                                    </Setter>
                                </Style>
                            </Thumb.Style>
                        </Thumb>
                    </Grid>
                </ControlTemplate>
            </Setter.Value>
        </Setter>
    </Style>