gpt4 book ai didi

silverlight - 使 Silverlight Datagrid 单元格不可选择

转载 作者:行者123 更新时间:2023-12-01 09:39:45 25 4
gpt4 key购买 nike

我有一个 DataGrid,我将它绑定(bind)到一个 PagedCollectionView,它是分组和排序的。 DataGrid 的内容不可编辑,尽管其中一列包含可点击的链接。

我已将 DataGrid 的 SelectionMode 限制为 DataGridSelectionMode.Single 以停止多行选择,这很好。但是选定的行也有一个选定的单元格,它以比选定行的其余部分略浅的颜色绘制,并且有一个边框。

基本上我想要一个 SelectedRow 而不是 SelectedCell(从 UI/显示的角度来看)。

感觉设置属性应该很简单,但我觉得可能我必须编辑 DataGrids 模板和/或弄乱 VisualStateManager。

我很高兴切换到 DataGrid 以外的其他控件,但我确实需要能够显示 Grouping。

最佳答案

我发现了一种使单个单元格看起来未被选中的方法,尽管我不确定它是否是最好的方法。
编辑 DataGrid 的 CellStyle,找到名为 FocusVisual 的 Rectangle。这是用于指示选定单元格的矩形。将其 Fill & Stroke 设置为透明,我还将其 StrokeThickness 设置为 0。不要完全删除 Rectangle,因为其他东西都希望它在那里。xaml 看起来像这样:

    <Style x:Key="NonSelectableDataGridCellStyle" TargetType="data:DataGridCell">
<Setter Property="Background" Value="Transparent"/>
<Setter Property="HorizontalContentAlignment" Value="Stretch"/>
<Setter Property="VerticalContentAlignment" Value="Stretch"/>
<Setter Property="IsTabStop" Value="False"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="data:DataGridCell">
<Grid x:Name="Root" Background="{TemplateBinding Background}">
<Grid.ColumnDefinitions>
<ColumnDefinition/>
<ColumnDefinition Width="Auto"/>
</Grid.ColumnDefinitions>
<VisualStateManager.VisualStateGroups>
<VisualStateGroup x:Name="CurrentStates">
<VisualState x:Name="Regular"/>
<VisualState x:Name="Current">
<Storyboard>
<DoubleAnimation Duration="0"
Storyboard.TargetName="FocusVisual"
Storyboard.TargetProperty="Opacity" To="1"/>
</Storyboard>
</VisualState>
</VisualStateGroup>
<VisualStateGroup x:Name="ValidationStates">
<VisualState x:Name="Valid"/>
<VisualState x:Name="Invalid">
<Storyboard>
<DoubleAnimation Duration="0" Storyboard.TargetName="InvalidVisualElement" Storyboard.TargetProperty="Opacity" To="1"/>
<ColorAnimation Duration="0" Storyboard.TargetName="FocusVisual" Storyboard.TargetProperty="(Fill).Color" To="#FFFFFFFF"/>
</Storyboard>
</VisualState>
</VisualStateGroup>
</VisualStateManager.VisualStateGroups>
<Rectangle x:Name="FocusVisual"
Fill="Transparent"
Stroke="Transparent"
StrokeThickness="0"
HorizontalAlignment="Stretch"
VerticalAlignment="Stretch"
IsHitTestVisible="false"
Opacity="0"
/>
<ContentPresenter HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" Margin="{TemplateBinding Padding}" VerticalAlignment="{TemplateBinding VerticalContentAlignment}" Content="{TemplateBinding Content}" ContentTemplate="{TemplateBinding ContentTemplate}"/>
<Rectangle x:Name="InvalidVisualElement" Stroke="#FFDC000C" StrokeThickness="1" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" IsHitTestVisible="False" Opacity="0"/>
<Rectangle x:Name="RightGridLine" VerticalAlignment="Stretch" Width="1" Grid.Column="1"/>
</Grid>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>

然后将 CellStyle 添加到 DataGrid

<data:DataGrid x:Name="uiDataGrid" 
CellStyle="{StaticResource NonSelectableDataGridCellStyle}"
>
...
</data:DataGrid>

关于silverlight - 使 Silverlight Datagrid 单元格不可选择,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1647925/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com