1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- #ifndef PC_VIDEO_TRACK_H_
- #define PC_VIDEO_TRACK_H_
- #include <string>
- #include "api/media_stream_interface.h"
- #include "api/scoped_refptr.h"
- #include "api/video/video_frame.h"
- #include "api/video/video_sink_interface.h"
- #include "api/video/video_source_interface.h"
- #include "media/base/video_source_base.h"
- #include "pc/media_stream_track.h"
- #include "rtc_base/thread.h"
- #include "rtc_base/thread_annotations.h"
- #include "rtc_base/thread_checker.h"
- namespace webrtc {
- class VideoTrack : public MediaStreamTrack<VideoTrackInterface>,
- public rtc::VideoSourceBase,
- public ObserverInterface {
- public:
- static rtc::scoped_refptr<VideoTrack> Create(
- const std::string& label,
- VideoTrackSourceInterface* source,
- rtc::Thread* worker_thread);
- void AddOrUpdateSink(rtc::VideoSinkInterface<VideoFrame>* sink,
- const rtc::VideoSinkWants& wants) override;
- void RemoveSink(rtc::VideoSinkInterface<VideoFrame>* sink) override;
- VideoTrackSourceInterface* GetSource() const override {
- return video_source_.get();
- }
- ContentHint content_hint() const override;
- void set_content_hint(ContentHint hint) override;
- bool set_enabled(bool enable) override;
- std::string kind() const override;
- protected:
- VideoTrack(const std::string& id,
- VideoTrackSourceInterface* video_source,
- rtc::Thread* worker_thread);
- ~VideoTrack();
- private:
-
- void OnChanged() override;
- rtc::Thread* const worker_thread_;
- rtc::ThreadChecker signaling_thread_checker_;
- rtc::scoped_refptr<VideoTrackSourceInterface> video_source_;
- ContentHint content_hint_ RTC_GUARDED_BY(signaling_thread_checker_);
- };
- }
- #endif
|