Index: webrtc/modules/desktop_capture/blank_detector_desktop_capturer_wrapper.h |
diff --git a/webrtc/modules/desktop_capture/blank_detector_desktop_capturer_wrapper.h b/webrtc/modules/desktop_capture/blank_detector_desktop_capturer_wrapper.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..621d972df85ce0f3de2caebc1f49e7c39b188a89 |
--- /dev/null |
+++ b/webrtc/modules/desktop_capture/blank_detector_desktop_capturer_wrapper.h |
@@ -0,0 +1,97 @@ |
+/* |
+ * 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 WEBRTC_MODULES_DESKTOP_CAPTURE_BLANK_DETECTOR_DESKTOP_CAPTURER_WRAPPER_H_ |
+#define WEBRTC_MODULES_DESKTOP_CAPTURE_BLANK_DETECTOR_DESKTOP_CAPTURER_WRAPPER_H_ |
+ |
+#include <memory> |
+ |
+#include "webrtc/modules/desktop_capture/desktop_capturer.h" |
+#include "webrtc/modules/desktop_capture/rgba_color.h" |
+ |
+namespace webrtc { |
+ |
+// A DesktopCapturer wrapper detects the return value of its owned |
+// DesktopCapturer implementation. If sampled pixels returned by the |
+// DesktopCapturer implementation all equal to the blank pixel, this wrapper |
+// returns ERROR_TEMPORARY. If the DesktopCapturer implementation fails for too |
+// many times, this wrapper returns ERROR_PERMANENT. |
+class BlankDetectorDesktopCapturerWrapper final |
+ : public DesktopCapturer, |
+ public DesktopCapturer::Callback { |
+ public: |
+ // Creates BlankDetectorDesktopCapturerWrapper. BlankDesktopCapturerWrapper |
+ // takes ownership of |capturer|. The |blank_pixel| is the unmodified color |
+ // returned by the |capturer|. |permanent_failure_threshold| controls how |
+ // many frames BlankDetectorDesktopCapturerWrapper checks before returning a |
+ // permanent error. Setting |permanent_failure_threshold| to negative value to |
+ // disable this function, i.e. BlankDetectorDesktopCapturerWrapper will check |
+ // every frame, and never return permanent error. |
Sergey Ulanov
2017/03/02 23:45:51
Do we actually need this feature? It adds complexi
Hzj_jie
2017/03/03 02:29:41
I am OK to remove the permanent_failure_threshold.
|
+ BlankDetectorDesktopCapturerWrapper(std::unique_ptr<DesktopCapturer> capturer, |
+ RgbaColor blank_pixel, |
Sergey Ulanov
2017/03/02 23:45:51
Do we need this parameter? Will we even need to pa
Hzj_jie
2017/03/03 02:29:41
If we use this class with GDI capturer on Windows
|
+ int permanent_failure_threshold); |
+ ~BlankDetectorDesktopCapturerWrapper() override; |
+ |
+ // DesktopCapturer interface. |
+ void Start(DesktopCapturer::Callback* callback) override; |
+ void SetSharedMemoryFactory( |
+ std::unique_ptr<SharedMemoryFactory> shared_memory_factory) override; |
+ void CaptureFrame() override; |
+ void SetExcludedWindow(WindowId window) override; |
+ bool GetSourceList(SourceList* sources) override; |
+ bool SelectSource(SourceId id) override; |
+ bool FocusOnSelectedSource() override; |
+ |
+ private: |
+ // DesktopCapturer::Callback interface. |
+ void OnCaptureResult(Result result, |
+ std::unique_ptr<DesktopFrame> frame) override; |
+ |
+ bool IsBlankFrame(const DesktopFrame& frame) const; |
+ |
+ // Detects whether pixel at (x, y) equals to |blank_pixel_|. |
+ bool IsBlankPixel(const DesktopFrame& frame, int x, int y) const; |
+ |
+ // Whether permanent failure has been enabled by this instance, i.e. |
+ // |permanent_failure_threshold_| >= 0. |
+ bool permanent_failure_enabled() const; |
+ |
+ // Whether permanent error should be returned by this instance for current |
+ // frame. |
+ bool permanent_failure_reached() const; |
+ |
+ // Returns a permanent error to |callback_|. |
+ void ReturnPermanentError(); |
+ |
+ const std::unique_ptr<DesktopCapturer> capturer_; |
+ const RgbaColor blank_pixel_; |
+ |
+ // The count of failures before this wrapper returns an ERROR_PERMANENT. Set |
+ // this value to negative to always return ERROR_TEMPORARY. |
+ const int permanent_failure_threshold_; |
+ |
+ // The count of blank frames received in a sequence. |
+ int failure_count_ = 0; |
+ |
+ // Whether a non-blank frame has been received. |
+ bool non_blank_frame_received_ = false; |
+ |
+ // Whether the last frame is blank. |
+ bool last_frame_is_blank_ = false; |
+ |
+ // Whether current frame is the first frame. |
+ bool is_first_frame_ = true; |
+ |
+ DesktopCapturer::Callback* callback_ = nullptr; |
+}; |
+ |
+} // namespace webrtc |
+ |
+#endif // WEBRTC_MODULES_DESKTOP_CAPTURE_BLANK_DETECTOR_DESKTOP_CAPTURER_WRAPPER_H_ |