mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-19 08:37:54 +01:00

This feature is active if and only if the RTP header extension playout-delay is used with min playout delay=0 and max playout delay>0. In this case, a maximum composition delay will be calculated and attached to the video frame as a signal to use the low-latency renderer algorithm, which is landed in a separate CL in Chromium. The maximum composition delay is specified in number of frames and is calculated based on the max playout delay. The feature can be completetly disabled by specifying the field trial WebRTC-LowLatencyRenderer/enabled:false/ Bug: chromium:1138888 Change-Id: I05f461982d0632bd6e09e5d7ec1a8985dccdc61b Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/190141 Reviewed-by: Niels Moller <nisse@webrtc.org> Reviewed-by: Ilya Nikolaevskiy <ilnik@webrtc.org> Commit-Queue: Johannes Kron <kron@webrtc.org> Cr-Commit-Position: refs/heads/master@{#32493}
132 lines
3.7 KiB
C++
132 lines
3.7 KiB
C++
/*
|
|
* Copyright (c) 2011 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 MODULES_VIDEO_CODING_ENCODED_FRAME_H_
|
|
#define MODULES_VIDEO_CODING_ENCODED_FRAME_H_
|
|
|
|
#include <vector>
|
|
|
|
#include "api/video/encoded_image.h"
|
|
#include "modules/rtp_rtcp/source/rtp_video_header.h"
|
|
#include "modules/video_coding/include/video_codec_interface.h"
|
|
#include "modules/video_coding/include/video_coding_defines.h"
|
|
#include "rtc_base/system/rtc_export.h"
|
|
|
|
namespace webrtc {
|
|
|
|
class RTC_EXPORT VCMEncodedFrame : protected EncodedImage {
|
|
public:
|
|
VCMEncodedFrame();
|
|
VCMEncodedFrame(const VCMEncodedFrame&);
|
|
|
|
~VCMEncodedFrame();
|
|
/**
|
|
* Set render time in milliseconds
|
|
*/
|
|
void SetRenderTime(const int64_t renderTimeMs) {
|
|
_renderTimeMs = renderTimeMs;
|
|
}
|
|
|
|
VideoPlayoutDelay PlayoutDelay() const { return playout_delay_; }
|
|
|
|
void SetPlayoutDelay(VideoPlayoutDelay playout_delay) {
|
|
playout_delay_ = playout_delay;
|
|
}
|
|
|
|
/**
|
|
* Get the encoded image
|
|
*/
|
|
const webrtc::EncodedImage& EncodedImage() const {
|
|
return static_cast<const webrtc::EncodedImage&>(*this);
|
|
}
|
|
|
|
using EncodedImage::ColorSpace;
|
|
using EncodedImage::data;
|
|
using EncodedImage::GetEncodedData;
|
|
using EncodedImage::NtpTimeMs;
|
|
using EncodedImage::PacketInfos;
|
|
using EncodedImage::Retain;
|
|
using EncodedImage::set_size;
|
|
using EncodedImage::SetColorSpace;
|
|
using EncodedImage::SetEncodedData;
|
|
using EncodedImage::SetPacketInfos;
|
|
using EncodedImage::SetSpatialIndex;
|
|
using EncodedImage::SetSpatialLayerFrameSize;
|
|
using EncodedImage::SetTimestamp;
|
|
using EncodedImage::size;
|
|
using EncodedImage::SpatialIndex;
|
|
using EncodedImage::SpatialLayerFrameSize;
|
|
using EncodedImage::Timestamp;
|
|
|
|
/**
|
|
* Get render time in milliseconds
|
|
*/
|
|
int64_t RenderTimeMs() const { return _renderTimeMs; }
|
|
/**
|
|
* Get frame type
|
|
*/
|
|
webrtc::VideoFrameType FrameType() const { return _frameType; }
|
|
/**
|
|
* Set frame type
|
|
*/
|
|
void SetFrameType(webrtc::VideoFrameType frame_type) {
|
|
_frameType = frame_type;
|
|
}
|
|
/**
|
|
* Get frame rotation
|
|
*/
|
|
VideoRotation rotation() const { return rotation_; }
|
|
/**
|
|
* Get video content type
|
|
*/
|
|
VideoContentType contentType() const { return content_type_; }
|
|
/**
|
|
* Get video timing
|
|
*/
|
|
EncodedImage::Timing video_timing() const { return timing_; }
|
|
EncodedImage::Timing* video_timing_mutable() { return &timing_; }
|
|
/**
|
|
* True if this frame is complete, false otherwise
|
|
*/
|
|
bool Complete() const { return _completeFrame; }
|
|
/**
|
|
* True if there's a frame missing before this frame
|
|
*/
|
|
bool MissingFrame() const { return _missingFrame; }
|
|
/**
|
|
* Payload type of the encoded payload
|
|
*/
|
|
uint8_t PayloadType() const { return _payloadType; }
|
|
/**
|
|
* Get codec specific info.
|
|
* The returned pointer is only valid as long as the VCMEncodedFrame
|
|
* is valid. Also, VCMEncodedFrame owns the pointer and will delete
|
|
* the object.
|
|
*/
|
|
const CodecSpecificInfo* CodecSpecific() const { return &_codecSpecificInfo; }
|
|
void SetCodecSpecific(const CodecSpecificInfo* codec_specific) {
|
|
_codecSpecificInfo = *codec_specific;
|
|
}
|
|
|
|
protected:
|
|
void Reset();
|
|
|
|
void CopyCodecSpecific(const RTPVideoHeader* header);
|
|
|
|
int64_t _renderTimeMs;
|
|
uint8_t _payloadType;
|
|
bool _missingFrame;
|
|
CodecSpecificInfo _codecSpecificInfo;
|
|
webrtc::VideoCodecType _codec;
|
|
};
|
|
|
|
} // namespace webrtc
|
|
|
|
#endif // MODULES_VIDEO_CODING_ENCODED_FRAME_H_
|