我需要的解决方案被99%封装在下面链接的可接受的解决方案中:
How to perform .Onkey Event in an Excel Add-In created with Visual Studio 2010?
但是,它似乎对钩住ALT键无效。我环顾四周并遇到了几个C#示例,但是我是编程的新手,我正在学习VB .NET,因此,以我的知识水平,我无法成功地将代码移植到其他C#示例中以使其在我的计算机中正常工作VB .NET项目。
由于上面链接的代码已经满足了我的所有需求,所以我想继续使用它,但是如果有人可以向我展示如何使其也钩上ALT键,我将不胜感激。我想有一个常数需要以特定的方式传递和检查,但是自找到此解决方案以来的最后4天,我一直无法弄清楚。任何帮助将不胜感激。
非常感谢!
编辑:@Vincent,这是我正在测试的代码,该代码因溢出错误而中断:
>brew upgrade maven
答案 0 :(得分:0)
该答案中的代码并不完全有效,并且没有使用确定修饰符的最佳方法。
由于标准的低级键盘挂钩不起作用,因此我在InputHelper库中添加了LocalKeyboardHook
,该库使用WH_KEYBOARD
挂钩而不是WH_KEYBOARD_LL
。区别在于WH_KEYBOARD
要求您注入DLL并在要挂接的每个进程中指定一个线程。幸运的是,由于您使用的是VSTO加载项,因此InputHelper已随您的加载项一起加载到Excel流程中。
编译后的DLL可以在我项目的 Release 部分中下载:
https://github.com/Visual-Vincent/InputHelper/releases
(您还可以直接从存储库下载InputHelper.vb
源文件)
用法示例:
Imports InputHelperLib
Public Class ThisAddIn
Dim KeyboardHook As InputHelper.Hooks.LocalKeyboardHook
Private Sub ThisAddIn_Startup() Handles Me.Startup
KeyboardHook = New InputHelper.Hooks.LocalKeyboardHook
AddHandler KeyboardHook.KeyDown, AddressOf KeyboardHook_KeyDown
AddHandler KeyboardHook.KeyUp, AddressOf KeyboardHook_KeyUp
End Sub
Private Sub ThisAddIn_Shutdown() Handles Me.Shutdown
If KeyboardHook IsNot Nothing Then KeyboardHook.Dispose()
End Sub
Private Sub KeyboardHook_KeyDown(sender As Object, e As InputHelper.Hooks.KeyboardHookEventArgs)
If e.Modifiers = InputHelper.ModifierKeys.Alt AndAlso e.KeyCode = System.Windows.Forms.Keys.M Then
System.Windows.Forms.MessageBox.Show("ALT + M was pressed!")
End If
End Sub
Private Sub KeyboardHook_KeyUp(sender As Object, e As InputHelper.Hooks.KeyboardHookEventArgs)
If e.Modifiers = InputHelper.ModifierKeys.Alt AndAlso e.KeyCode = System.Windows.Forms.Keys.M Then
System.Windows.Forms.MessageBox.Show("ALT + M was released!")
End If
End Sub
End Class