Вам необходимо привязать свойство IsChecked флажка к другому свойству объекта поддержки для каждого элемента.т. е. тип с именем должен предоставлять логическое свойство IsSelected.
При связывании данных будет соответствующим образом обновлено свойство IsSelected, к которому вам будет легко получить доступ в коде.Например, вы можете перебрать список и отфильтровать все элементы, для которых IsSelected = false.
Пример кода
XAML
<StackPanel>
<ComboBox ItemsSource="{Binding Items}">
<ComboBox.ItemTemplate>
<DataTemplate>
<CheckBox Content="{Binding Name}" IsChecked="{Binding IsSelected}"/>
</DataTemplate>
</ComboBox.ItemTemplate>
</ComboBox>
<Button Click="EvaluateSelectedItems">Show Selected</Button>
<TextBlock>Selected Items</TextBlock>
<ListBox ItemsSource="{Binding SelectedItems}" DisplayMemberPath="Name" Background="AliceBlue"/>
</StackPanel>
Код позади
public MainWindow()
{
InitializeComponent();
this.DataContext = this;
Items = new List<ItemVM>
{
new ItemVM {IsSelected = false, Name = "Firefox"},
new ItemVM {IsSelected = false, Name = "Chrome"},
new ItemVM {IsSelected = false, Name = "IE"}
};
}
public IEnumerable<ItemVM> Items { get; set; }
private IEnumerable<ItemVM> _selectedItems;
public IEnumerable<ItemVM> SelectedItems
{
get { return _selectedItems; }
set
{
_selectedItems = value;
if (PropertyChanged != null)
this.PropertyChanged(this, new PropertyChangedEventArgs("SelectedItems"));
}
}
private void EvaluateSelectedItems(object sender, RoutedEventArgs e)
{
SelectedItems = Items.Where(item => item.IsSelected);
}