0

我有一个带有样式模板的 DevExpress GridControl,它有一个转换器,提供单元格的背景画笔属性,但它不能正常工作。

在我的 GridControl 中,我想显示客户是否参加了研讨会,因此我为客户提供了一个专栏,并且根据所选月份,28 到 31 列带有 checkits,如果有研讨会,转换器将返回蓝色画笔如果没有研讨会,则在该日期或白色刷子。

选择月份后,GridControl 的源将更新,并且仅包含希望在该特定月份参加研讨会的客户,但是当我在 convert 方法中开始调试时,我看到它还会检查不应再出现在源集合中的客户而且我绝对确定在更新源集合后会调用转换方法,因为我通过为每一列提供一个新标题然后重置标题来触发转换方法。

奇怪的是,这有时有效,但并非每次都有效。

<dxg:GridControl x:Name="seminarGrid" ItemsSource="{Binding CustomerList}">
    <dxg:GridControl.Resources>
        <Style x:Key="customCellStyle" 
               BasedOn="{StaticResource {dxgt:GridRowThemeKey ResourceKey=CellStyle}}"
               TargetType="grid:CellContentPresenter">
            <Setter Property="Background">
                <Setter.Value>
                    <MultiBinding Converter="{converter:CellColorConverter}">
                        <Binding />
                        <Binding Path="Column.Header" />
                    </MultiBinding>
                </Setter.Value>
            </Setter>
        </Style>
     </dxg:GridControl.Resources>
     <dxg:GridControl.Columns>
         <dxg:GridColumn FieldName="Customer" Header="Customer" AllowEditing="False"/>
         <dxg:GridColumn x:Name="d0" FieldName="d0" Header="1." Width="27" 
                         CellStyle="{StaticResource customCellStyle}" 
                         EditSettings="{dxe:CheckSettings}"/>
         <dxg:GridColumn x:Name="d1" FieldName="d1" Header="2." Width="27" 
                         CellStyle="{StaticResource customCellStyle}" 
                         EditSettings="{dxe:CheckSettings}"/>
         [...]
         <dxg:GridColumn x:Name="d30" FieldName="d30" Header="2." Width="27" 
                         CellStyle="{StaticResource customCellStyle}" 
                         EditSettings="{dxe:CheckSettings}"/>
    </dxg:GridControl.Columns>
</dxg:GridControl>

转换方法:

public object Convert(object[] value, Type targetType, object parameter, CultureInfo culture)
    {
        if (value[1].ToString().Equals(string.Empty))
            return Brushes.White;

        var cellData = value[0] as EditGridCellData;
        var customer = cellData.RowData.Row as Customer;

        if (customer == null)
            return Brushes.White;

        var date = int.Parse(value[1].ToString().Split('.')[0], NumberStyles.Integer);
        var result = Brushes.BlueViolet;
        var viewTag = cellData.View.Tag is int
                          ? int.Parse(cellData.View.Tag.ToString(), NumberStyles.Integer)
                          : 0;
        var elements = customer.BookingRelation.Where(p => p.Value.Datum.Day == date && p.Value.Datum.Month == viewTag);


        if (elements.Count() == 1)
            result = Brushes.CornflowerBlue;


        return customer.BookingRelation.Any(item => item.Value.Date.Day == date && item.Value.Date.Month == viewTag) ? result : Brushes.White;
    }

我怎么解决这个问题?我能想到的唯一解决方案是每次用户选择一个月时在代码隐藏中生成 GridControl ,但这比仅更新源集合要慢...

4

1 回答 1

1

很难说没有看到转换器的代码,但我倾向于摆脱不必要的 MultiBinding 并简化为:

<Setter Property="Background" Value="{Binding Path=Column.Header, Converter={converter:CellColorConverterAmended} }" />
于 2013-02-28T14:18:16.830 回答