WP8 LongListMultiSelector绑定SelectedItems

时间:2013-08-16 07:50:34

标签: c# xaml mvvm binding windows-phone-8

我对Windows Phone 8工具包中的LongListMultiSelector有疑问。

我想使用此控件在WP8中实现文件浏览器(使用MVVM)。由于SelectedItems属性不可绑定,我使用本文中的解决方案来解决这个问题。 http://dotnet-redzone.blogspot.de/2012/11/windows-phone-8longlistselector.html

这是我的相关代码: 的 XAML

 <Grid DataContext="{Binding FileBrowserViewModel}">
    <local:LongListMultiSelector
                    x:Name="FileList"
                    ItemsSource ="{Binding CurrentFileList}"
                    EnforceIsSelectionEnabled="{Binding IsInSelectionMode}" 
                    toolkit:TiltEffect.IsTiltEnabled="True" 
                    SelectedItems="{Binding SelectedFiles, Mode=TwoWay}"
                    IsSelectionEnabled="True"/>

 </Grid>

我的LonglistMultiSelector

public class LongListMultiSelector : Microsoft.Phone.Controls.LongListMultiSelector
{  
    public LongListMultiSelector()
    {
        SelectionChanged += LongListMultiSelector_SelectionChanged;
    }

    void LongListMultiSelector_SelectionChanged(object sender, System.Windows.Controls.SelectionChangedEventArgs e)
    {
        this.SelectedItems = base.SelectedItems;
    }

    public static readonly DependencyProperty SelectedItemsProperty =
        DependencyProperty.Register(
            "SelectedItems",
            typeof(object),
            typeof(LongListMultiSelector),
            new PropertyMetadata(null, OnSelectedItemsChanged)
        );

    private static void OnSelectedItemsChanged(DependencyObject d, DependencyPropertyChangedEventArgs e)
    {
        var selector = (LongListMultiSelector) d;
        selector.SelectedItems = e.NewValue;
    }

    public new object SelectedItems
    {
        get { return GetValue(SelectedItemsProperty); }
        set { SetValue(SelectedItemsProperty, value); }
    }
}

查看模型

/// <summary>
/// The currently selected Items.
/// </summary>
public ObservableCollection<File> SelectedFiles
{
    get { return _selectedFiles; }
    set { Set(() => this.SelectedFiles, ref _selectedFiles, value); }
}
private ObservableCollection<File> _selectedFiles;

但是这个解决方案不起作用。 SelectedFiles属性根本不会改变。 (_selectedFiles始终为null)

  • 编辑:设置(()=&gt; this.SelectedFiles,ref _selectedFiles,value);来自Mvvmlight(Laurent Bugnion)包。

1 个答案:

答案 0 :(得分:0)

我使用普通的LongListSelector解决了我的问题,并为其中的每个Item赋予了一个布尔IsSelected。

DataTemplate然后有一个如下所示的复选框:

<CheckBox IsChecked="{Binding IsSelected, Converter={StaticResource BooleanToVisibilityConverter}}"/>