webrtc_m130/test/video_capturer.h
Patrik Höglund 9e19403d10 Move videosourceinterface to api.
VideoSourceInterface is clearly an integral part of
mediastreaminterface.h already, so moving that interface to api makes
sense. This also resolves a circular dependency in call/.

Bug: webrc:6828
Change-Id: Ic1862f118363b0b55a235a9c0c35d9adc647184c
Reviewed-on: https://webrtc-review.googlesource.com/37500
Reviewed-by: Stefan Holmer <stefan@webrtc.org>
Commit-Queue: Patrik Höglund <phoglund@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#21498}
2018-01-05 09:14:19 +00:00

54 lines
1.4 KiB
C++

/*
* Copyright (c) 2013 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 TEST_VIDEO_CAPTURER_H_
#define TEST_VIDEO_CAPTURER_H_
#include <stddef.h>
#include <memory>
#include "api/optional.h"
#include "api/video/i420_buffer.h"
#include "api/video/video_frame.h"
#include "api/videosourceinterface.h"
#include "media/base/videoadapter.h"
#include "rtc_base/criticalsection.h"
namespace cricket {
class VideoAdapter;
} // namespace cricket
namespace webrtc {
class Clock;
namespace test {
class VideoCapturer : public rtc::VideoSourceInterface<VideoFrame> {
public:
VideoCapturer();
virtual ~VideoCapturer();
virtual void Start() = 0;
virtual void Stop() = 0;
void AddOrUpdateSink(rtc::VideoSinkInterface<VideoFrame>* sink,
const rtc::VideoSinkWants& wants) override;
protected:
rtc::Optional<VideoFrame> AdaptFrame(const VideoFrame& frame);
rtc::VideoSinkWants GetSinkWants();
private:
const std::unique_ptr<cricket::VideoAdapter> video_adapter_;
};
} // namespace test
} // namespace webrtc
#endif // TEST_VIDEO_CAPTURER_H_