我是MVVM / WPF的新手,经过几个小时的研究,没有找到任何真正有用/可行的答案,我决定试一试,试试这里。
我想从我的列表框中选择一个项目,它使用List作为ItemSource。
相关ViewModel:
public class FavoriteStructureVm : INotifyPropertyChanged
{
#region
public event PropertyChangedEventHandler PropertyChanged;
private void OnPropertyChanged(string propertyName)
{
if (this.PropertyChanged != null)
PropertyChanged(this, new PropertyChangedEventArgs(propertyName));
}
#endregion
public ObservableCollection<FavoriteDataVm> Favorites { get; set; }
public int SelectedIndex { get; set; }
private FavoriteDataVm _selectedItem;
public FavoriteDataVm SelectedItem
{
set
{
_selectedItem = value;
var item = (FavoriteDataVm)_selectedItem;
if (item.Type == FavoriteDataType.Add)
{
SelectedIndex = 1;
}
}
}
}
ListBox默认包含一些项目,最后一个项目始终是Add
类型之一,如果选中,可以添加新项目并默认选择它,如果没有新项目则选择之前选择的项目项目已添加。 For Simplicity 所选项目只是1,无论是否添加新项目。
无论我在OnPropertyChanged
尝试更新的位置和内容,它都没有更新视图中的SelectedIndex,但是,通过在FavoriteDataVm
中添加/插入新的ObservableCollection<FavoriteDataVm> Favorites
,视图中的SelectedIndex
会更新。
将新项目添加到列表的过程并不总是会发生,但我仍然希望始终更新SelectedIndex
。
相关XAML:
<ListBox Name="favMenu" ItemsSource="{Binding Favorites}" SelectionMode="Single"
HorizontalAlignment="Center" VerticalAlignment="Top"
BorderThickness="0" Background="Transparent" Height="{Binding ElementName=window, Path=ActualHeight}"
SelectedItem="{Binding SelectedItem, Mode=TwoWay}"
SelectedIndex="{Binding SelectedIndex, Mode=TwoWay}"
>
<ListBox.Resources>
<Style TargetType="ListBoxItem">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="ListBoxItem">
<Border Background="Transparent" SnapsToDevicePixels="true">
<ContentPresenter />
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</ListBox.Resources>
<!--changing default orientation-->
<ListBox.ItemsPanel>
<ItemsPanelTemplate>
<VirtualizingStackPanel Orientation="Vertical"/>
</ItemsPanelTemplate>
</ListBox.ItemsPanel>
<ListBox.ItemTemplate>
<DataTemplate>
<Border x:Name="Border"
BorderThickness="0" BorderBrush="Black" Background="{x:Null}"
Width="60" Height="60" CornerRadius="30" Margin="{Binding Margin}"
ToolTip="{Binding Name}">
<Image Source="{Binding ImageUri}" Width="60" Height="60" Stretch="UniformToFill">
<Image.Clip>
<EllipseGeometry RadiusX="30" RadiusY="30" Center="30,30"/>
</Image.Clip>
</Image>
</Border>
</DataTemplate>
</ListBox.ItemTemplate>
</ListBox>
我找到了一种解决方法,只需创建一个虚拟项并将其删除,因为添加内容似乎更新了视图中的SelectedIndex
。我不认为这是一个解决方案,因为它有很多缺点。
所以这实际上提出了两个问题:
SelectedIndex
?还有一个初学者问题,因为我是MVVM的新手:
答案 0 :(得分:3)
如何更新ListBox的SelectedIndex?
您可以通过获取源集合中SelectedItem
的索引来获取所选索引:
int selectedIndex = (SelectedItem != null && Favorites != null) ? Favorites.IndexOf(SelectedItem) : -1;
您可以通过设置SelectedItem
属性来选择项目:
SelectedItem = Favorites[1]; //selects the second item
您不应该绑定SelectedItem
的{{1}}和SelectedIndex
属性。这些必须同步。从您的XAML中删除ListBox
。
另请注意,如果您打算动态更新源属性,则需要为此属性引发SelectedIndex="{Binding SelectedIndex, Mode=TwoWay}"
以使视图刷新:
PropertyChanged
答案 1 :(得分:0)
您没有更新SelectedIndex 声明应如下
private int _selectedIndex ;
public int SelectedIndex{
get{return _selectedIndex };
set{_selectedIndex=value;OnPropertyChanged("SelectedIndex") };
}
这样,当selectedindex更改时,将通知列表
&#34;对不起,如果有任何拼写错误,我直接在这里写了这个,而不是在代码编辑器中,所以你可能会得到拼写错误&#34;