blob: 978ee5ce44b5a9a25ca5d18c91191dd124ca2bc4 [file] [log] [blame]
niklase@google.com470e71d2011-07-07 08:21:25 +00001/*
2 * Copyright (c) 2011 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020011#ifndef MODULES_VIDEO_CODING_ENCODED_FRAME_H_
12#define MODULES_VIDEO_CODING_ENCODED_FRAME_H_
niklase@google.com470e71d2011-07-07 08:21:25 +000013
stefan@webrtc.orgc5300432012-10-08 07:06:53 +000014#include <vector>
15
Niels Möller4dc66c52018-10-05 14:17:58 +020016#include "api/video/encoded_image.h"
Mirko Bonadei71207422017-09-15 13:58:09 +020017#include "common_types.h" // NOLINT(build/include)
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020018#include "modules/include/module_common_types.h"
19#include "modules/video_coding/include/video_codec_interface.h"
20#include "modules/video_coding/include/video_coding_defines.h"
niklase@google.com470e71d2011-07-07 08:21:25 +000021
philipel9d3ab612015-12-21 04:12:39 -080022namespace webrtc {
niklase@google.com470e71d2011-07-07 08:21:25 +000023
philipel9d3ab612015-12-21 04:12:39 -080024class VCMEncodedFrame : protected EncodedImage {
25 public:
26 VCMEncodedFrame();
Niels Möller72f52a12018-06-26 11:14:11 +020027 VCMEncodedFrame(const VCMEncodedFrame&) = delete;
niklase@google.com470e71d2011-07-07 08:21:25 +000028
philipel9d3ab612015-12-21 04:12:39 -080029 ~VCMEncodedFrame();
30 /**
Yves Gerey665174f2018-06-19 15:03:05 +020031 * Delete VideoFrame and resets members to zero
32 */
philipel9d3ab612015-12-21 04:12:39 -080033 void Free();
34 /**
Yves Gerey665174f2018-06-19 15:03:05 +020035 * Set render time in milliseconds
36 */
philipel9d3ab612015-12-21 04:12:39 -080037 void SetRenderTime(const int64_t renderTimeMs) {
38 _renderTimeMs = renderTimeMs;
39 }
niklase@google.com470e71d2011-07-07 08:21:25 +000040
philipel9d3ab612015-12-21 04:12:39 -080041 /**
Yves Gerey665174f2018-06-19 15:03:05 +020042 * Set the encoded frame size
43 */
philipel9d3ab612015-12-21 04:12:39 -080044 void SetEncodedSize(uint32_t width, uint32_t height) {
45 _encodedWidth = width;
46 _encodedHeight = height;
47 }
gnishb2a318b2017-05-10 09:21:33 -070048
49 void SetPlayoutDelay(PlayoutDelay playout_delay) {
50 playout_delay_ = playout_delay;
51 }
52
philipel9d3ab612015-12-21 04:12:39 -080053 /**
Yves Gerey665174f2018-06-19 15:03:05 +020054 * Get the encoded image
55 */
philipel9d3ab612015-12-21 04:12:39 -080056 const webrtc::EncodedImage& EncodedImage() const {
57 return static_cast<const webrtc::EncodedImage&>(*this);
58 }
59 /**
Yves Gerey665174f2018-06-19 15:03:05 +020060 * Get pointer to frame buffer
61 */
philipel9d3ab612015-12-21 04:12:39 -080062 const uint8_t* Buffer() const { return _buffer; }
63 /**
Benjamin Wright192eeec2018-10-17 17:27:25 -070064 * Get pointer to frame buffer that can be mutated.
65 */
66 uint8_t* MutableBuffer() { return _buffer; }
67 /**
Niels Möller23775882018-08-16 10:24:12 +020068 * Frame RTP timestamp (90kHz)
Yves Gerey665174f2018-06-19 15:03:05 +020069 */
Ilya Nikolaevskiy5546aef2018-12-04 15:54:52 +010070 using EncodedImage::set_size;
Sergey Silkin61832dd2018-12-20 14:32:14 +010071 using EncodedImage::SetSpatialIndex;
Niels Möller23775882018-08-16 10:24:12 +020072 using EncodedImage::SetTimestamp;
Niels Möllerf0eee002018-11-28 16:31:29 +010073 using EncodedImage::size;
Ilya Nikolaevskiy5546aef2018-12-04 15:54:52 +010074 using EncodedImage::Timestamp;
75
philipel9d3ab612015-12-21 04:12:39 -080076 /**
Yves Gerey665174f2018-06-19 15:03:05 +020077 * Get render time in milliseconds
78 */
philipel9d3ab612015-12-21 04:12:39 -080079 int64_t RenderTimeMs() const { return _renderTimeMs; }
80 /**
Yves Gerey665174f2018-06-19 15:03:05 +020081 * Get frame type
82 */
philipel9d3ab612015-12-21 04:12:39 -080083 webrtc::FrameType FrameType() const { return _frameType; }
84 /**
Yves Gerey665174f2018-06-19 15:03:05 +020085 * Get frame rotation
86 */
perkj414dda12016-07-04 01:45:23 -070087 VideoRotation rotation() const { return rotation_; }
philipel9d3ab612015-12-21 04:12:39 -080088 /**
ilnik00d802b2017-04-11 10:34:31 -070089 * Get video content type
90 */
91 VideoContentType contentType() const { return content_type_; }
92 /**
ilnik04f4d122017-06-19 07:18:55 -070093 * Get video timing
94 */
95 EncodedImage::Timing video_timing() const { return timing_; }
Ilya Nikolaevskiy5546aef2018-12-04 15:54:52 +010096 EncodedImage::Timing* video_timing_mutable() { return &timing_; }
ilnik04f4d122017-06-19 07:18:55 -070097 /**
ilnik00d802b2017-04-11 10:34:31 -070098 * True if this frame is complete, false otherwise
99 */
philipel9d3ab612015-12-21 04:12:39 -0800100 bool Complete() const { return _completeFrame; }
101 /**
Yves Gerey665174f2018-06-19 15:03:05 +0200102 * True if there's a frame missing before this frame
103 */
philipel9d3ab612015-12-21 04:12:39 -0800104 bool MissingFrame() const { return _missingFrame; }
105 /**
Yves Gerey665174f2018-06-19 15:03:05 +0200106 * Payload type of the encoded payload
107 */
philipel9d3ab612015-12-21 04:12:39 -0800108 uint8_t PayloadType() const { return _payloadType; }
109 /**
Yves Gerey665174f2018-06-19 15:03:05 +0200110 * Get codec specific info.
111 * The returned pointer is only valid as long as the VCMEncodedFrame
112 * is valid. Also, VCMEncodedFrame owns the pointer and will delete
113 * the object.
114 */
philipel9d3ab612015-12-21 04:12:39 -0800115 const CodecSpecificInfo* CodecSpecific() const { return &_codecSpecificInfo; }
Ilya Nikolaevskiy5546aef2018-12-04 15:54:52 +0100116 void SetCodecSpecific(const CodecSpecificInfo* codec_specific) {
117 _codecSpecificInfo = *codec_specific;
118 }
niklase@google.com470e71d2011-07-07 08:21:25 +0000119
philipel9d3ab612015-12-21 04:12:39 -0800120 /**
Yves Gerey665174f2018-06-19 15:03:05 +0200121 * Verifies that current allocated buffer size is larger than or equal to the
122 * input size.
123 * If the current buffer size is smaller, a new allocation is made and the old
124 * buffer data
125 * is copied to the new buffer.
126 * Buffer size is updated to minimumSize.
127 */
philipel9d3ab612015-12-21 04:12:39 -0800128 void VerifyAndAllocate(size_t minimumSize);
niklase@google.com470e71d2011-07-07 08:21:25 +0000129
Ilya Nikolaevskiy5546aef2018-12-04 15:54:52 +0100130 protected:
philipel9d3ab612015-12-21 04:12:39 -0800131 void Reset();
niklase@google.com470e71d2011-07-07 08:21:25 +0000132
philipel9d3ab612015-12-21 04:12:39 -0800133 void CopyCodecSpecific(const RTPVideoHeader* header);
henrik.lundin@webrtc.org473bac82011-08-17 09:47:33 +0000134
philipel9d3ab612015-12-21 04:12:39 -0800135 int64_t _renderTimeMs;
136 uint8_t _payloadType;
137 bool _missingFrame;
138 CodecSpecificInfo _codecSpecificInfo;
139 webrtc::VideoCodecType _codec;
guoweis@webrtc.org54d072e2015-03-17 21:54:50 +0000140
philipel9d3ab612015-12-21 04:12:39 -0800141 // Video rotation is only set along with the last packet for each frame
142 // (same as marker bit). This |_rotation_set| is only for debugging purpose
143 // to ensure we don't set it twice for a frame.
144 bool _rotation_set;
niklase@google.com470e71d2011-07-07 08:21:25 +0000145};
146
pbos@webrtc.orgd900e8b2013-07-03 15:12:26 +0000147} // namespace webrtc
niklase@google.com470e71d2011-07-07 08:21:25 +0000148
Mirko Bonadei92ea95e2017-09-15 06:47:31 +0200149#endif // MODULES_VIDEO_CODING_ENCODED_FRAME_H_