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}
This commit is contained in:
Patrik Höglund
2018-01-04 15:58:20 +01:00
committed by Commit Bot
parent 75ceef2ab4
commit 9e19403d10
13 changed files with 91 additions and 57 deletions

View File

@ -73,6 +73,8 @@ rtc_static_library("libjingle_peerconnection_api") {
"umametrics.cc",
"umametrics.h",
"videosinkinterface.h",
"videosourceinterface.cc",
"videosourceinterface.h",
"videosourceproxy.h",
]

View File

@ -28,7 +28,7 @@
// relying on them; they were previously transitively included by
// mediachannel.h, which is no longer a dependency of this file.
#include "api/videosinkinterface.h"
#include "media/base/videosourceinterface.h"
#include "api/videosourceinterface.h"
#include "modules/audio_processing/include/audio_processing_statistics.h"
#include "rtc_base/ratetracker.h"
#include "rtc_base/refcount.h"

View File

@ -0,0 +1,18 @@
/*
* Copyright (c) 2017 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.
*/
#include "api/videosourceinterface.h"
namespace rtc {
VideoSinkWants::VideoSinkWants() = default;
VideoSinkWants::~VideoSinkWants() = default;
} // namespace rtc

View File

@ -0,0 +1,59 @@
/*
* Copyright (c) 2016 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 API_VIDEOSOURCEINTERFACE_H_
#define API_VIDEOSOURCEINTERFACE_H_
#include <limits>
#include "api/optional.h"
#include "api/videosinkinterface.h"
namespace rtc {
// VideoSinkWants is used for notifying the source of properties a video frame
// should have when it is delivered to a certain sink.
struct VideoSinkWants {
VideoSinkWants();
~VideoSinkWants();
// Tells the source whether the sink wants frames with rotation applied.
// By default, any rotation must be applied by the sink.
bool rotation_applied = false;
// Tells the source that the sink only wants black frames.
bool black_frames = false;
// Tells the source the maximum number of pixels the sink wants.
int max_pixel_count = std::numeric_limits<int>::max();
// Tells the source the desired number of pixels the sinks wants. This will
// typically be used when stepping the resolution up again when conditions
// have improved after an earlier downgrade. The source should select the
// closest resolution to this pixel count, but if max_pixel_count is set, it
// still sets the absolute upper bound.
rtc::Optional<int> target_pixel_count;
// Tells the source the maximum framerate the sink wants.
int max_framerate_fps = std::numeric_limits<int>::max();
};
template <typename VideoFrameT>
class VideoSourceInterface {
public:
virtual void AddOrUpdateSink(VideoSinkInterface<VideoFrameT>* sink,
const VideoSinkWants& wants) = 0;
// RemoveSink must guarantee that at the time the method returns,
// there is no current and no future calls to VideoSinkInterface::OnFrame.
virtual void RemoveSink(VideoSinkInterface<VideoFrameT>* sink) = 0;
protected:
virtual ~VideoSourceInterface() {}
};
} // namespace rtc
#endif // API_VIDEOSOURCEINTERFACE_H_

View File

@ -157,12 +157,6 @@ rtc_static_library("call") {
}
rtc_source_set("video_stream_api") {
# TODO(bugs.webrtc.org/6828): Remove dependency cycle:
# //call:video_stream_api ->
# //media:rtc_media_base ->
# //call:call_interfaces ->
# //call:video_stream_api
check_includes = false
sources = [
"video_config.cc",
"video_config.h",
@ -173,12 +167,15 @@ rtc_source_set("video_stream_api") {
]
deps = [
":rtp_interfaces",
"../:typedefs",
"../:webrtc_common",
"../api:libjingle_peerconnection_api",
"../api:optional",
"../api:transport_api",
"../api:video_frame_api",
"../common_video:common_video",
"../modules/rtp_rtcp:rtp_rtcp_format",
"../rtc_base:checks",
"../rtc_base:rtc_base_approved",
]
}

View File

@ -20,11 +20,11 @@
#include "api/rtpparameters.h"
#include "api/rtp_headers.h"
#include "api/videosinkinterface.h"
#include "api/videosourceinterface.h"
#include "call/rtp_config.h"
#include "call/video_config.h"
#include "common_types.h" // NOLINT(build/include)
#include "common_video/include/frame_callback.h"
#include "media/base/videosourceinterface.h"
#include "modules/rtp_rtcp/include/rtp_rtcp_defines.h"
#include "rtc_base/platform_file.h"

View File

@ -92,7 +92,6 @@ rtc_static_library("rtc_media_base") {
"base/videocommon.h",
"base/videosourcebase.cc",
"base/videosourcebase.h",
"base/videosourceinterface.cc",
"base/videosourceinterface.h",
]

View File

@ -11,49 +11,7 @@
#ifndef MEDIA_BASE_VIDEOSOURCEINTERFACE_H_
#define MEDIA_BASE_VIDEOSOURCEINTERFACE_H_
#include <limits>
// TODO(bugs.webrtc.org/6828): remove this file after downstream is updated.
#include "api/videosourceinterface.h"
#include "api/optional.h"
#include "api/videosinkinterface.h"
namespace rtc {
// VideoSinkWants is used for notifying the source of properties a video frame
// should have when it is delivered to a certain sink.
struct VideoSinkWants {
VideoSinkWants();
~VideoSinkWants();
// Tells the source whether the sink wants frames with rotation applied.
// By default, any rotation must be applied by the sink.
bool rotation_applied = false;
// Tells the source that the sink only wants black frames.
bool black_frames = false;
// Tells the source the maximum number of pixels the sink wants.
int max_pixel_count = std::numeric_limits<int>::max();
// Tells the source the desired number of pixels the sinks wants. This will
// typically be used when stepping the resolution up again when conditions
// have improved after an earlier downgrade. The source should select the
// closest resolution to this pixel count, but if max_pixel_count is set, it
// still sets the absolute upper bound.
rtc::Optional<int> target_pixel_count;
// Tells the source the maximum framerate the sink wants.
int max_framerate_fps = std::numeric_limits<int>::max();
};
template <typename VideoFrameT>
class VideoSourceInterface {
public:
virtual void AddOrUpdateSink(VideoSinkInterface<VideoFrameT>* sink,
const VideoSinkWants& wants) = 0;
// RemoveSink must guarantee that at the time the method returns,
// there is no current and no future calls to VideoSinkInterface::OnFrame.
virtual void RemoveSink(VideoSinkInterface<VideoFrameT>* sink) = 0;
protected:
virtual ~VideoSourceInterface() {}
};
} // namespace rtc
#endif // MEDIA_BASE_VIDEOSOURCEINTERFACE_H_

View File

@ -22,12 +22,12 @@
#include "api/video/video_frame.h"
#include "api/video_codecs/sdp_video_format.h"
#include "api/videosinkinterface.h"
#include "api/videosourceinterface.h"
#include "call/call.h"
#include "call/flexfec_receive_stream.h"
#include "call/video_receive_stream.h"
#include "call/video_send_stream.h"
#include "media/base/mediaengine.h"
#include "media/base/videosourceinterface.h"
#include "media/engine/webrtcvideodecoderfactory.h"
#include "media/engine/webrtcvideoencoderfactory.h"
#include "rtc_base/asyncinvoker.h"

View File

@ -22,10 +22,10 @@
#include "api/jsep.h"
#include "api/rtpreceiverinterface.h"
#include "api/videosinkinterface.h"
#include "api/videosourceinterface.h"
#include "media/base/mediachannel.h"
#include "media/base/mediaengine.h"
#include "media/base/streamparams.h"
#include "media/base/videosourceinterface.h"
#include "p2p/base/dtlstransportinternal.h"
#include "p2p/base/packettransportinternal.h"
#include "p2p/client/socketmonitor.h"

View File

@ -61,6 +61,7 @@ rtc_source_set("video_test_common") {
deps = [
"..:webrtc_common",
"../:typedefs",
"../api:libjingle_peerconnection_api",
"../api:optional",
"../api:video_frame_api",
"../api:video_frame_api_i420",

View File

@ -15,7 +15,7 @@
#include <vector>
#include "api/video/video_frame.h"
#include "media/base/videosourceinterface.h"
#include "api/videosourceinterface.h"
#include "rtc_base/criticalsection.h"
#include "typedefs.h" // NOLINT(build/include)

View File

@ -17,8 +17,8 @@
#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 "media/base/videosourceinterface.h"
#include "rtc_base/criticalsection.h"
namespace cricket {