数据更改后,WPF ItemsControl元素DataTrigger不会触发

时间:2015-05-07 14:10:29

标签: c# wpf colors itemscontrol datatrigger

我遇到了这样的问题:我的数据触发器在绑定数据更改后不会改变颜色。 Datatrigger在TextBlock上,它是ItemsControl的ElemntTenplate。

我的Xaml:

   <Grid>
    <Grid.RowDefinitions>
        <RowDefinition ></RowDefinition>
        <RowDefinition Height="3*"></RowDefinition>
    </Grid.RowDefinitions>

    <Grid>
        <Grid.RowDefinitions>
            <RowDefinition ></RowDefinition>
            <RowDefinition ></RowDefinition>
        </Grid.RowDefinitions>
        <Grid.ColumnDefinitions>
            <ColumnDefinition></ColumnDefinition>
            <ColumnDefinition></ColumnDefinition>
        </Grid.ColumnDefinitions>

        <TextBlock Grid.Row="1" Grid.Column="0" Text="{Binding TaresToReturn, StringFormat='К возврату: {0}'}"></TextBlock>
        <TextBlock Grid.Row="1" Grid.Column="1" Text="{Binding TaresReturned, StringFormat='Возвращено: {0}'}"></TextBlock>
    </Grid>


    <ScrollViewer Grid.Row="1" VerticalScrollBarVisibility="Visible">
        <ItemsControl ItemsSource="{Binding Tares}" Margin="5">
            <ItemsControl.ItemsPanel>
                <ItemsPanelTemplate>
                    <WrapPanel Orientation="Horizontal" IsItemsHost="True"/>
                </ItemsPanelTemplate>
            </ItemsControl.ItemsPanel>

            <ItemsControl.ItemTemplate>
                <DataTemplate DataType="tareReturnController:p_GetTaresForReturnResult">
                    <Border Width="100" Height="30" Margin="10">
                        <TextBlock x:Name="TextBlock" Text="{Binding barcode}" FontSize="15">
                            <TextBlock.Style>
                                <Style>
                                    <Style.Triggers>
                                        <DataTrigger Binding="{Binding IsReturned, UpdateSourceTrigger=PropertyChanged}" Value="false">
                                            <Setter Property="TextBlock.Background" Value="Red"/>
                                        </DataTrigger>

                                        <DataTrigger Binding="{Binding IsReturned, UpdateSourceTrigger=PropertyChanged}" Value="true">
                                            <Setter Property="TextBlock.Background" Value="Green"/>
                                        </DataTrigger>
                                    </Style.Triggers>
                                </Style>
                            </TextBlock.Style>
                        </TextBlock>
                    </Border>
                    <!--<DataTemplate.Triggers>
                    <DataTrigger Binding="{Binding IsReturned}" Value="false">
                        <Setter TargetName="TextBlock" Property="TextBlock.Background" Value="Red"/>
                    </DataTrigger>

                    <DataTrigger Binding="{Binding IsReturned}" Value="true">
                        <Setter TargetName="TextBlock" Property="TextBlock.Background" Value="Green"/>
                    </DataTrigger>
                </DataTemplate.Triggers>-->
                </DataTemplate>
            </ItemsControl.ItemTemplate>
        </ItemsControl>
    </ScrollViewer>

</Grid>

我的ViewModel部分:

        private ObservableCollection<p_GetTaresForReturnResult> tares_;

        public ObservableCollection<p_GetTaresForReturnResult> Tares
        { get { return tares_; } set { tares_ = value; } }

        private void GetTares()
        {
            tares_ = new ObservableCollection<p_GetTaresForReturnResult>(Terminal.Dc.p_GetTaresForReturn(DateTime.Parse("05.05.2015")));
        }

        public int TaresToReturn
        { get { return Tares.Count(t => Convert.ToBoolean(t.IsReturned) == false); } }

        public int TaresReturned
        { get { return Tares.Count(t => Convert.ToBoolean(t.IsReturned)); } }

        public void ScannerOnOnBarcodeReceived(string[] _args)
        {
            foreach (string barcode in _args)
            {
                var tt = Tares.FirstOrDefault(t => t.barcode.ToLower().Trim() == barcode.ToLower().Trim());
                if (tt != null)
                {
                    var ttt = new p_GetTaresForReturnResult();
                    ttt.barcode = "111";
                    ttt.id = 111;
                    ttt.IsReturned = false;
                    tares_.Add(ttt);//Add new element for test
                    tt.IsReturned = true;
                    tt.barcode = "1";
                    RaisePropertyChanged("TaresToReturn");
                    RaisePropertyChanged("TaresReturned");
                    RaisePropertyChanged("barcode");
                    RaisePropertyChanged("IsReturned");
                    RaisePropertyChanged("Tares");
                }
            }
        }

p_GetTaresForReturnResult的代码

    public partial class p_GetTaresForReturnResult
{

    private int _id;

    private string _barcode;

    private System.Nullable<bool> _IsReturned;

    public p_GetTaresForReturnResult()
    {
    }

    [global::System.Data.Linq.Mapping.ColumnAttribute(Storage="_id", DbType="Int NOT NULL")]
    public int id
    {
        get
        {
            return this._id;
        }
        set
        {
            if ((this._id != value))
            {
                this._id = value;
            }
        }
    }

    [global::System.Data.Linq.Mapping.ColumnAttribute(Storage="_barcode", DbType="NChar(20)")]
    public string barcode
    {
        get
        {
            return this._barcode;
        }
        set
        {
            if ((this._barcode != value))
            {
                this._barcode = value;
            }
        }
    }

    [global::System.Data.Linq.Mapping.ColumnAttribute(Storage="_IsReturned", DbType="Bit")]
    public System.Nullable<bool> IsReturned
    {
        get
        {
            return this._IsReturned;
        }
        set
        {
            if ((this._IsReturned != value))
            {
                this._IsReturned = value;
            }
        }
    }
}

第一次加载页面时,我的元素颜色正确。 当我更改集合并调用RaisePropertyCahnged时,他们不会改变它们的颜色! 注意:如果我将新的elemnt添加到集合中,它将出现在WrapPanel中。但是已经创建的项目不会改变它们的颜色和文字!

谁能告诉我我做错了什么?

1 个答案:

答案 0 :(得分:1)

如果你想顺利处理这个问题,我认为你必须使用包含NotificatonObject字段的p_GetTaresForReturnResult包装此类并从中写入/读取属性,但它调用{{1}在setter。

否则,您需要替换项目以通知视图有关更改。

Messenger 编辑: 我修改了p_GetTaresForReturnResult类:

RaisePropertyChanged