通常在Windows环境中选定某个应用程序后按鼠标右键,即可从快捷菜单中创建该应用程序的快捷方式,也就是生成(.lnk)的文件,请问我怎样在Visual C++程序中实现生成某个应用程序的快捷方式,(.lnk)具有怎样的文件结构.非常谢谢您的指导.

eknight 2000-06-28 08:32:00
通常在Windows环境中选定某个应用程序后按鼠标右键,即可从快捷菜单中创建该应用程序的快捷方式,也就是生成(.lnk)的文件,请问我怎样在Visual C++程序中实现生成某个应用程序的快捷方式,(.lnk)具有怎样的文件结构.非常谢谢您的指导.
...全文
304 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
eknight 2000-06-28
  • 打赏
  • 举报
回复
谢谢前面俩位大哥了,有机会一定请你们喝酒!
xielm 2000-06-28
  • 打赏
  • 举报
回复
创建和读取快捷方式是通过COM,看下面的例子:

HRESULT CreateLink(HWND hwnd)
{
HRESULT r = CoInitialize(NULL);


IShellLink* psl;
IPersistFile* ppf;
r = CoCreateInstance(CLSID_ShellLink, NULL,
CLSCTX_INPROC_SERVER, IID_IShellLinkA,(LPVOID *) &psl);

// read short cut

r = psl->QueryInterface(IID_IPersistFile,(void **) &ppf);
if (SUCCEEDED(r)) {
WORD wsz[MAX_PATH]; // Ensure that the string is ANSI.
MultiByteToWideChar(CP_ACP, 0, "C:\\WINDOWS\\Desktop\\s.lnk", -1,
wsz, MAX_PATH);
// Save the link by calling IPersistFile::Save.
r = ppf->Load (wsz,STGM_READWRITE);

char szFile[255];
WIN32_FIND_DATA fd;


psl->GetPath(szFile,255,&fd,SLGP_UNCPRIORITY);
psl->GetArguments(szFile,255);
ppf->Release();
}

/*create shortcut
psl->SetPath("c:\\windows\\notepad.exe");
psl->SetDescription("snotepad");
psl->SetWorkingDirectory("c:\\windows");
WORD key;
key = (HOTKEYF_CONTROL << 8) | (HOTKEYF_ALT << 8) | 0x42;
psl->SetHotkey(key);
// Query IShellLink for the IPersistFile interface for saving the
// shortcut in persistent storage.
r = psl->QueryInterface(IID_IPersistFile,(void **) &ppf);
if (SUCCEEDED(r)) {
WORD wsz[MAX_PATH]; // Ensure that the string is ANSI.
MultiByteToWideChar(CP_ACP, 0, "C:\\WINDOWS\\Desktop\\s.lnk", -1,
wsz, MAX_PATH);
// Save the link by calling IPersistFile::Save.
r = ppf->Save(wsz, TRUE);
ppf->Release(); }
psl->Release(); return r;

*/
CoUninitialize();
return r;
}
Jackzhu 2000-06-28
  • 打赏
  • 举报
回复
使用CoCreateInstance()
得到IShellLink,即可设置快捷方式内容了
在Excel使用过程,运用一些技巧会使得我们的工作效率提高很多。而这些技巧往往又被忽略或忘记怎么去使用。本套课程基于此整理了一些Excel方面的技巧,这些呢为学习笔记集锦,前后章内容不存在连贯性,仅整理一些常用的技巧与大家分享。l  本课程知识点l  第1节:概述、使用excel必会技巧之隐藏自己的工作表l  第2节:excel单元格任意区域禁止输入重复值设置技巧l  第3节: 一键快速删除工作表重复数据l  第4节:追踪所引用的单元格,查找数据来源l  第5节: 自动查找工作表的错误数据l  第6节:快速在单元格创建下拉按钮,内容直接选择不需输入l  第7节: 自动选择不重复的数据并复制到指定位置l  第8节:光标进入单元格时自动弹出提示内容l  第9节: 使用特殊符号将单元格内容分列并复制到指定区域l  第10节: Excel鼠标模式和触摸模式自由切换l  第11节:快速冻结首行和首列单元格l  第12节: 将打印预览和打印添加到快捷操作栏上l  第13节: 在录入日期的时候限制日期范围,错误则弹出提示l  第14节: Excel内置的屏幕截图工具操作方法l  第15节:插入注册商标符号及特殊符号l  第16节:在Excel工作表插入艺术字并对艺术字特殊效果处理l  第17节: 对excel工作表的多列数据同时排序l  第18节: 将选定的区域放大到恰好容纳位置l  第19节:按姓名或文汉字笔画进行排序l  第20节: 按单元格颜色进行排序l  第21节:excel按行也可以排序l  第22节: excel的数据快速条件筛选l  第23节:巧妙删除带有空格的单元格所在的行的内容l  第24节: 巧用辅助列进行筛选l  第25节:对文汉字繁体字和简体字快速转换l  第26节: 隐藏最近使用的文件列表l  第27节:使用图标或等级符号标记单元格l  第28节: 自动套用主题单元格样式l  第29节: 插入超链接删除超链接l  第30节:绘图格式形状效果形状轮廓

16,472

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧