- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图通过Rust中的CGWindowListCopyWindowInfo获取窗口所有者名称。到目前为止,我已经设法获取CFDictionaryRef,但是我无法为使用正确的指针CFDictionaryGetValueIfPresent 。
这是方法签名:https://docs.rs/CoreFoundation-sys/0.1.4/CoreFoundation_sys/dictionary/fn.CFDictionaryGetValueIfPresent.html
const options: CGWindowListOption = kCGWindowListOptionOnScreenOnly + kCGWindowListExcludeDesktopElements;
const ptr_window_list_info: CFArrayRef = unsafe { CGWindowListCopyWindowInfo(options, kCGNullWindowID) as CFArrayRef };
const count = unsafe { CFArrayGetCount(ptr_window_list_info) };
for i in 0..count-1 {
let dic_ref = CFArrayGetValueAtIndex(ptr_window_list_info, i) as CFDictionaryRef;
//let key = CFString::new("kCGWindowOwnerName");
let b = CFDictionaryGetValueIfPresent(dic_ref, ?, ?);
println!("window owner name: {}", value);
}
最佳答案
CFDictionaryGetValueIfPresent
看起来像这样:Boolean CFDictionaryGetValueIfPresent(CFDictionaryRef theDict, const void *key, const void **value);
在core_foundation中,它看起来像这样:
pub unsafe extern "C" fn CFDictionaryGetValueIfPresent(
theDict: CFDictionaryRef,
key: *const c_void,
value: *mut *const c_void
) -> Boolean
CFStringRef
;在C语言中,有一个宏可以简化操作(
CFSTR("cstring")
),在这里我们必须使用稍长一点的形式:
let c_key = CString::new("kCGWindowOwnerName").unwrap();
let cf_key = unsafe {
CFStringCreateWithCString(std::ptr::null(), c_key.as_ptr(), kCFStringEncodingUTF8)
};
CFStringRef
,在core_foundation中它是这样定义的:
pub type CFStringRef = *const __CFString;
*const
指针,而不仅仅是我们需要的类型。您可以改为转成
c_void
:
let key_ptr: *const c_void = unsafe { std::mem::transmute(cf_key) };
let mut value: *const c_void = std::ptr::null();
&mut value
)以获取
*mut *const c_void
。
use core_graphics::display::*;
use core_foundation::string::*;
use std::ffi::{ CStr, CString, c_void };
fn main() {
// CGWindowListOption is a bitmask, combine the flags with bitwise OR
const OPTIONS: CGWindowListOption = kCGWindowListOptionOnScreenOnly | kCGWindowListExcludeDesktopElements;
// No need to specify the type or use 'as'; CFArrayRef is the return type from CGWindowListCopyWindowInfo
let window_list_info = unsafe { CGWindowListCopyWindowInfo(OPTIONS, kCGNullWindowID) };
// Don't use const here, CFArrayGetCount returns CFIndex (long)
let count: i64 = unsafe { CFArrayGetCount(window_list_info) };
for i in 0..count-1 {
// Here we need the 'as', CFArrayGetValueAtIndex just returns void*
let dic_ref = unsafe { CFArrayGetValueAtIndex(window_list_info, i) as CFDictionaryRef };
// Create a CString from the key name we are interested in
let c_key = CString::new("kCGWindowOwnerName").unwrap();
// Create a CFString, needs to be released with `CFRelease`. I leave that as an exercise for the reader.
let cf_key = unsafe { CFStringCreateWithCString(std::ptr::null(), c_key.as_ptr(), kCFStringEncodingUTF8) };
// cf_key is a CFStringRef, which is a type alias to *const __CFString
// We transmute it into *const c_void since that is what CFDictionaryGetValueIfPresent wants
let key_ptr: *const c_void = unsafe { std::mem::transmute(cf_key) };
// A raw void* to hold the result
let mut value: *const c_void = std::ptr::null();
if unsafe { CFDictionaryGetValueIfPresent(dic_ref, key_ptr, &mut value) != 0 } {
// CFDictionaryGetValueIfPresent returned true; that means value must point to a CFStringRef
let cf_ref = value as core_foundation::string::CFStringRef;
// Get a pointer to a C-string buffer with the characters from the CFString
let c_ptr = unsafe { CFStringGetCStringPtr(cf_ref, kCFStringEncodingUTF8) };
// The value may be null; don't pass it to CStr::from_ptr
if c_ptr.is_null() { continue; }
// Wrap the pointer in a rust CStr so we can convert a str
let c_value = unsafe { CStr::from_ptr(c_ptr) };
println!("{}", c_value.to_str().unwrap());
}
}
}
#import <Foundation/Foundation.h>
#import <CoreGraphics/CoreGraphics.h>
int main(int argc, const char * argv[]) {
@autoreleasepool {
CGWindowListOption options = kCGWindowListOptionOnScreenOnly | kCGWindowListExcludeDesktopElements;
CFArrayRef windows = CGWindowListCopyWindowInfo(options, kCGNullWindowID);
CFIndex count = CFArrayGetCount(windows);
for (int i = 0; i < count; i++)
{
CFDictionaryRef windowDict = CFArrayGetValueAtIndex(windows, i);
CFStringRef key = CFStringCreateWithCString(NULL, "kCGWindowOwnerName", kCFStringEncodingUTF8);
const void* value = nil;
if (CFDictionaryGetValueIfPresent(windowDict, key, &value) == YES)
{
const char* c_value = CFStringGetCStringPtr(value, kCFStringEncodingUTF8);
NSLog(@"window: %s", c_value);
}
CFRelease(key);
}
}
return 0;
}
关于macos - 通过Rust中的CGWindowListCopyWindowInfo获取窗口所有者名称,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60117318/
在跨平台应用程序中,我正在使用一个配置文件,允许用户根据需要覆盖各种默认值。 我的问题是...在哪里放置/查找此配置文件,尤其是关于 MacOS X(我从未使用过且无法访问)?我知道 MacOS X
由于Xcode的代码签名和存档非常耗时,枯燥且有问题,因此我一直通过自己的脚本使用命令行工具xcodebuild,codesign等对我的开发人员ID签名的macOS应用进行代码签名,存档和交付。公证
我正在寻找一种在 MacOs 应用程序中以编程方式逐帧绘制动画的方法(不是关键帧属性动画)。我尝试使用drawLayer:inContext:委托(delegate)方法绘制到CALayers,调用s
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我在83%的安装openCV中遇到问题...我的python是2.7.3。我已经适应了xcode。我使用了这个tuturial。 我的Cmake: cmake -D CMAKE_BUILD_TYPE=
我需要弄清楚 Mac 的日志键的键码(ctrl、shift 等)或者需要知道如何跟踪这个日志按键事件... 基本上我正在将 mac key 代码转换为等效的 Windows key 代码......我
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 2年前关闭。 Improve thi
我想将一个 Rust 程序从我的 x86 Mac 交叉编译成一个可以在 Silicon Mac 上运行的二进制文件,但我无法弄清楚链接。 我有: 运行 macOS 10.15.7 Catalina 的
在 macOS ventura 中,我无法复制我的终端应用程序。 我想这样做,因为我有一个 M1 处理器,我想要一个使用 Rosetta2 打开的处理器和一个本地打开的处理器。 有什么办法解决这个问题
当您可以访问实际硬件时,在 Mac 上以安全模式启动是很容易的。您只需在启动时按住 shift 键即可。 在虚拟机中运行 macOS (OSX) 时如何启动到安全模式? 最佳答案 Schmitty 在
这个问题在这里已经有了答案: How to get Conda and Virtualenv to work on mac OS Catalina? (8 个答案) 关闭 3 年前。 我在 macO
我有一个关于 macOS 应用程序图标的问题。我以前看过很多动画图标,但从来没有真正密切关注正在发生的事情/他们是如何做的。我只是想知道是否有任何方法可以创建在停靠栏中动画的动画应用程序图标。 例如:
每当我在 vim 中输入终端命令(例如,!echo hello)时,我会立即被踢出去查看该终端命令的结果,然后提示我使用 按 ENTER 或键入命令继续。这有点刺耳。我想留在 vim 中,并在底部打印
当使用文本编辑应用程序时,选择一种字体(例如“Menlo”)来呈现字形,当所选字体不包含特殊字形(例如“𠹷”,它是一个简单的中文字形,“Menlo"不包含它), 应用程序会选择一种字体来呈现它, 在
已经有几个关于如何在 Mac 上启用虚拟化的问题(例如 How to enable support of CPU virtualization on Macbook Pro?)。经常报告 sysctl
这只是出于好奇。 Exposé 有两个功能,其中一个是重新排列桌面上的窗口,一个是显示所有打开的窗口,这样用户可以看到隐藏在其他窗口下面的窗口,另一个功能是将所有窗口移到两侧,让用户与桌面交互。 我只
我使用的是 MacOS X,我对应用程序包类型的东西还很陌生。我正在编写一个程序来打开一个窗口并注册鼠标输入——而不是一个命令行工具。当我将我的代码(用 C 编写,如果这很重要)编译成一个可执行文件(
我正在制作一个必须支持 macOS 的 Flutter 插件。但是,当我想创建一个插件并在示例应用程序中运行该插件时(即使我还没有编辑过 Flutter 生成的代码),Xcode 会抛出以下错误。 无
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve thi
我想在终端(MacOs)中像屏幕一样显示当前目录面包屑: 我该怎么做? 现在它只是一个文本...... 谢谢 最佳答案 首选项 -> 窗口 -> 检查工作目录或文档下的“路径”。 路径将作为窗口标题的
我是一名优秀的程序员,十分优秀!