Shell extensions

Строго говоря, я сейчас буду говорить не о всей теме расширений оболочки, а более конкретно - о функции, открывающей окно выбора папки, и списках идентификаторов.

Что такое списки идентификаторов... Вообще, предполагается, что в оболочке данные, такие как имена файлов, директорий и т.д. записываются не простыми строками, а списками идентификаторов. Это довольно сложный способо хранения информации такого рода, и мне немного непонятно, к чему такие ухищрения... Но, неважно. Так вот, так как диалог открывается, первая выделенная папка, которую он отображает, и вообще выбранная папка, которую он (вернее она - функция) возвращает, находятся в указателях на списки идентфикаторов, именумых item identifier list. Для этих списков существуют функции. Которые мы естественно рассмотрим.

SHBrowseForFolder

Функция, открывающая диалоговое окно, довольно лаконично выглядит:

WINSHELLAPI LPITEMIDLIST WINAPI SHBrowseForFolder( LPBROWSEINFO lpbi );

Как я и предупреждал, возвращает указатель на список идентификаторов. Аргумент lpbi содержит необходимые данные. Хочу обратить Ваше внимание на некоторую систему, существующую в способах определения данных в WinAPI. Имена структур пишутся прописью (ITEMIDLIST). Простой указатель на эту структуру прибавляет P (PITEMIDLIST). Дальний указатель - LP (LPITEMIDLIST). Дальний константный указатель - LPC (LPCITEMIDLIST).

BROWSEINFO

Надо сказать, помимо того, что эта структура передает иформацию функции SHBrowseForFolder, функция через эту структуру еще и кое-что возвращает. Определение функции выглядит так:

typedef struct _browseinfo { 
HWND hwndOwner;
LPCITEMIDLIST pidlRoot;
LPSTR pszDisplayName;
LPCSTR lpszTitle;
UINT ulFlags;
BFFCALLBACK lpfn;
LPARAM lParam;
int iImage;
} BROWSEINFO, *PBROWSEINFO, *LPBROWSEINFO;

 

  • hwndOwner - Указатель на родительское окно, обычно это главная форма приложения. Реально относительно этого параметра диалог выравнивается. Вполне может быть NULL, тогда дилог выравнивается относительно корневого окна.
  • pidlRoot - Указатель на список идентификаторов, указывающих, от какого каталога показать дерево. Несмотря на то, что определен как LPCITEMIDLIST, в качестве параметра нужно передавать просто LPITEMIDLIST.
  • pszDisplayName - Указатель на область памяти (массив байтов, или NULL-terminated строка), получающих путь выбранной папки выбранной пользователем. Предполагается, что размер массива MAX_PATH байтов.
  • lpszTitle - Указатель на NULL-terminated строку, которая отображается над деревом. Опять-таки может быть равна NULL
  • ulFlags - Целое значение, определяющее поведение диалогового окна. Получается OR-комбинированием следующих значений:
    • BIF_BROWSEFORCOMPUTER - разрешает пользователю выбирать только компьютеры сетевого окружения.
    • BIF_BROWSEFORPRINTER - то же самое с принтерами
    • BIF_DONTGOBELOWDOMAIN - не выходить из домена сети
    • BIF_RETURNFSANCESTORS - возвращать только системные подпапки
    • BIF_RETURNONLYFSDIRS - возвращать только системные папки
    • BIF_STATUSTEXT - разрешает отображение статусного текста.
  • lpfn - Указатель на функцию-обработчик событий диалогового окна. Должна быть типа BrowseCallbackProc, которую мы рассмотрим ниже. Может быть равно NULL.
  • lParam - Любое значение, которое передается функции lpfn при возникновении события.
  • iImage - Получает индекс значка выбранной папки. Это индекс значка в системном списке изображений (IMAGELIST).
 
« Предыдущая статья