Nuta
Dostęp do tej strony wymaga autoryzacji. Możesz spróbować się zalogować lub zmienić katalog.
Dostęp do tej strony wymaga autoryzacji. Możesz spróbować zmienić katalogi.
W tym temacie przedstawiono sposób wyświetlania i uzyskiwania dostępu do zawartości katalogu w polu listy wielokrotnej wyboru. W polu listy wielokrotnego wyboru użytkownik może wybrać kilka elementów jednocześnie.
Przykładowy kod języka C++ w tym temacie umożliwia użytkownikowi wyświetlenie listy plików w bieżącym katalogu, wybranie grupy plików z listy i usunięcie ich.
Co musisz wiedzieć
Technologie
Warunki wstępne
- C/C++
- Programowanie interfejsu użytkownika systemu Windows
Instrukcje
Aplikacja do wyświetlania katalogów musi wykonywać następujące zadania związane z oknem listy:
- Zainicjuj pole listy.
- Pobierz wybrane opcje użytkownika z pola listy.
- Usuń nazwy plików z pola listy po usunięciu wybranych plików.
W poniższym przykładzie kodu języka C++ procedura okna dialogowego inicjuje pole listy wielokrotnego wyboru (IDC_FILELIST) przy użyciu funkcji DlgDirList, aby wypełnić pole listy nazwami wszystkich plików w bieżącym katalogu.
Gdy użytkownik wybierze grupę plików i wybierze przycisk Usuń, procedura okna dialogowego wysyła komunikat LB_GETSELCOUNT, aby pobrać liczbę wybranych plików oraz komunikat LB_GETSELITEMS, aby pobrać tablicę wybranych elementów pola listy. Po usunięciu pliku procedura okna dialogowego usuwa odpowiedni element z pola listy, wysyłając komunikat LB_DELETESTRING.
#define BIGBUFF 8192
INT_PTR CALLBACK DlgDelFilesProc(HWND hDlg, UINT message,
UINT wParam, LONG lParam)
{
PTSTR pszCurDir;
PTSTR pszFileToDelete;
int cSelItems;
int cSelItemsInBuffer;
TCHAR achBuffer[MAX_PATH];
int aSelItems[BIGBUFF];
int i;
BOOL fResult;
HWND hListBox;
int iRet;
switch (message) {
case WM_INITDIALOG:
// Initialize the list box by filling it with files from
// the current directory.
pszCurDir = achBuffer;
GetCurrentDirectory(MAX_PATH, pszCurDir);
DlgDirList(hDlg, pszCurDir, IDC_FILELIST, IDS_PATHTOFILL, 0);
SetFocus(GetDlgItem(hDlg, IDC_FILELIST));
return FALSE;
case WM_COMMAND:
switch (LOWORD(wParam))
{
case IDOK:
// When the user presses the DEL (IDOK) button,
// first retrieve the list of selected files.
pszFileToDelete = achBuffer;
hListBox = GetDlgItem(hDlg, IDC_FILELIST);
cSelItems = SendMessage(hListBox,
LB_GETSELCOUNT, 0, 0);
cSelItemsInBuffer = SendMessage(hListBox,
LB_GETSELITEMS, 512, (LPARAM) aSelItems);
if (cSelItems > cSelItemsInBuffer)
{
MessageBox(hDlg, L"Too many items selected.",
NULL, MB_OK);
}
else
{
// Make sure the user really wants to delete the files.
iRet = MessageBox(hDlg,
L"Are you sure you want to delete these files?",
L"Deleting Files", MB_YESNO | MB_ICONEXCLAMATION);
if (iRet == IDNO)
return TRUE;
// Go through the list backward because after deleting
// an item the indices change for every subsequent
// item. By going backward, the indices are never
// invalidated.
for (i = cSelItemsInBuffer - 1; i >= 0; i--)
{
SendMessage(hListBox, LB_GETTEXT,
aSelItems[i],
(LPARAM) pszFileToDelete);
fResult = DeleteFile(pszFileToDelete);
if (!fResult)
{
MessageBox(hDlg, L"Could not delete file.",
NULL, MB_OK);
}
else
{
SendMessage(hListBox, LB_DELETESTRING,
aSelItems[i], 0);
}
}
SendMessage(hListBox, LB_SETCARETINDEX, 0, 0);
}
return TRUE;
case IDCANCEL:
// Destroy the dialog box.
EndDialog(hDlg, TRUE);
return TRUE;
default:
return FALSE;
}
default:
return FALSE;
}
}
Tematy pokrewne