Чтобы узнать атрибуты данного объекта или нескольких объектов, необходимо вызвать метод GetAttributesOfинтерфейса IShellFolderпапки-владельца. При этом перед вызовом этого метода необходимо установить те атрибуты, значения которых Вы бы хотели выяснить. Если запрошены атрибуты нескольких элементов, то метод вернёт только те значения атрибутов, которые совпадают у всех переданных элементов. В частности, Вы сможете взять интерфейс IShellFolderтолько от тех объектов, которые имеют атрибут SFGAO_FOLDER. Вы можете обновить информацию об элементах, входящих в папку, использовав флаг SFGAO_VALIDATE.
Дополнительные возможности
Прежде всего, Ваше приложение всегда можете получить строку с именем объекта, представленном в удобном для Вас формате. Для этого интерфейс IShellFolderпредоставляет метод GetDisplayNameOf.
Вы можете указать один из следующих требующихся форматов:
SHGDN_NORMAL |
Обычный формат представления; |
SHGDN_INFOLDER |
Формат представления относительно данной папки; |
SHGDN_INCLUDE_NONFILESYS |
Приложение заинтересовано в именах элементов всех типов. Если этот флаг не установлен, то приложение заинтересовано лишь в тех элементах, которые представляют часть файловой системы. Если этот флаг не установлен, и элемент не представляет собой часть файловой системы, то этот метод может быть выполнен неудачно; |
SHGDN_FORADDRESSBAR |
Имя будет использовано для показа в адресном комбобоксе; |
SHGDN_FORPARSING |
Формат представления, используемый для дальнейшего разбора имени; |
Имя элемента, полученное с установленным флагом SHGDN_FORPARSING, имеет особое значение. Вы можете использовать такое имя как командную строку для запуска приложения. Говоря точнее – такое имя эквивалентно понятию пути файловой системы.
Интерфейс IShellFolderпредоставляет метод SetNameOf, позволяющий изменить экранное имя файлового объекта или вложенной папки. Изменяя экранное имя элемента, Вы изменяете его идентификатор, поэтому функция возвращает PIDL-указательна новый идентификатор. Изменение экранного имени файлового объекта приводит к его фактическому переименованию в файловой системе.
Интерфейс IShellFolderтакже предоставляет метод ParseDisplayName, который позволяет узнать идентификатор элемента по его имени. Этому методу необходимо передавать имя, сгенерированное методом GetDisplayNameOfс установленным флагом SHGDN_FORPARSING.
С помощью глобального метода SHGetPathFromIDListпо списку идентификаторов, определяющих объект относительно корня пространства имён, можно определить путь к объекту файловой системы.
С помощью глобального метода SHAddToRecentDocsВаше приложение может добавить документ к списку последних, с которыми работал пользователь, или очистить этот список.
С помощью глобального метода SHEmptyRecycleBin, появившегося в версии 4.71 оболочки windows, Ваше приложение может очистить корзину (recycle bin). Удаление файла в корзину (то есть – с возможностью дальнейшего восстановления) производится глобальным методом SHFileOperation, подробное описание которого выходит за рамки этого обзора. Вы также можете узнать количество объектов, расположенных в корзине, и их суммарный размер, с помощью метода SHQueryRecycleBin.
Примечания
Microsoft Visual C++ поставляется с файлами заголовков и поддержки COM, в которых определены шаблон класса _com_ptr_t, инкапсулирующий функциональность ссылки на com-объект, и самые распространённые специализации этого шаблона (в том числе для большинства стандартных интерфейсов пространства имён оболочки). При их использовании освобождение ссылок автоматизируется.
Copyright 1999 by Akzhan Abdulin. При публикации просьба указывать источник и авторство.
Комментарии, исправления, замечания и пожелания приветствуются по адресу: akzhan@beep.ru.
ВОПРОС-ОТВЕТ
Q. У меня одна проблема: Пишу одну программку (написал уже довольно много) используя Win32API. И у меня возникла проблема со ScrollBar'ами. Вся загвоздка в том, что позиция бегунка прокрутки описана как short int и соответственно лежит в двухбайтном диапазоне. А в моей программе диапазон прокрутки может быть больше чем 32767. В хелпе на сообщение WM_VSCROLL советуют использовать функцию GetScrollPos, у меня че-то не получилось ее использовать. Как решить эту проблему?
Алексей Иванов
A 1 При работе с 32-битными значениями позиции бегунка значение nPos, передаваемое обработчику OnHScroll некорректно, для получения реального значения можно использовать ф-цию GetScrollPos, либо GetScrollInfo [возвращается в scrollinfo.nPos]. Однако, при обработке случая nSBCode==SB_THUMBTRACK, правильное значение текущей позиции возможно получить лишь при вызове GetScrollInfo(). Это значение будет возвращено в поле scrollinfo.nTrackPos;
Читать дальше