簡體   English   中英

為什么多項刪除在列表框上不起作用?

[英]Why is multiple item drop not working on listbox?

我為媒體播放器創建播放列表。

按照我的代碼:

Xaml:

<MediaElement x:Name="mePlayer" Margin="64,0,90,61"  ></MediaElement>
<ListBox x:Name="listbox4" Background="Salmon"   BorderBrush="Black" BorderThickness="3" Drop="listbox4_Drop"  >
</ListBox>
<Button x:Name="load" Content="Load" HorizontalAlignment="Left"  VerticalAlignment="Top" Width="76" Click="load_Click" Margin="184,285,0,0"/>

Xaml.cs:

private Dictionary<string, string> fileDictionary = new Dictionary<string, string>();   

private void load_Click(object sender, RoutedEventArgs e)
{
    Microsoft.Win32.OpenFileDialog ofd = new Microsoft.Win32.OpenFileDialog();
    ofd.DefaultExt = ".mp3";
    ofd.Filter = "All|*.*";
    ofd.Multiselect = true;
    Nullable<bool> result = ofd.ShowDialog();
    if (result == true)
    {

        for (int i = 0; i < ofd.FileNames.Length; i++)
        {
            var filePath = ofd.FileNames[i];
            var fileName = System.IO.Path.GetFileName(filePath);
            fileDictionary.Add(fileName, filePath);
            listbox4.Items.Add(fileName);
            listbox4.SelectedItem = fileName;
        }
    }
}


private void listbox4_Drop(object sender, DragEventArgs e)
{
    if (e.Data.GetDataPresent(DataFormats.FileDrop))
    {

        string[] droppedFilePaths =
            e.Data.GetData(DataFormats.FileDrop, true) as string[];

        foreach (string droppedFilePath in droppedFilePaths)
        {
         for (int i = 0; i < droppedFilePaths.Length; i++)
            {
                var filePath = droppedFilePaths[i];
                var fileName = System.IO.Path.GetFileName(filePath);
                fileDictionary.Add(fileName, filePath);
                listbox4.Items.Add(fileName);
                listbox4.SelectedItem = fileName;
            }

        }
    }
}

它可以刪除單個文件,但是當我刪除多個文件時,它不會添加到列表框中。

已加載多個已加載文件,但不會刪除多個文件。

如何在列表框上放置多個文件?

由於我無法復制您列出的問題,因此我目前無法在這方面為您提供幫助。 不過,我可以在您認為合適的地方為您提供幫助。

您當前的Drop方法有一個額外的循環,該循環會使您添加到列表框中的項目數成倍增加。

您當前的方法:

    private void listbox4_Drop(object sender, DragEventArgs e)
    {
        if (e.Data.GetDataPresent(DataFormats.FileDrop))
        {

            string[] droppedFilePaths =
                e.Data.GetData(DataFormats.FileDrop, true) as string[];

            foreach (string droppedFilePath in droppedFilePaths)
            {
                //if you keep this loop, you will all the dropped files for each dropped file
                //therefore, if I dropped 3 files, I'd get 9 entries in the listbox
                //if I dropped 4 files, I'd get 16 entries and so on...
                for (int i = 0; i < droppedFilePaths.Length; i++)//this has to go
                {//this has to go
                    var filePath = droppedFilePaths[i];//this needs to be a different variable since "i" will no longer exist
                    var fileName = System.IO.Path.GetFileName(filePath);
                    //fileDictionary.Add(fileName, filePath);
                    listbox4.Items.Add(fileName);
                    listbox4.SelectedItem = fileName;
                }//this has to go

            }
        }
    }

重構(使用ForEach)

    private void blaze_125_listbox4_Drop(object sender, DragEventArgs e)
    {
        if (e.Data.GetDataPresent(DataFormats.FileDrop))
        {

            string[] droppedFilePaths =
                e.Data.GetData(DataFormats.FileDrop, true) as string[];

            foreach (string droppedFilePath in droppedFilePaths)
            {
                var filePath = droppedFilePath;
                var fileName = System.IO.Path.GetFileName(filePath);
                //fileDictionary.Add(fileName, filePath);
                listbox4.Items.Add(fileName);
                listbox4.SelectedItem = fileName;
            }

        }
    }

這也將起作用(使用ForLoop)

    private void blaze_125_listbox4_Drop_anotherSpin(object sender, DragEventArgs e)
    {
        if (e.Data.GetDataPresent(DataFormats.FileDrop))
        {
            string[] droppedFilePaths =
                e.Data.GetData(DataFormats.FileDrop, true) as string[];

            for (int i = 0; i < droppedFilePaths.Length; i++)
            {
                var filePath = droppedFilePaths[i];
                var fileName = System.IO.Path.GetFileName(filePath);
                //fileDictionary.Add(fileName, filePath);
                listbox4.Items.Add(fileName);
                listbox4.SelectedItem = fileName;
            }
        }
    }

微光

    private void blaze_125_listbox4_Drop_Slimmer(object sender, DragEventArgs e)
    {
        if (e.Data.GetDataPresent(DataFormats.FileDrop))
        {
            string[] droppedFilePaths =
                e.Data.GetData(DataFormats.FileDrop, true) as string[];

            foreach (string droppedFilePath in droppedFilePaths)
            {
                listbox4.Items.Add(System.IO.Path.GetFileName(droppedFilePath));
            }
        }
    }

使用字典存儲項目並更新列表

    Dictionary<string, string> fileDictionary = new Dictionary<string, string>();

    private void blaze_125_listbox4_Drop_Slimmer(object sender, DragEventArgs e)
    {
        if (e.Data.GetDataPresent(DataFormats.FileDrop))
        {
            string[] droppedFilePaths =
                e.Data.GetData(DataFormats.FileDrop, true) as string[];

            foreach (string droppedFilePath in droppedFilePaths)
            {
                //listbox4.Items.Add(System.IO.Path.GetFileName(droppedFilePath));//don't need this anymore

                //Check if the file is already in the dictionary.
                //Check by looking up the key, and by looking up the value too.
                if (fileDictionary.ContainsKey(System.IO.Path.GetFileName(droppedFilePath)) || fileDictionary.ContainsValue(droppedFilePath))
                {
                    //no need to add this file, it's already in the dictionary
                    //if you try to add a file with a KEY identical to a KEY that already exists in the dictionary,
                    //it will throw an exception
                    //A dictionary can contain the same value multiple times, but it can not contain the same key more than once.
                }
                else
                {
                    //the file is not listed in the dictionary, so lets add it
                    fileDictionary.Add(System.IO.Path.GetFileName(droppedFilePath), droppedFilePath);
                }
            }
        }

        //Now lets call the method in charge of updating the listbox 
        UpdateTheListbox(fileDictionary, listbox4);
    }

    private void UpdateTheListbox(Dictionary<string, string> incomingDictionary, ListBox listboxToModify)
    {
        listboxToModify.Items.Clear();//clear all the items in the list
        foreach (KeyValuePair<string, string> item in incomingDictionary)
        {
            listboxToModify.Items.Add(item.Key);
        }
        //this method should probably be optimized because if your listBox already contains a large number of items
        //it may be quicker to only add the missing items, instead of reverting back to an empty list, and adding all the items to it again.
        //Though I'll leave this up to you to implement. We'll be here to answer questions if you have a hard time doing it.
    }

更新了維護選定項目(如果存在選定項目)的方法

    private void UpdateTheListboxMaintainExistingSelection(Dictionary<string, string> incomingDictionary, ListBox listboxToModify)
    {
        var preSelectedItem = listboxToModify.SelectedItem;//store the current selection

        listboxToModify.Items.Clear();//clear all the items in the list
        foreach (KeyValuePair<string, string> item in incomingDictionary)
        {
            listboxToModify.Items.Add(item.Key);
        }
        //this method should probably be optimized because if your listBox already contains a large number of items
        //it may be quicker to only add the missing items, instead of reverting back to an empty list, and adding all the items to it again.
        //Though I'll leave this up to you to implement. We'll be here to answer questions if you have a hard time doing it.

        //Maintain the selected item if there was one
        if (preSelectedItem != null)
        {
            listboxToModify.SelectedItem = preSelectedItem;
        }
    }

保持選擇或在沒有選擇的情況下選擇最后一項

    private void UpdateTheListboxMaintainExistingOrSelectLastAdded(Dictionary<string, string> incomingDictionary, ListBox listboxToModify)
    {
        var preSelectedItem = listboxToModify.SelectedItem;//store the current selection

        listboxToModify.Items.Clear();//clear all the items in the list
        foreach (KeyValuePair<string, string> item in incomingDictionary)
        {
            listboxToModify.Items.Add(item.Key);
        }
        //this method should probably be optimized because if your listBox already contains a large number of items
        //it may be quicker to only add the missing items, instead of reverting back to an empty list, and adding all the items to it again.
        //Though I'll leave this up to you to implement. We'll be here to answer questions if you have a hard time doing it.


        if (preSelectedItem != null)
        {
            //Maintain the selected item if there was one
            listboxToModify.SelectedItem = preSelectedItem;
        }
        else
        {
            //select the last item in the listbox if nothing was pre-selected
            listboxToModify.SelectedItem = listboxToModify.Items[listboxToModify.Items.Count - 1];
        }
    }

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM