gpt4 book ai didi

linux - 如何确定 X Windows/Linux 中 Windows 的可见区域?

转载 作者:太空宇宙 更新时间:2023-11-04 11:42:42 24 4
gpt4 key购买 nike

我有几个嵌套的 X Windows - 比方说 - 一个可滚动窗口内的一个可滚动窗口(参见下面的示例)。在这种情况下,主窗口包含(至少)主要滚动条和它们控制的(主要)绘图区域。该绘图区域依次包含(至少)一个可滚动窗口批处理 - 一个(小)主窗口,包含一个滚动条和一个小绘图区域。

在内部绘图区域的实时滚动期间,重绘过程出现困惑,因为我正在使用 XCopyArea 来加速该过程并移动有效的内容并为新出现的内容调用实际的重绘例程。这在内部绘图批处理单独存在时工作正常,但是当嵌套在另一个绘图批处理中时会出现问题 - 当内部滚动批处理部分可见时(即滚动主要绘图区域),新出现的内容的重绘从主要内容中剪裁绘图区域并没有真正重绘,但被认为是这样。当在下一次滚动时,XCopyArea 得到这个应该重绘的区域,它实际上是空的。最后,这个空白区域出现在部分可见的内部滚动批处理上,并且它是空的。在第一个一般重绘消息中,它们是固定的。

如果我可以获得从(我的)内部绘图区域实际可见的内容的剪贴蒙版,我可以调整 XCopyArea() 调用和重绘调用,并在没有计划“B”的情况下克服问题,该计划正在重绘每个区域的所有内容滚动条移动。

示例:为 Mozilla Firefox 开发插件并需要确定描述“我的”窗口可见区域的区域,即从 Mozilla 系统作为插件视口(viewport)传递的区域。

最佳答案

如果您得到的确实是一个 X Window,而不是来自某个特定工具包(比如 GTK+ ?)的小部件,那么您可以使用 XGetWindowAttributes 函数调用。

这会填充提供的 XWindowAttributes 结构,其中包括表示窗口 x 和 y 位置的整数以及窗口的宽度和高度以及其他有用的信息。

但实际上我认为您可能正在使用从 Netscape 继承的 Mozilla 插件 API,又名 NSAPI,在这种情况下,您得到的是对函数 NPP_SetWindow() 的调用至少一次(必要时再次调用,因为发生了一些变化) 的结构包含您要查找的信息。尝试查看 http://www.mozilla.org/projects/plugins/有关您应该使用的 API 的更多信息。

关于linux - 如何确定 X Windows/Linux 中 Windows 的可见区域?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/72254/

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