blob: 99e3cce55950bd2c4c75b978a273e27d16a22873 [file] [log] [blame]
* Copyright (c) 2017 The WebRTC project authors. All Rights Reserved.
* Use of this source code is governed by a BSD-style license
* that can be found in the LICENSE file in the root of the source
* tree. An additional intellectual property rights grant can be found
* in the file PATENTS. All contributing project authors may
* be found in the AUTHORS file in the root of the source tree.
#include <memory>
#include "api/scoped_refptr.h"
#include "modules/desktop_capture/desktop_capture_types.h"
#include "modules/desktop_capture/desktop_geometry.h"
#if defined(WEBRTC_MAC) && !defined(WEBRTC_IOS)
#include "modules/desktop_capture/mac/desktop_configuration_monitor.h"
namespace webrtc {
#if defined(WEBRTC_USE_X11)
class XAtomCache;
// An interface to return the id of the visible window under a certain point.
class WindowFinder {
WindowFinder() = default;
virtual ~WindowFinder() = default;
// Returns the id of the visible window under `point`. This function returns
// kNullWindowId if no window is under `point` and the platform does not have
// "root window" concept, i.e. the visible area under `point` is the desktop.
// `point` is always in system coordinate, i.e. the primary monitor always
// starts from (0, 0).
virtual WindowId GetWindowUnderPoint(DesktopVector point) = 0;
struct Options final {
Options(const Options& other);
Options(Options&& other);
#if defined(WEBRTC_USE_X11)
XAtomCache* cache = nullptr;
#if defined(WEBRTC_MAC) && !defined(WEBRTC_IOS)
rtc::scoped_refptr<DesktopConfigurationMonitor> configuration_monitor;
// Creates a platform-independent WindowFinder implementation. This function
// returns nullptr if `options` does not contain enough information or
// WindowFinder does not support current platform.
static std::unique_ptr<WindowFinder> Create(const Options& options);
} // namespace webrtc