gpt4 book ai didi

objective-c - cocoa 事件水龙头

转载 作者:行者123 更新时间:2023-12-03 16:35:45 25 4
gpt4 key购买 nike

我正在尝试在 OS X 上使用 Quartz 事件服务(特别是事件点击)来捕获由连接到剥离键盘 PCB 的无源红外传感器生成的模拟按键。理论上,通过事件点击,我可以选择吞下并忽略按键,只需使用键盘输入来“唤醒”计算机。我还可以使用事件点击(仅连接一个“键”,因此运动检测器始终发送“0”)将输入修改为任意键或键组合,进而调用主机上的任意功能。让事情变得更复杂的是,最终主机是一台旧的 G4 Powerbook (PPC),它无法真正运行 OS X 10.4 之外的任何东西,而我当前的开发机器是一台更新的基于 Intel 的 iMac,运行 10.9 并使用 Xcode 5.1。 1.

我从答案 here 中找到了以下代码,看起来就很完美了。如果我在 Cocoa 中创建一个终端应用程序,我基本上可以按原样使用代码。我还尝试创建一个基于窗口的 Cocoa 应用程序,以防需要将该应用程序添加到可在安全/隐私首选项下“控制”计算机的辅助功能应用程序列表中(Mavericks 中不推荐启用辅助设备访问)。这两种应用程序类型都不能完全运行。我能够实现的最好的结果是让程序识别修饰键(命令、选项、Shift、ctl 等)的按键,但是我无法从“常规”键盘按键的按键中得到任何响应,并且我似乎无法实际更改捕获的关键事件。此外,似乎鼠标事件,特别是鼠标单击,注册为 KeyUp 和 KeyDown 事件 - 即使我将事件掩码从“AllEvents”更改为“KeyUp”或“KeyDown”。

这是我对原始代码稍作修改的版本,旨在尝试符合 Xcode 5 约定。正如您所看到的,繁重的工作是在 applicationDidFinishLaunching 方法中,而不是原始的 main() 方法中。显然,我必须在 AppDelegate.h 文件中创建一个方法声明,这也不是原始代码的一部分。

#import "AppDelegate.h"
#import <Cocoa/Cocoa.h>
#import <ApplicationServices/ApplicationServices.h>
#include <Carbon/Carbon.h>


@implementation AppDelegate

CGEventRef myCGEventCallback(CGEventTapProxy proxy, CGEventType type, CGEventRef event, void *refcon) {
NSLog(@"In the callback");
//0x0b is the virtual keycode for "b"
//0x09 is the virtual keycode for "v"
if ((type != kCGEventKeyDown) && (type != kCGEventKeyUp))
NSLog(@"event: %@", event);
if (CGEventGetIntegerValueField(event, kCGKeyboardEventKeycode) == kVK_ANSI_S) {
NSLog(@"event matched");
CGEventSetIntegerValueField(event, kCGKeyboardEventKeycode, kVK_ANSI_1);
}

return event;
}

- (void)applicationDidFinishLaunching:(NSNotification *)aNotification
{
NSLog(@"Hello?");

CFRunLoopSourceRef runLoopSource;

CFMachPortRef eventTap = CGEventTapCreate(kCGHIDEventTap, kCGHeadInsertEventTap, kCGEventTapOptionDefault, kCGEventMaskForAllEvents, myCGEventCallback, NULL);

if (!eventTap) {
NSLog(@"Couldn't create event tap!");
exit(1);
}

runLoopSource = CFMachPortCreateRunLoopSource(kCFAllocatorDefault, eventTap, 0);

CFRunLoopAddSource(CFRunLoopGetCurrent(), runLoopSource, kCFRunLoopCommonModes);

CGEventTapEnable(eventTap, true);

CFRunLoopRun();

CFRelease(eventTap);
CFRelease(runLoopSource);

NSLog(@"goodbye");
}

@end

此时,我只是尝试在 10.9 上运行一些东西,作为概念证明,然后再尝试向后移植到 10.4 兼容性。抱歉发了这么长的帖子。第一次在这里寻求帮助,只是想彻底。预先感谢您的所有回复!

最佳答案

好的,所以我对解决方案的追求引导我到 this发布于堆栈溢出。特别令人感兴趣的是下面突出显示的代码。

NSDictionary *options = @{(id)kAXTrustedCheckOptionPrompt: @YES};
BOOL accessibilityEnabled = AXIsProcessTrustedWithOptions((CFDictionaryRef)options);

这是 10.9 Mavericks 中新 API 的一部分。将其添加到混合中会导致出现 Sys Pref/Deny 提示,最终 Xcode 本身被添加到列表中,而不是我正在处理的编译应用程序(我从未想过这一点)。即使注释掉这段代码后,它仍然有效,显然因为 Xcode 现在位于白名单中,并且只需要完成一次。所以概念验证就在眼前。

它似乎也适用于 10.4。有几个错误。我不确定这部分是否必要,但我在 Powerbook 上下载并安装了 Xcode 2.5,并直接在主机上创建和编译应用程序。有两个问题似乎与常数有关。 CGEventTapCreate 函数中的 kCGEventTapOptionDefault 常量(似乎它可以很容易地是一个 BOOL 而不是 uINT)在 10.4 框架头中没有定义,因此除非将其更改为 0 或 1,否则将会出现错误。这似乎同样适用于在较新系统上的 Carbon header 中定义的 kVC 虚拟键代码常量。相反,我只是坚持使用十六进制值。最后,请大家鼓掌,不要错误地尝试将远程桌面按键注册为远程系统上的 KeyUp 或 KeyDown 事件。它不起作用,所以最后我有了一个好主意,走到 G4 并插入键盘(G4 向后弯曲一半并卡在墙上,因此,从前面看,它看起来只是一个安装在 G4 上的 LCD墙)。瞧。完美。

关于objective-c - cocoa 事件水龙头,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25240297/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com