簡體   English   中英

在WPF DataGrid選擇/取消選擇(WPF,VB.NET,WinForms)中更改單元的背景色

[英]Change Backcolor of cell in WPF DataGrid Selection / Deselection (WPF, VB.NET, WinForms)

我有WPF表單,其中有一個DataGrid。 當表單加載或沒有焦點時,第一個單元格上會顯示白色的高光。 如果單擊gridview或當窗體獲得焦點時,當前單元格將變為藍色(我設置的選擇顏色)。 看圖片:

'失去重點 在此處輸入圖片說明

獲得焦點 在此處輸入圖片說明

當沒有將焦點放在數據網格上時,我想刪除白色突出顯示,即它看起來應該與該行中的其他單元格相似。 我必須處理的財產或事件是什么?

        <DockPanel Name="DocHolder" >            
           <DataGrid x:Name="dataGrid1" MaxHeight="100" AutoGenerateColumns="False" HeadersVisibility="Column" SelectionUnit="Cell" FontSize="11" 
                 VerticalContentAlignment="Center" 
                  HorizontalGridLinesBrush="#FFC7BDBD" AlternatingRowBackground="#690BB9F8"
                  EnableColumnVirtualization="False" EnableRowVirtualization="False" GridLinesVisibility="None"
                CanUserResizeColumns="False"  CanUserResizeRows="False"  CanUserReorderColumns="False" CanUserAddRows="False"  CanUserDeleteRows="False"  
                ClipboardCopyMode="ExcludeHeader" HorizontalScrollBarVisibility="Disabled"  MinRowHeight="20"  OverridesDefaultStyle="False"
                Style="{DynamicResource scGrid}" ColumnHeaderStyle="{DynamicResource scGridHeader}">

                <DataGrid.BorderBrush> <SolidColorBrush /> </DataGrid.BorderBrush>
                <DataGrid.RowBackground> <SolidColorBrush /></DataGrid.RowBackground>
                <DataGrid.Background> <SolidColorBrush /> </DataGrid.Background>
                <DataGrid.Columns>
                    <DataGridTextColumn Header="GID"  DisplayIndex="0" Visibility="Hidden"   Binding="{Binding GID}" />
                    <DataGridTextColumn Header="Region" DisplayIndex="1" IsReadOnly="True" Binding="{Binding AreaName}" CellStyle="{StaticResource CellGotFocus}" HeaderStyle="{StaticResource HeaderStyle}" />
                    <DataGridTextColumn Header="Grps"  DisplayIndex="2" IsReadOnly="True" Binding="{Binding GName}" CellStyle="{StaticResource FocusAndShowElementData}" HeaderStyle="{StaticResource HeaderStyle}" />
                    <DataGridTextColumn Header="Thk"   DisplayIndex="3" Binding="{Binding Thick}"  IsReadOnly="True" CellStyle="{StaticResource CellGotFocus}"  HeaderStyle="{StaticResource HeaderStyle}"/>
                    <DataGridTextColumn Header="TX"   DisplayIndex="4" Binding="{Binding TopX}" IsReadOnly="True" CellStyle="{StaticResource CellGotFocus}" HeaderStyle="{StaticResource HeaderStyle}"/>
                    <DataGridTextColumn Header="TY"   DisplayIndex="5" Binding="{Binding TopY}" IsReadOnly="True" CellStyle="{StaticResource CellGotFocus}" HeaderStyle="{StaticResource HeaderStyle}"/>
                    <DataGridTextColumn Header="BX"  DisplayIndex="6" Binding="{Binding BottomX}" IsReadOnly="True" CellStyle="{StaticResource CellGotFocus}"  HeaderStyle="{StaticResource HeaderStyle}"/>
                    <DataGridTextColumn Header="BY"   DisplayIndex="7" Binding="{Binding BottomY}" IsReadOnly="True" CellStyle="{StaticResource CellGotFocus}" HeaderStyle="{StaticResource HeaderStyle}"/>
                    <DataGridComboBoxColumn Header="DTX"  DisplayIndex="8" TextBinding ="{Binding BTopX, Mode=TwoWay}" x:Name="cmbBTopX" CellStyle="{StaticResource CellGotFocus}" HeaderStyle="{StaticResource HeaderStyle}" ElementStyle="{StaticResource scDGCombo}"/>
                    <DataGridTextColumn Header="STX"  DisplayIndex="9" Binding="{Binding BTopX, Mode=TwoWay}" CellStyle="{StaticResource CellGotFocus}" HeaderStyle="{StaticResource HeaderStyle}" />
                    <DataGridComboBoxColumn Header="DTY"  DisplayIndex="10" TextBinding ="{Binding BTopY, Mode=TwoWay}" x:Name="cmbBTopY" CellStyle="{StaticResource CellGotFocus}" HeaderStyle="{StaticResource HeaderStyle}" ElementStyle="{StaticResource scDGCombo}"/>
                    <DataGridTextColumn Header="STY"   DisplayIndex="11" Binding="{Binding BTopY, Mode=TwoWay}" CellStyle="{StaticResource CellGotFocus}" HeaderStyle="{StaticResource HeaderStyle}" />
                    <DataGridComboBoxColumn Header="DBX"  DisplayIndex="12" TextBinding ="{Binding BBottomX, Mode=TwoWay}"  x:Name="cmbBBottomX" CellStyle="{StaticResource CellGotFocus}" HeaderStyle="{StaticResource HeaderStyle}" ElementStyle="{StaticResource scDGCombo}"/>
                    <DataGridTextColumn Header="SBX" DisplayIndex="13" Binding="{Binding SBottomX, Mode=TwoWay}" CellStyle="{StaticResource CellGotFocus}" HeaderStyle="{StaticResource HeaderStyle}"/>
                    <DataGridComboBoxColumn Header="DBY"  DisplayIndex="14" TextBinding ="{Binding BBottomY, Mode=TwoWay}" x:Name="cmbBBottomY" CellStyle="{StaticResource CellGotFocus}" HeaderStyle="{StaticResource HeaderStyle}" ElementStyle="{StaticResource scDGCombo}"/>
                    <DataGridTextColumn Header="SBY"  DisplayIndex="15" Binding="{Binding BBottomY, Mode=TwoWay}" CellStyle="{StaticResource CellGotFocus}" HeaderStyle="{StaticResource HeaderStyle}" />
            </DataGrid.Columns>               
        </DataGrid>            
    </DockPanel>                       

您必須覆蓋datagrid單元的單元模板

<Style TargetType="{x:Type DataGridCell}">
    <Style.Triggers>
        <Trigger Property="IsSelected" Value="True">
            <Setter Property="Background" Value="Red"/>
        </Trigger>
        <Trigger Property="IsSelected" Value="False">
            <Setter Property="Background" Value="Red"/>
        </Trigger>
    </Style.Triggers>
    <Setter Property="Template">
        <Setter.Value>
            <ControlTemplate TargetType="{x:Type DataGridCell}">
                <Border Background="{TemplateBinding Background}">
                    <ContentPresenter VerticalAlignment="Center"></ContentPresenter>
                </Border>
            </ControlTemplate>
        </Setter.Value>
    </Setter>
</Style>

這只是一個示例,您可以參考,像這樣您可以執行所需的任何模板

希望這可以幫助。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM