这段代码是一个实现 HRContextMenu 类中 EnumSubCommands 方法的示例。它的功能是在上下文菜单中枚举子命令,通常用于 Windows Shell 扩展或上下文菜单扩展。
代码解析
函数签名:
IFACEMETHODIMP HRContextMenu::EnumSubCommands(IEnumExplorerCommand** ppEnum)IFACEMETHODIMP: 用于标识接口方法的返回类型。IEnumExplorerCommand** ppEnum: 输出参数,用于返回命令枚举器的指针。
创建命令向量:
std::vector<winrt::com_ptr<IExplorerCommand>> subCommands;- 创建一个向量来存储子命令,这里使用了
winrt::com_ptr来管理 COM 对象的生命周期。
- 创建一个向量来存储子命令,这里使用了
注册表检查:
if (RegistryControllerClass::KeyExists(HKEY_LOCAL_MACHINE, HR_CONTEXT_MENU_REGISTRY)) { RegistryControllerClass reg(HKEY_LOCAL_MACHINE, HR_CONTEXT_MENU_REGISTRY); if (reg.GetDwordValue(HR_FILESHRED_REGISTRY)) { subCommands.push_back(winrt::make<FileShredContextMenu>().as<IExplorerCommand>()); subCommands.push_back(winrt::make<UnlockFileContextMenu>().as<IExplorerCommand>()); } if (reg.GetDwordValue(HR_SCANVIRUS_REGISTRY)) { subCommands.push_back(winrt::make<ScanVirusContextMenu>().as<IExplorerCommand>()); } }- 检查指定的注册表键是否存在。如果存在,进一步检查特定值,以决定是否添加对应的上下文菜单项(如文件粉碎、解锁文件和扫描病毒)。
创建并返回枚举器:
auto enumCommands = winrt::make_self<BaseEnumCommand>(move(subCommands)); *ppEnum = enumCommands.detach(); return S_OK;- 使用
winrt::make_self创建一个自定义枚举器对象,并将之前收集到的子命令传递给它。然后将其指针赋值给输出参数ppEnum,最后返回成功状态S_OK。
- 使用
总结
该方法动态构建一个包含子命令的集合,并通过注册表设置决定哪些命令可用。这种方法在创建 Windows Shell 扩展时非常常见,通过这种方式可以灵活地为用户提供不同功能的上下文菜单选项。
如果你有具体的问题或需要更深入地理解某个部分,请告诉我!
内容由零声教学AI助手提供,问题来源于学员提问




