123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- #ifndef MEDIA_BASE_VIDEO_BROADCASTER_H_
- #define MEDIA_BASE_VIDEO_BROADCASTER_H_
- #include "api/scoped_refptr.h"
- #include "api/video/video_frame_buffer.h"
- #include "api/video/video_source_interface.h"
- #include "media/base/video_source_base.h"
- #include "rtc_base/synchronization/mutex.h"
- #include "rtc_base/thread_annotations.h"
- #include "rtc_base/thread_checker.h"
- namespace rtc {
- class VideoBroadcaster : public VideoSourceBase,
- public VideoSinkInterface<webrtc::VideoFrame> {
- public:
- VideoBroadcaster();
- ~VideoBroadcaster() override;
- void AddOrUpdateSink(VideoSinkInterface<webrtc::VideoFrame>* sink,
- const VideoSinkWants& wants) override;
- void RemoveSink(VideoSinkInterface<webrtc::VideoFrame>* sink) override;
-
- bool frame_wanted() const;
-
-
- VideoSinkWants wants() const;
-
-
-
-
- void OnFrame(const webrtc::VideoFrame& frame) override;
- void OnDiscardedFrame() override;
- protected:
- void UpdateWants() RTC_EXCLUSIVE_LOCKS_REQUIRED(sinks_and_wants_lock_);
- const rtc::scoped_refptr<webrtc::VideoFrameBuffer>& GetBlackFrameBuffer(
- int width,
- int height) RTC_EXCLUSIVE_LOCKS_REQUIRED(sinks_and_wants_lock_);
- mutable webrtc::Mutex sinks_and_wants_lock_;
- VideoSinkWants current_wants_ RTC_GUARDED_BY(sinks_and_wants_lock_);
- rtc::scoped_refptr<webrtc::VideoFrameBuffer> black_frame_buffer_;
- bool previous_frame_sent_to_all_sinks_ RTC_GUARDED_BY(sinks_and_wants_lock_) =
- true;
- };
- }
- #endif
|