2013-09-19 12:14:03 +00:00
|
|
|
/*
|
|
|
|
|
* 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.
|
|
|
|
|
*/
|
2016-09-16 07:53:41 -07:00
|
|
|
#ifndef WEBRTC_TEST_FRAME_GENERATOR_H_
|
|
|
|
|
#define WEBRTC_TEST_FRAME_GENERATOR_H_
|
2013-09-19 12:14:03 +00:00
|
|
|
|
2015-02-18 12:46:06 +00:00
|
|
|
#include <string>
|
|
|
|
|
#include <vector>
|
|
|
|
|
|
2017-01-10 07:44:26 -08:00
|
|
|
#include "webrtc/api/video/video_frame.h"
|
2016-09-16 07:53:41 -07:00
|
|
|
#include "webrtc/base/criticalsection.h"
|
|
|
|
|
#include "webrtc/media/base/videosourceinterface.h"
|
2013-09-19 12:14:03 +00:00
|
|
|
#include "webrtc/typedefs.h"
|
|
|
|
|
|
|
|
|
|
namespace webrtc {
|
2015-07-29 07:58:13 -07:00
|
|
|
class Clock;
|
2013-09-19 12:14:03 +00:00
|
|
|
namespace test {
|
|
|
|
|
|
2016-09-16 07:53:41 -07:00
|
|
|
// FrameForwarder can be used as an implementation
|
|
|
|
|
// of rtc::VideoSourceInterface<VideoFrame> where the caller controls when
|
|
|
|
|
// a frame should be forwarded to its sink.
|
|
|
|
|
// Currently this implementation only support one sink.
|
|
|
|
|
class FrameForwarder : public rtc::VideoSourceInterface<VideoFrame> {
|
|
|
|
|
public:
|
|
|
|
|
FrameForwarder();
|
2017-02-01 08:38:12 -08:00
|
|
|
virtual ~FrameForwarder();
|
2016-09-16 07:53:41 -07:00
|
|
|
// Forwards |video_frame| to the registered |sink_|.
|
2017-02-01 08:38:12 -08:00
|
|
|
virtual void IncomingCapturedFrame(const VideoFrame& video_frame);
|
2016-11-01 11:45:46 -07:00
|
|
|
rtc::VideoSinkWants sink_wants() const;
|
|
|
|
|
bool has_sinks() const;
|
2016-09-16 07:53:41 -07:00
|
|
|
|
2017-02-01 08:38:12 -08:00
|
|
|
protected:
|
2016-09-16 07:53:41 -07:00
|
|
|
void AddOrUpdateSink(rtc::VideoSinkInterface<VideoFrame>* sink,
|
|
|
|
|
const rtc::VideoSinkWants& wants) override;
|
|
|
|
|
void RemoveSink(rtc::VideoSinkInterface<VideoFrame>* sink) override;
|
|
|
|
|
|
|
|
|
|
rtc::CriticalSection crit_;
|
|
|
|
|
rtc::VideoSinkInterface<VideoFrame>* sink_ GUARDED_BY(crit_);
|
2016-11-01 11:45:46 -07:00
|
|
|
rtc::VideoSinkWants sink_wants_ GUARDED_BY(crit_);
|
2016-09-16 07:53:41 -07:00
|
|
|
};
|
|
|
|
|
|
2013-09-19 12:14:03 +00:00
|
|
|
class FrameGenerator {
|
|
|
|
|
public:
|
|
|
|
|
FrameGenerator() {}
|
|
|
|
|
virtual ~FrameGenerator() {}
|
|
|
|
|
|
|
|
|
|
// Returns video frame that remains valid until next call.
|
2015-05-29 17:21:40 -07:00
|
|
|
virtual VideoFrame* NextFrame() = 0;
|
2013-09-19 12:14:03 +00:00
|
|
|
|
2016-10-02 23:45:26 -07:00
|
|
|
// Change the capture resolution.
|
|
|
|
|
virtual void ChangeResolution(size_t width, size_t height) {
|
|
|
|
|
RTC_NOTREACHED();
|
|
|
|
|
}
|
|
|
|
|
|
2015-02-18 12:46:06 +00:00
|
|
|
// Creates a test frame generator that creates fully saturated frames with
|
|
|
|
|
// varying U, V values over time.
|
|
|
|
|
static FrameGenerator* CreateChromaGenerator(size_t width, size_t height);
|
|
|
|
|
|
|
|
|
|
// Creates a frame generator that repeatedly plays a set of yuv files.
|
|
|
|
|
// The frame_repeat_count determines how many times each frame is shown,
|
2015-03-02 11:55:45 +00:00
|
|
|
// with 1 = show each frame once, etc.
|
2015-02-18 12:46:06 +00:00
|
|
|
static FrameGenerator* CreateFromYuvFile(std::vector<std::string> files,
|
2013-09-19 12:14:03 +00:00
|
|
|
size_t width,
|
2015-02-18 12:46:06 +00:00
|
|
|
size_t height,
|
|
|
|
|
int frame_repeat_count);
|
2015-07-29 07:58:13 -07:00
|
|
|
|
|
|
|
|
// Creates a frame generator which takes a set of yuv files (wrapping a
|
|
|
|
|
// frame generator created by CreateFromYuvFile() above), but outputs frames
|
|
|
|
|
// that have been cropped to specified resolution: source_width/source_height
|
|
|
|
|
// is the size of the source images, target_width/target_height is the size of
|
|
|
|
|
// the cropped output. For each source image read, the cropped viewport will
|
|
|
|
|
// be scrolled top to bottom/left to right for scroll_tim_ms milliseconds.
|
|
|
|
|
// After that the image will stay in place for pause_time_ms milliseconds,
|
|
|
|
|
// and then this will be repeated with the next file from the input set.
|
|
|
|
|
static FrameGenerator* CreateScrollingInputFromYuvFiles(
|
|
|
|
|
Clock* clock,
|
|
|
|
|
std::vector<std::string> filenames,
|
|
|
|
|
size_t source_width,
|
|
|
|
|
size_t source_height,
|
|
|
|
|
size_t target_width,
|
|
|
|
|
size_t target_height,
|
|
|
|
|
int64_t scroll_time_ms,
|
|
|
|
|
int64_t pause_time_ms);
|
2013-09-19 12:14:03 +00:00
|
|
|
};
|
|
|
|
|
} // namespace test
|
|
|
|
|
} // namespace webrtc
|
|
|
|
|
|
2016-09-16 07:53:41 -07:00
|
|
|
#endif // WEBRTC_TEST_FRAME_GENERATOR_H_
|