
I updated some dependency enforcement rules to allow examples and pc to depend on common_video. I reckoned depending on common_video is not controversial when they already dependend on media/base, which is a lower-level abstraction. Bug: webrtc:6828 Change-Id: I77dbeb10187b4e70dda1d873a29994fa76070758 Reviewed-on: https://webrtc-review.googlesource.com/34187 Reviewed-by: Stefan Holmer <stefan@webrtc.org> Commit-Queue: Patrik Höglund <phoglund@webrtc.org> Cr-Commit-Position: refs/heads/master@{#21495}
45 lines
1.4 KiB
C++
45 lines
1.4 KiB
C++
/*
|
|
* Copyright (c) 2012 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 COMMON_VIDEO_INCLUDE_INCOMING_VIDEO_STREAM_H_
|
|
#define COMMON_VIDEO_INCLUDE_INCOMING_VIDEO_STREAM_H_
|
|
|
|
#include "api/videosinkinterface.h"
|
|
#include "common_video/video_render_frames.h"
|
|
#include "rtc_base/race_checker.h"
|
|
#include "rtc_base/task_queue.h"
|
|
|
|
namespace webrtc {
|
|
|
|
class IncomingVideoStream : public rtc::VideoSinkInterface<VideoFrame> {
|
|
public:
|
|
IncomingVideoStream(int32_t delay_ms,
|
|
rtc::VideoSinkInterface<VideoFrame>* callback);
|
|
~IncomingVideoStream() override;
|
|
|
|
private:
|
|
void OnFrame(const VideoFrame& video_frame) override;
|
|
void Dequeue();
|
|
|
|
// Fwd decl of a QueuedTask implementation for carrying frames over to the TQ.
|
|
class NewFrameTask;
|
|
|
|
rtc::ThreadChecker main_thread_checker_;
|
|
rtc::RaceChecker decoder_race_checker_;
|
|
|
|
VideoRenderFrames render_buffers_; // Only touched on the TaskQueue.
|
|
rtc::VideoSinkInterface<VideoFrame>* const callback_;
|
|
rtc::TaskQueue incoming_render_queue_;
|
|
};
|
|
|
|
} // namespace webrtc
|
|
|
|
#endif // COMMON_VIDEO_INCLUDE_INCOMING_VIDEO_STREAM_H_
|