1

私はWPFデータグリッドを持っています。データグリッドは、Orders というカスタム タイプのリストにバインドされます。現在、データグリッドのすべての行にトグル ボタンがあります。

Orders のプロパティ MultiID (boolean) が true であるが、これを機能させることができない場合にのみ、行ヘッダーにトグル ボタンを配置したい。

私の DataGridRow では、下の行のコメントアウトされたセクションを使用してみましたが、すべての行にトグル ボタンがあるため、違いはないようです。

<Style.Triggers>
            <Trigger Property="IsMouseOver" Value="True">
                <Setter Property="Foreground" Value="Blue"/>
            </Trigger>
            <!--<DataTrigger Binding="{Binding MultiID}" Value="True">
                <Setter Property="HeaderTemplate" Value="{StaticResource rowdetailToggleButton}"/>
            </DataTrigger>-->
        </Style.Triggers>

私のデータグリッド

<!-- The data grid to display orders-->
        <DataGrid DataContext="{Binding OrderBlock}" 
                  x:Name="dataGridOrders" 
                  ItemsSource="{Binding Orders}"

                  RowStyle="{StaticResource DG_Row}"

                  RowDetailsTemplate="{StaticResource DG_RowDetail}" 
                  RowHeaderStyle="{StaticResource DG_RowHeader}"
                                        RowDetailsVisibilityChanged="dataGridOrders_RowDetailsVisibilityChanged">
                <DataGrid.RowHeaderTemplate>                    
                <DataTemplate>
                    <ToggleButton x:Name="RowHeaderToggleButton"                                                                           
                                  Click="RowHeaderToggleButton_Click"
                                  Cursor="Hand"/>
   <DataTemplate.Triggers>
                            <DataTrigger Binding="{Binding Orders.MultiID}" Value="False">
                                <Setter TargetName="RowHeaderToggleButton" Property="Visibility" Value="Collapsed"/>
                            </DataTrigger>
                        </DataTemplate.Triggers>
                    </DataTemplate>
                 </DataGrid.RowHeaderTemplate>

私のDataGridRowHeader

<!-- Data Grid row with toggle button -->
    <Style x:Key="DG_RowHeader" TargetType="{x:Type DataGridRowHeader}">
        <Setter Property="Width" Value="35"/>
        <Setter Property="Template">
            <Setter.Value>
                <ControlTemplate TargetType="{x:Type DataGridRowHeader}">
                    <Border x:Name="DGRH_Border"
                                BorderBrush="{TemplateBinding BorderBrush}"
                                BorderThickness="{TemplateBinding BorderThickness}"
                                SnapsToDevicePixels="True">
                        <Border.Background>
                            <LinearGradientBrush StartPoint="0,0" EndPoint="1,1">
                                <GradientStop Offset="0" Color="LightGray"/>
                                <GradientStop Offset="1" Color="WhiteSmoke"/>
                            </LinearGradientBrush>
                        </Border.Background>
                        <ContentPresenter Content="{TemplateBinding Content}"
                                          ContentTemplate="{TemplateBinding ContentTemplate}"/>                            
                    </Border>                        
                </ControlTemplate>
                                </Setter.Value>
        </Setter>
    </Style>

私のDataGridRow

 <!-- Data grid formatting Grid Row template -->
    <Style x:Key="DG_Row" TargetType="{x:Type DataGridRow}">
        <Setter Property="Opacity" Value="1"/>
        <Setter Property="Padding" Value="3,2,2,3"/>            
        <Setter Property="Template">
            <Setter.Value>
                <ControlTemplate TargetType="{x:Type DataGridRow}">
                    <Border x:Name="DGR_Border"
                            BorderBrush="{TemplateBinding BorderBrush}"
                            BorderThickness="{TemplateBinding BorderThickness}"
                            SnapsToDevicePixels="True">
                        <Border.Background>
                            <LinearGradientBrush StartPoint="0.5,0" EndPoint="0.5,1">
                                <GradientStop Offset="0" Color="Transparent"/>
                                <GradientStop Offset="1" Color="Silver"/>
                            </LinearGradientBrush>
                        </Border.Background>
                    </Border>
                    <ControlTemplate.Triggers>
                        <DataTrigger Binding="{Binding StatusGood}" Value="Send">
                            <Setter TargetName="DGR_Border" Property="Background" Value="{StaticResource brushRowSend}"/>
                        </DataTrigger>
                    </ControlTemplate.Triggers>
                </ControlTemplate>
            </Setter.Value>
        </Setter>
        <Style.Triggers>
            <Trigger Property="IsMouseOver" Value="True">
                <Setter Property="Foreground" Value="Blue"/>
            </Trigger>
            <!--<DataTrigger Binding="{Binding MultiID}" Value="True">
                <Setter Property="HeaderTemplate" Value="{StaticResource rowdetailToggleButton}"/>
            </DataTrigger>-->
        </Style.Triggers>
    </Style>
4

2 に答える 2

0

RowHeaderTemplate 用に定義した DataTemplate に DataTrigger を配置できます

      <DataTemplate.Triggers>
            <DataTrigger Binding="{Binding DataContext.MultiID,RelativeSource={RelativeSource Mode=FindAncestor, AncestorType={x:Type DataGridRow}}" Value="false">
                <Setter TargetName="RowHeaderToggleButton" Property="Visibility" Value="Collapsed"/>
             </DataTrigger>
       </DataTemplate.Triggers>
于 2013-09-30T14:57:41.980 に答える