2

CheckBox在过去的一个小时里,我一直在寻找应该是一个简单问题的解决方案:如何在 Xceed 的社区中创建单击可编辑的绑定DataGridControl

需要明确的是:我想要一个CheckBox用户可以单击 any 的列CheckBox,而不管选择了哪一行,并相应地IsSelected更改视图模型的属性。

以下是我尝试过的最新排列。此代码从模型中读取值,但由于某种原因单击CheckBox不会调用IsSelected设置器。

<xcdg:DataGridControl x:Name="DictionariesDataGridControl" ItemsSource="{Binding Mode=OneWay, Source={StaticResource DictionariesViewSource}}" AutoCreateColumns="False" AutoRemoveColumnsAndDetailConfigurations="False" SelectionMode="Extended" NavigationBehavior="RowOnly">
    <xcdg:DataGridControl.View>
        <xcdg:TableView UseDefaultHeadersFooters="False" ShowRowSelectorPane="False" VerticalGridLineThickness="0">
            <xcdg:TableView.FixedHeaders>
                <DataTemplate>
                    <xcdg:ColumnManagerRow BorderThickness="0"/>
                </DataTemplate>
            </xcdg:TableView.FixedHeaders>
        </xcdg:TableView>
    </xcdg:DataGridControl.View>
    <xcdg:DataGridControl.Columns>
        <xcdg:Column FieldName="IsSelected" MinWidth="20" MaxWidth="20" CellEditorDisplayConditions="RowIsCurrent">
            <xcdg:Column.CellContentTemplate>
                <DataTemplate>
                    <CheckBox IsChecked="{Binding ., Mode=OneWay}" IsHitTestVisible="False"/>
                </DataTemplate>
            </xcdg:Column.CellContentTemplate>
            <xcdg:Column.CellEditor>
                <xcdg:CellEditor>
                    <xcdg:CellEditor.EditTemplate>
                        <DataTemplate>
                            <CheckBox IsChecked="{Binding ., Mode=TwoWay}"/>
                        </DataTemplate>
                    </xcdg:CellEditor.EditTemplate>
                </xcdg:CellEditor>
            </xcdg:Column.CellEditor>
        </xcdg:Column>
    </xcdg:DataGridControl.Columns>

编辑 1

我正在尝试这个,这正是我需要的:

<xcdg:Column FieldName="IsSelected" MinWidth="20" MaxWidth="20" CellEditorDisplayConditions="Always"/>

除了,由于某种原因,它CheckBox的样式是蓝色的!

蓝色背景的复选框

我在可视化树中选择了具有定义为颜色的属性Background的元素:SolidColorBrush#FF0000FF

视觉树

编辑 2

我反编译了DataGridCheckBoxXceed 用来渲染的类,CheckBox发现了这个覆盖:

public override void OnApplyTemplate()
{
  base.OnApplyTemplate();
  this.ChildCheckBox.Background = (Brush) new SolidColorBrush(Colors.Blue);
}

Xceed 任意将背景颜色设置为蓝色,这是多么奇怪的决定。

编辑 3

使用@JBrooks 的回答,我尝试了以下方法:

<xcdg:Column FieldName="IsSelected" MinWidth="20" MaxWidth="20" CellEditorDisplayConditions="Always">
    <xcdg:Column.CellEditor>
        <xcdg:CellEditor>
            <xcdg:CellEditor.EditTemplate>
                <DataTemplate>
                    <CheckBox IsChecked="{Binding ., Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"/>
                </DataTemplate>
            </xcdg:CellEditor.EditTemplate>
        </xcdg:CellEditor>
    </xcdg:Column.CellEditor>
</xcdg:Column>

不幸的是,由于某种原因,IsSelected当我选中该框时,从未调用该属性的设置器。不过,getter 被多次调用,并且CheckBoxes 在初始绑定时正确显示。

4

1 回答 1

1

您同时拥有 CellContentTemplate 和 CellEditor,因此第一次单击会执行“进入编辑模式”逻辑。只要有一个像下面这样的。这是一个普通的 WPF DataGrid,但也许你可以为你的网格尝试类似的东西。

  <DataGridTemplateColumn Header="Active" SortMemberPath="IsActive"  >
     <DataGridTemplateColumn.CellTemplate>
        <DataTemplate>
           <CheckBox IsChecked="{Binding IsActive, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" IsEnabled="{Binding IsEnabled}" Style="{StaticResource rightsCB}" />
        </DataTemplate>
    </DataGridTemplateColumn.CellTemplate>
  </DataGridTemplateColumn>

对于这个 DataGrid,我还设置了以下属性:

SelectedItem="{Binding SelectedUser, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" SelectionUnit="FullRow" SelectionMode="Single"

所以这个 DataGrid 确实像你想要的那样 - 我单击第 4 行中的复选框并且 IsChecked 更改并且它还使第 4 行成为当前行,它将 SelectedUser 设置为绑定到第 4 行的用户。

于 2016-10-04T01:26:44.613 回答