/* * 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. */ #ifndef MODULES_DESKTOP_CAPTURE_WINDOW_FINDER_H_ #define MODULES_DESKTOP_CAPTURE_WINDOW_FINDER_H_ #include #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" #endif namespace webrtc { #if defined(WEBRTC_USE_X11) class XAtomCache; #endif // An interface to return the id of the visible window under a certain point. class WindowFinder { public: 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(); ~Options(); Options(const Options& other); Options(Options&& other); #if defined(WEBRTC_USE_X11) XAtomCache* cache = nullptr; #endif #if defined(WEBRTC_MAC) && !defined(WEBRTC_IOS) rtc::scoped_refptr configuration_monitor; #endif }; // 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 Create(const Options& options); }; } // namespace webrtc #endif // MODULES_DESKTOP_CAPTURE_WINDOW_FINDER_H_