blob: eb2035208b6a763980f48701c0166f8fa524bf74 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
|
// Copyright (C) 2023 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
#include "qcgcapturablewindows_p.h"
#include "private/qcapturablewindow_p.h"
#include "QtCore/private/qcore_mac_p.h"
#include <AppKit/NSWindow.h>
QT_BEGIN_NAMESPACE
QList<QCapturableWindow> QCGCapturableWindows::windows() const
{
QList<QCapturableWindow> result;
QCFType<CFArrayRef> windowList(
CGWindowListCopyWindowInfo(kCGWindowListOptionOnScreenOnly, kCGNullWindowID));
// Iterate through the window dictionaries
CFIndex count = CFArrayGetCount(windowList);
for (CFIndex i = 0; i < count; ++i) {
auto windowInfo = (CFDictionaryRef)CFArrayGetValueAtIndex(windowList, i);
auto windowNumber = (CFNumberRef)CFDictionaryGetValue(windowInfo, kCGWindowNumber);
auto windowName = (CFStringRef)CFDictionaryGetValue(windowInfo, kCGWindowName);
CGWindowID windowId = 0;
static_assert(sizeof(windowId) == 4,
"CGWindowID size is not compatible with kCFNumberSInt32Type");
CFNumberGetValue(windowNumber, kCFNumberSInt32Type, &windowId);
auto windowData = std::make_unique<QCapturableWindowPrivate>();
windowData->id = static_cast<QCapturableWindowPrivate::Id>(windowId);
if (windowName)
windowData->description = QString::fromCFString(windowName);
result.push_back(windowData.release()->create());
}
return result;
}
bool QCGCapturableWindows::isWindowValid(const QCapturableWindowPrivate &window) const
{
QCFType<CFArrayRef> windowList(
CGWindowListCreate(kCGWindowListOptionIncludingWindow, window.id));
return CFArrayGetCount(windowList) > 0;
}
QT_END_NAMESPACE
|