Пятница, 27.06.2025
Королевство Delphi
Главное меню
Статьи
Наш опрос
Как часто ви на этот сайт заходите?
Всего ответов: 159
Статистика
Онлайн всего: 1
Гостей: 1
Пользователей: 0
Форма входа
Главная » Статьи » Система » Разное

Интерфейс IShellLink

Этот интерфейс представляет собой средство для создания и управления ярлыками (shortcuts). Все читатели этой главы наверняка создавали и перемещали ярлыки для наиболее нужных программ, файлов и папок — на рабочем столе, в главном меню и т. д. С точки зрения ОС эти действия — не что иное, как создание и изменение свойств СОМ-объекта.

Каждый ярлык содержит следующую информацию: 

  • путь к объекту, на который ссылается ярлык (Path);
  • рабочий каталог для этого объекта (Working Directory);
  • список параметров, передаваемый объекту при его активизации (Arguments);
  • начальное состояние окна, соответствующего объекту (нормальное, минимизированное, максимизированное) (ShowCmd);
  • путь к значку, соответствующему объекту (Icon Location);
  • описание объекта (Description);
  • сочетание "горячих" клавиш (HotKey).

Для всех этих свойств ярлыка в интерфейсе дано по паре методов — один для чтения, другой для установки значения:

 IShellLink = interface(lUnknown) 
 { si }
 [SID_IShellLinkA]
 function GetPath(pszFile: PAnsiChar;
 cchMaxPath: Integer; var pfd: TWin32FindData; 
 fFlags: DWORD): HResult; stdcall;
 function GetlDList(var ppidl: PItemlDList): HResult; stdcall;
 function SetlDList(pidl: PItemlDList): HResult;
 stdcall;
 function GetDescription(pszName: PAnsiChar; 
 cchMaxName: Integer): HResult;
 stdcall;
 function SetDescription(pszName: PAnsiChar): HResult; stdcall;
 function GetWorkingDirectory(pszDir: PAnsiChar; cchMaxPath: Integer): HResult; stdcall;
 function SetWorkingDirectory(pszDir: PAnsiChar): HResult; stdcall;
 function GetArguments(pszArgs: PAnsiChar; cchMaxPath: Integer): HResult; stdcall;
 function SetArguments(pszArgs: PAnsiChar): HResult; stdcall;
 function GetHotkey(var pwHotkey: Word): HResult; stdcall;
 function SetHotkey(wHotkey: Word): HResult; stdcall;
 function GetShowCmd(out piShowCmd: Integer): HResult; stdcall;
 function SetShowCmd(iShowCmd: Integer): HResult; stdcall;
 function GetIconLocation(pszIconPath: PAnsiChar; cchlconPath: Integer; out pilcon: Integer): HResult; stdcall;
 function SetlconLocation(pszIconPath: PAnsiChar; ilcon: Integer): HResult; stdcall;
 function SetRelativePath(pszPathRel: PAnsiChar; dwReserved: DWORD): HResult; stdcall;
 function Resolve(Wnd: HWND; fFlags: DWORD): HResult; stdcall; 
 function SetPath(pszFile: PAnsiChar): HResult; stdcall; 
 end; 

Сохраним ярлык для данной программы-примера где-нибудь на диске, скажем, в той же самой папке. Для этого создадим новый объект NewLink класса CLSiD_shellLink, предоставляющий нам нужный интерфейс:

 procedure TForml.ButtonlClick(Sender: TObject);
 var NewLink : IShellLink; 
 fn, fp : string; ws : WideString; hRes : THandle;
 pf : IPersistFile;
 begin
 NewLink := CreateComObject(CLSID_ShellLink) as IShellLink; fn := ParamStr(O); NewLink.SetPath(pchar(fn)); 
 fp := ExtractFilePath(fn); NewLink.SetWorkingDirectory(pchar(fp)); NewLink.SetDescription
 (pChar(Application.Title)); 
 ws := fp+Application.Title+'.Ink';
 hRes := NewLink.Querylnterface(IID__IPersistFile, pf) ; if Succeeded(hRes) then
 pf.Save(pWideChar(ws),False);
 end; 

В этом примере помимо IShellLink нужно получить доступ к интерфейсу IPersistFile, который "умеет" записывать данные. Задав параметры ярлыка, мы записываем его на диск. При этом проверяется тот факт, что созданный нами объект поддерживает интерфейс IPersistFile. Если указатель на этот интерфейс получен, вызывается его метод save.

Среди перечисленных выше методов IShellLink особое внимание уделим методу Resolve. Он понадобится вам при получении указателя на интерфейс уже существующих ярлыков. Windows пытается вести себя "разумно" и отслеживает перемещения и переименования объекта, на который указывает существующий IShellLink. Но если вы записали содержимое ярлыка в поток (или на диск), то отследить соответствие ярлыка объекту должны сами, вызвав метод Resolve. Если объект, на который ссылается ярлык, по-прежнему находится на своем месте, метод немедленно завершается с нормальным кодом возврата. Если файл или объект перемещен или переименован, начинается его поиск.

Знакомая картина, не правда ли? Особенно часто она наблюдается в том случае, если пользователь не выработал у себя привычки правильно деинсталлировать раздобытый где-то "софт", стирая его "по старинке". Между тем, за привычным диалоговым окном на рисунке стоит вызов метода ishellLink. Resolve. Если в пределах досягаемости поиска окажется файл с тем же именем и размерами, ярлык будет автоматически переадресован на него; в противном случае пользователю будет предложено использовать ближайший по характеристикам файл из просмотренных. Если вы вообще не хотите, чтобы пользователь вмешивался в процесс отыскания соответствия, при вызове метода Resolve в параметре fFlags укажите значение SLR_NO_UI — диалоговое окно появляться в этом случае не будет.

Если вы внимательно изучили рабочий стол своего компьютера, то должны были заметить там ярлыки, ссылающиеся не на файлы, а на специальные объекты — "Мой компьютер", "Сетевое окружение", "Принтеры" и т. п. Чтобы создать такой ярлык самому, нужно обращение к методу setiDList. В качестве параметра ему передается структура pitemiDList (pidi). О том, где ее взять и как заполнить, рассказано в следующем разделе.

Получить ссылку на материал

Категория: Разное | Добавил: Барон (09.12.2011)
Просмотров: 1124 | Теги: интерфейс, IShellLink | Рейтинг: 0.0/0
[ Пожертвования для сайта ] [ Пожаловаться на материал ]

Если вам помог материал сайта кликните по оплаченной рекламе размещенной в центре

Поиск
Категории раздела
ActiveX [10]
CORBA и COM [16]
Kol и MCK [23]
WinAPI [28]
Компоненты [27]
Работа с Bluetooth [4]
Железо [8]
Текст [18]
Разное [98]
Королевство Delphi © 2010-2025
Яндекс цитирования