WinRT XAML Toolkit BindableSelections不更新UI

时间:2013-03-26 22:38:18

标签: xaml windows-runtime winrt-xaml mvvm-light winrt-xaml-toolkit

以下是用于处理gridview中所选项目的xaml和c#代码。

我也在使用MVVM Light,一切正常,包括我能够看到SelectedItems中的内容。

但是,当我尝试清除SelectedItems时,我的UI似乎没有更新/反映对SelectedItems所做的更改。

我正在使用WinRT XAML工具包(http://winrtxamltoolkit.codeplex.com/),它在GridView上具有BindableSelection扩展

XAML

<controls:CustomGridView
    x:Name="VideoItemGridView"
    Grid.Row="2"
    Margin="0,-3,0,0"
    Padding="116,0,40,46"
    HorizontalContentAlignment="Stretch"
    VerticalContentAlignment="Stretch"
    IsItemClickEnabled="True"
    SelectionMode="Extended"
    Extensions:GridViewExtensions.BindableSelection="{Binding SelectedVideoItems, Mode=TwoWay}"
    ItemsSource="{Binding Source={StaticResource ViewSource}}"
    ItemTemplate="{StaticResource VideoItemTemplate}">
    <GridView.ItemsPanel>
        <ItemsPanelTemplate>
            <VariableSizedWrapGrid ItemWidth="250" ItemHeight="160" />
        </ItemsPanelTemplate>
    </GridView.ItemsPanel>
</controls:CustomGridView>

MyViewViewModel.cs

#region Selected Items

/// <summary>
/// Gets or sets the selected video items.
/// </summary>
public ObservableCollection<object> SelectedVideoItems
{
    get { return this._selectedVideoItems; }
    set
    {
        this._selectedVideoItems = value;
        this.Set("SelectedVideoItems", ref this._selectedVideoItems, value);
    }
}
private ObservableCollection<object> _selectedVideoItems = new ObservableCollection<object>();

#endregion

#region App Bar Click Commands

/// <summary>
/// Gets the ClearSelection click command.
/// </summary>
public ICommand ClearSelectionClickCommand
{
    get
    {
        return new RelayCommand(() => this.ClearSelectionOperation());
    }
}

/// <summary>
/// Selects all command operation.
/// </summary>
private void ClearSelectionOperation()
{
    this.SelectedVideoItems = new ObservableCollection<object>();
}

#endregion

2 个答案:

答案 0 :(得分:0)

尝试通过调用

清除ClearSelectionOperation中的所选项目
this.SelectedVideoItems.Clear();

而不是

this.SelectedVideoItems = new ObservableCollection<object>();

如果这无法帮助检查current version of the extension from March 7是否解决了问题。

答案 1 :(得分:0)

事实证明,由于我使用的是数据模板,实际上我的数据模型需要设置一个标志来表明它已被选中

这是拼图的缺失部分。一旦我更新绑定到网格视图项的数据模型(其中还包括对行/列跨越的支持),UI就会按预期更新。

希望这有助于其他人。

public class CustomGridView : GridView
{
    protected override void PrepareContainerForItemOverride(DependencyObject element, object item)
    {
        try
        {
            base.PrepareContainerForItemOverride(element, item);

            dynamic _Item = item;
            element.SetValue(VariableSizedWrapGrid.ColumnSpanProperty, _Item.ColumnSpan);
            element.SetValue(VariableSizedWrapGrid.RowSpanProperty, _Item.RowSpan);
            element.SetValue(GridViewItem.IsSelectedProperty, _Item.IsSelected);
        }
        catch
        {
            element.SetValue(VariableSizedWrapGrid.ColumnSpanProperty, 1);
            element.SetValue(VariableSizedWrapGrid.RowSpanProperty, 1);
            element.SetValue(GridViewItem.IsSelectedProperty, false);
        }
        finally
        {
            base.PrepareContainerForItemOverride(element, item);
        }
    }