【问题标题】:In VBA how do I restore keyboard shortcut to default?在 VBA 中,如何将键盘快捷键恢复为默认值?
【发布时间】:2020-02-27 18:31:53
【问题描述】:

在我的 VBA Excel 插件中,我允许用户为我的公共宏分配任意键盘快捷键。我允许他们在运行时更改这些快捷方式(实际上,他们更改了配置文件然后重新加载它)。我使用Application.OnKey 来执行此操作。

如果用户在运行时更改了快捷键,如何恢复旧键盘快捷键的任何先前默认定义?

例如,如果我以编程方式将^S 分配给宏,然后将其更改为^E,如何将^S 恢复为原始Excel“保存”行为?

【问题讨论】:

  • 我应该提到,出于向后兼容的原因,我需要能够支持一些覆盖默认行为的快捷方式;我必须至少允许 ^S、^D 和 ^B 选项,我知道它们都有默认行为。

标签: vba keyboard-shortcuts


【解决方案1】:

要将通过OnKey 定义的键恢复为默认值,请在没有过程的情况下定义它。

这会将 CTRL+S 设置为“SpecialPrintProc”

Application.OnKey "^S", "SpecialPrintProc" 

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

Application.OnKey "^S" 

这会禁用 CTRL+S

Application.OnKey "^S", "" 

【讨论】:

  • 有没有办法一次重置所有键?
  • 我没有看到任何方法可以做到这一点,除了完全退出 excel(关闭工作簿本身不起作用,好像 excel 仍在运行,它会记住分配)。
  • 我想我将不得不限制用户的选项,然后通过我的 Auto_Close 列表将它们重置为默认值。
猜你喜欢
  • 1970-01-01
  • 2012-03-07
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多