在VBA中,如何将键盘快捷键恢复为默认设置?

5
在我的 VBA Excel 插件中,我允许用户为我的公共宏分配任意键盘快捷键。我允许他们在运行时更改这些快捷键 (实际上,他们会更改配置文件,然后重新加载它)。我使用 Application.OnKey 来完成这个操作。
如果用户在运行时更改了快捷键,如何恢复旧键盘快捷键的默认定义呢?
例如,如果我已经通过编程方式将 ^S 分配给一个宏,然后将其更改为 ^E,我该如何将 ^S 恢复到原来的 Excel “保存”行为呢?

出于向后兼容性的考虑,我需要能够支持一些覆盖默认行为的快捷方式;我至少必须允许使用^S、^D和^B选项,我知道它们都有默认行为。 - Josh
1个回答

11

若要将通过OnKey定义的按键返回到默认设置,可以将其不带任何过程定义。

这将把CTRL+S设置为"SpecialPrintProc"。

Application.OnKey "^S", "SpecialPrintProc" 

这将CTRL+S恢复其正常含义。

Application.OnKey "^S" 

这会禁用 CTRL+S

Application.OnKey "^S", "" 

2
有没有一种方法可以同时重置所有键? - Josh
我没有看到任何方法可以做到这一点,除了完全退出Excel(关闭工作簿本身不起作用,因为如果Excel仍在运行,它将记住分配)。 - SeanC
我想我必须限制用户的选项,并通过我的Auto_Close列表将它们重置为默认值。 - Josh

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接