У меня есть представление списка с некоторыми элементами в главном окне. Затем я добавляю флажки, чтобы при выборе элемента он также отмечался.

Теперь я попытался передать выбранные элементы из этого списка в другой список, но вот что я получаю:

enter image description here

Вот мой XAML:

<Window x:Class="WpfApp1.MainWindow"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    xmlns:local="clr-namespace:WpfApp1"
    mc:Ignorable="d"
    Title="MainWindow" Height="350" Width="525">
<Grid>
    <Canvas HorizontalAlignment="Left" Height="299" Margin="10,10,0,0" VerticalAlignment="Top" Width="497">
        <TabControl Height="279" Canvas.Left="10" Canvas.Top="10" Width="477">
            <TabItem Header="TabItem">
                <Grid Background="#FFE5E5E5">
                    <ListView Name="lv1" Margin="0,0,0,0" HorizontalAlignment="Left" VerticalAlignment="Top" Height="110" Width="471">
                        <ListViewItem>
                            <CheckBox >
                                <StackPanel Orientation="Horizontal">
                                    <TextBlock Text="Apple"/>
                                </StackPanel>
                            </CheckBox>
                        </ListViewItem>
                        <ListViewItem>
                            <CheckBox >
                                <StackPanel Orientation="Horizontal">
                                    <TextBlock Text="Orange"/>
                            </StackPanel>
                            </CheckBox>
                        </ListViewItem>
                    </ListView>
                    <Button Content="Copy" Width="100" Height="25" Click="Button_Click"/>
                    <ListView Name="lv2" HorizontalAlignment="Left" VerticalAlignment="Bottom" Height="110" Width="471"/>
                </Grid>
            </TabItem>
            <TabItem Header="TabItem">
                <Grid Background="#FFE5E5E5"/>
            </TabItem>
            <TabItem Header="TabItem">
                <Grid Background="#FFE5E5E5"/>
            </TabItem>
            <TabItem Header="TabItem">
                <Grid Background="#FFE5E5E5"/>
            </TabItem>
            <TabItem Header="TabItem">
                <Grid Background="#FFE5E5E5"/>
            </TabItem>
            <TabItem Header="TabItem">
                <Grid Background="#FFE5E5E5"/>
            </TabItem>
            <TabItem Header="TabItem">
                <Grid Background="#FFE5E5E5"/>
            </TabItem>
        </TabControl>
    </Canvas>

</Grid>

Вот код в C #:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;

namespace WpfApp1
{
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : Window
{
    public MainWindow()
    {
        InitializeComponent();
    }

    private void Button_Click(object sender, RoutedEventArgs e)
    {
        List<string> lv1list = new List<string>();
        foreach (var i in lv1.SelectedItems)
        {
            lv1list.Add(i.ToString());
        }
        lv2.Items.Add(lv1.SelectedItems);
        }
    }
}

Что здесь пошло не так?

3
user7900863 25 Апр 2017 в 00:06

2 ответа

Лучший ответ

Проблема в том, что вы добавляете полный список как элемент, поэтому вы получаете значение (Collection).

Что вы можете сделать, это получить все выбранные элементы в списке их цикла и добавить их один за другим

private void Button_Click(object sender, RoutedEventArgs e)
{
    var selectedItems = lv1.SelectedItems;

    for(int i = 0; i < selectedItems.Count; i++)
    {
        lv2.Items.Add(selectedItems[i]);
    }
}

Вы также можете очистить lv2 перед добавлением новых значений

lv2.Items.Clear();

Другой вариант, при котором вам не нужно нажимать кнопку, чтобы значения отображались во втором списке, состоял бы в том, чтобы связать ItemsSource вашего lv2 с SelectedItems вашего {{X3) } }

lv2.ItemsSource = lv1.SelectedItems;

Вы можете сделать это один раз в начале, и lv2 всегда будет содержать выбранные элементы lv1 и будет обновляться, как только выбранные элементы изменятся.

2
I.B 24 Апр 2017 в 21:44

Я сделал еще несколько модификаций, а потом понял, что это не работает, как следует. У меня есть «оператор foreach», проходящий по всем проверенным / выбранным элементам в listBox1, затем внутри «оператора foreach» есть «оператор If», чтобы проверить, находятся ли отмеченные / выбранные элементы из listBox1 в списке listBox2, если они нет. затем они копируются в listBox2. Каждое условие «оператора If» должно отображать соответствующий MessageBox. Проблема в том, что «оператор If» не работает должным образом. Я знаю это, потому что не могу увидеть правильный релевантный MessageBox для правильного условия «оператора If». Тем не менее, элементы не дублируются, то есть они не копируются снова и снова, только они выглядят дублированными в MessageBox. Вот мой код и надеюсь, что кто-то может заметить мою ошибку

using System.Windows;
using System.Windows.Controls;
using System.Collections.Generic;
using System.ComponentModel;
using System.Windows.Controls.Primitives;
using System.Windows.Media;
using System;

namespace MYNAMESPACE
{
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>

public partial class MainWindow : INotifyPropertyChanged
{
    public MainWindow()
    {
        InitializeComponent();
        // To initialise the List and use it outside the class
        //MyListItem instanceOfClass = new MyListItem();
        //List<CheckBoxListItem> listOfItems = instanceOfClass.MyMethod();
        //listBox1.ItemsSource = listOfItems;
    }

    public class CheckBoxListItem : INotifyPropertyChanged
    {
        public bool CheckStatus { get; set; }
        public string Text { get; set; }
        public CheckBoxListItem(bool _CheckStatus, string _Text)
        {
            CheckStatus = _CheckStatus;
            Text = _Text;
        }

        public event PropertyChangedEventHandler PropertyChanged;
    }

    public class MyListItem
    {
        public List<CheckBoxListItem> MyMethod()
        {
            List<CheckBoxListItem> items = new List<CheckBoxListItem>();
            items.Add(new CheckBoxListItem(false, "Item 1"));
            items.Add(new CheckBoxListItem(false, "Item 2"));
            items.Add(new CheckBoxListItem(false, "Item 3"));

            return items;
        }
    }

    public List<string> selectedNames = new List<string>();
    private void CheckBox_Click(object sender, RoutedEventArgs e)
    {
        var checkBox = sender as CheckBox;
        var item = checkBox.Content;
        bool isChecked = checkBox.IsChecked.HasValue ? checkBox.IsChecked.Value : false;

        if (isChecked)
            selectedNames.Add(item.ToString());
        else
            selectedNames.Remove(item.ToString());
    }

    public string selections;
    bool updatedItems;
    public void Button_Click(object sender, RoutedEventArgs e)
    {
        foreach (string selection in selectedNames)
        {
            selections += selection + Environment.NewLine;

            if (!listBox2.Items.Contains(selection))
            {
                listBox2.Items.Add(selection);
                updatedItems = true;
            }

            else if (listBox2.Items.Contains(selection))
            {
                updatedItems = false;
            }
        }

        if (updatedItems == true)
            MessageBox.Show("Add items are: " + selections);

        else if (updatedItems == false)
            MessageBox.Show("No update to selection was made.");
    }

    private void CheckStatus(string propName)
    {
        PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propName));
    }
    public event PropertyChangedEventHandler PropertyChanged;
    }
   }
2
25 Апр 2017 в 16:18
43597717