/* | |
* Copyright (c) 2020 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_WIN_WGC_CAPTURE_SESSION_H_ | |
#define MODULES_DESKTOP_CAPTURE_WIN_WGC_CAPTURE_SESSION_H_ | |
#include <d3d11.h> | |
#include <windows.graphics.capture.h> | |
#include <wrl/client.h> | |
#include <memory> | |
#include "modules/desktop_capture/desktop_capture_options.h" | |
#include "modules/desktop_capture/win/wgc_capture_source.h" | |
#include "rtc_base/synchronization/sequence_checker.h" | |
namespace webrtc { | |
class WgcCaptureSession final { | |
public: | |
WgcCaptureSession( | |
Microsoft::WRL::ComPtr<ID3D11Device> d3d11_device, | |
Microsoft::WRL::ComPtr< | |
ABI::Windows::Graphics::Capture::IGraphicsCaptureItem> item); | |
// Disallow copy and assign. | |
WgcCaptureSession(const WgcCaptureSession&) = delete; | |
WgcCaptureSession& operator=(const WgcCaptureSession&) = delete; | |
~WgcCaptureSession(); | |
HRESULT StartCapture(); | |
// Returns a frame from the frame pool, if any are present. | |
HRESULT GetFrame(std::unique_ptr<DesktopFrame>* output_frame); | |
bool IsCaptureStarted() const { | |
RTC_DCHECK_RUN_ON(&sequence_checker_); | |
return is_capture_started_; | |
} | |
private: | |
// Initializes |mapped_texture_| with the properties of the |src_texture|, | |
// overrides the values of some necessary properties like the | |
// D3D11_CPU_ACCESS_READ flag. Also has optional parameters for what size | |
// |mapped_texture_| should be, if they aren't provided we will use the size | |
// of |src_texture|. | |
HRESULT CreateMappedTexture( | |
Microsoft::WRL::ComPtr<ID3D11Texture2D> src_texture, | |
UINT width = 0, | |
UINT height = 0); | |
// Event handler for |item_|'s Closed event. | |
HRESULT OnItemClosed( | |
ABI::Windows::Graphics::Capture::IGraphicsCaptureItem* sender, | |
IInspectable* event_args); | |
// A Direct3D11 Device provided by the caller. We use this to create an | |
// IDirect3DDevice, and also to create textures that will hold the image data. | |
Microsoft::WRL::ComPtr<ID3D11Device> d3d11_device_; | |
// This item represents what we are capturing, we use it to create the | |
// capture session, and also to listen for the Closed event. | |
Microsoft::WRL::ComPtr<ABI::Windows::Graphics::Capture::IGraphicsCaptureItem> | |
item_; | |
// The IDirect3DDevice is necessary to instantiate the frame pool. | |
Microsoft::WRL::ComPtr< | |
ABI::Windows::Graphics::DirectX::Direct3D11::IDirect3DDevice> | |
direct3d_device_; | |
// The frame pool is where frames are deposited during capture, we retrieve | |
// them from here with TryGetNextFrame(). | |
Microsoft::WRL::ComPtr< | |
ABI::Windows::Graphics::Capture::IDirect3D11CaptureFramePool> | |
frame_pool_; | |
// This texture holds the final image data. We made it a member so we can | |
// reuse it, instead of having to create a new texture every time we grab a | |
// frame. | |
Microsoft::WRL::ComPtr<ID3D11Texture2D> mapped_texture_; | |
// This lets us know when the source has been resized, which is important | |
// because we must resize the framepool and our texture to be able to hold | |
// enough data for the frame. | |
ABI::Windows::Graphics::SizeInt32 previous_size_; | |
// The capture session lets us set properties about the capture before it | |
// starts such as whether to capture the mouse cursor, and it lets us tell WGC | |
// to start capturing frames. | |
Microsoft::WRL::ComPtr< | |
ABI::Windows::Graphics::Capture::IGraphicsCaptureSession> | |
session_; | |
bool item_closed_ = false; | |
bool is_capture_started_ = false; | |
SequenceChecker sequence_checker_; | |
}; | |
} // namespace webrtc | |
#endif // MODULES_DESKTOP_CAPTURE_WIN_WGC_CAPTURE_SESSION_H_ |