这个类(下)是一个自定义组件。它应该只是通过单击扩展器内的列表来搜索文件夹。
ExpanderList 是扩展器中的列表
DirMaker 是实际的扩展器
using System;
using System.Collections.Generic;
using System.Text;
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;
using System.IO;
namespace BigHand
{
/// <summary>
/// Interaction logic for DirMakerControl.xaml
/// </summary>
public partial class DirMakerControl : UserControl
{
string currentDirectory = "c:/";
DirectoryInfo di;
bool directoryEmpty;
public DirMakerControl()
{
this.InitializeComponent();
getFolders();
updateHeader();
}
private void getFolders()
{
ExpanderList.Items.Clear();
try
{
di = new DirectoryInfo(currentDirectory);
foreach (DirectoryInfo d in di.GetDirectories())
{
ExpanderList.Items.Add(d.ToString());
}
}
catch (UnauthorizedAccessException)
{
//goBack() keeps display the same
goBack();
MessageBox.Show(" SORRY!!!! \nYou dont have the correct \npermisions to use these files.");
}
if (ExpanderList.Items.Count == 0)
{
directoryEmpty = true;
ExpanderList.IsEnabled = false;
ExpanderList.Items.Add("No Folders Here");
}
else
{
directoryEmpty = false;
ExpanderList.IsEnabled = true;
}
updateHeader();
}
private void ListClicked(object sender, SelectionChangedEventArgs e)
{
// If selected index is -1 (no selection) do nothing
if (ExpanderList.SelectedIndex != -1)
{
//update list and variables
if (!directoryEmpty)
{
ExpanderList.IsEnabled = true;
currentDirectory = currentDirectory + ExpanderList.SelectedItem + "/";
// Reset selected index to -1 (no selection)
ExpanderList.SelectedIndex = -1;
getFolders();
}
}
}
private void goBack()
{
currentDirectory = currentDirectory.Substring(0, getCurrentFolderStringIndex());
getFolders();
}
private void Button_Click(object sender, RoutedEventArgs e)
{
goBack();
}
//returns an integer representing where the current folder name starts in the current folder string
public int getCurrentFolderStringIndex()
{
char[] currentD = currentDirectory.ToCharArray();
for (int index = currentD.Length - 2; index >= 0; index--)
{
if (currentD[index] == '/')
{
return index + 1;
}
}
//if this gets called(should at least start back at the c:/)
return 0;
}
private void updateHeader()
{
//Change Header
//get temp int to save calling the method twice
int index = getCurrentFolderStringIndex();
if (index == 0)
DirMaker.Header = currentDirectory;
else
DirMaker.Header = currentDirectory.Substring(index, currentDirectory.Length - index);
}
private void selectionMade(ListBox sender, System.Windows.Input.MouseButtonEventArgs e)
{
// TODO: Add event handler implementation here.
// If selected index is -1 (no selection) do nothing
if (ExpanderList.SelectedIndex == -1)
return;
//update list and variables
if (!directoryEmpty)
{
ExpanderList.IsEnabled = true;
currentDirectory = currentDirectory + ExpanderList.SelectedItem + "/";
// Reset selected index to -1 (no selection)
ExpanderList.SelectedIndex = -1;
getFolders();
}
}
}
}
它工作得非常好,哈哈,除了私有 void ListClicked(object sender, SelectionChangedEventArgs e) 有时会触发不止一次,它的效果是跳过更深的文件,然后按预期的级别。当我在 if (ExpanderList.SelectedIndex != -1) 行上放置断点时,这种行为似乎不会重复,该行总是返回 -1 并在不应该发生的情况下阻止这种情况。我已经看到证据表明这种方法存在错误?虽然我没有经验或正面指责别人.....绝对是我虽然这个选项一直在我的脑海中发挥作用,因为我不能找到它反复射击的理由。
真的很重要,我尽快查明真相,这让我发疯
预先感谢您的任何帮助
约翰哈里斯