CreateLnk & ResolveLnk CreateLnk & ResolveLnk 本文介绍的两个函数,其原型声明如下,具体实现可以在源代码中找到,我只简要介绍一下用法。
function ResolveLnk( Wnd : HWnd; lpszLinkFile : PChar; lpszPath, lpszArgs, lpszWorkDir, lpszIconPath, lpszDescription : PChar; piIcon, piShowCmd, piSpecial : PInteger) : HResult;
function CreateLnk( Wnd : HWnd; const SrcFile, DstPath, WorkDir, Description : String ) : HResult;
ResolveLnk接收lpszLinkFile作为快捷方式的源文件名,解析后的目标文件名保存在lpszPath中,其余参数只需形式上定义一个变量传入即可。
Var lpszLinkFile, lpszPath, lpszArgs, lpszWorkDir, lpszIconPath, lpszDescription: array[0..MAX_PATH] of Char; piIcon, piShowCmd, piSpecial: PInteger; …… ResolveLnk(0, lpszLinkFile, lpszPath, lpszArgs, lpszWorkDir, lpszIconPath, lpszDescription, piIcon, piShowCmd, piSpecial);
--------------------------------------------------------------------------------------
CreateLnk比较简单,SrcFile, DstPath分别是源文件名和希望建立的快捷方式文件名,Description是对该快捷方式的描述,举例如下:
CreateLnk(Handle,'c:/app.exe','c:/LinkToApp.lnk','c:/','ShortCut to app.exe') ;
WorkDir在Windows帮助中是这样说的:指定包含原始项目或一些相关文件的文件夹。有时,程序需要使用其他位置的文件。这时需要您指定这些文件所在的文件夹,以便程序能够找到它们。 建立快捷方式还可以使用下面的过程:
procedure CreateShortCut(sName: string; dPath: integer; dName: widestring); var tmpObject : IUnknown; tmpSLink : IShellLink; tmpPFile : IPersistFile; PIDL : PItemIDList; StartupDirectory : array[0..MAX_PATH] of Char; StartupFilename : String; LinkFilename : WideString; begin coInitialize(nil); StartupFilename := sName; tmpObject := CreateComObject(CLSID_ShellLink); //创建建立快捷方式的外壳扩展 tmpSLink := tmpObject as IShellLink; //取得接口 tmpPFile := tmpObject as IPersistFile; //用来储存*.lnk文件的接口 tmpSLink.SetPath(pChar(StartupFilename)); //设定.exe所在路径 tmpSLink.SetWorkingDirectory( pChar(ExtractFilePath(StartupFilename))); //设定工作目录 SHGetSpecialFolderLocation(0,dPath,PIDL); //获得dPath的Itemidlist SHGetPathFromIDList(PIDL,StartupDirectory); //获得dPath路径 LinkFilename := StartupDirectory + dName; tmpPFile.Save(pWChar(LinkFilename),FALSE); //保存*.lnk文件 CoUninitialize end;
应用举例,把快捷方式建立到“SendTo”目录:
CreateShortCut('c:/app.exe', CSIDL_SENDTO, 'c:/LinkToApp.lnk');
发表于“阿甘的家”2000年8月15日