blob: 2d65e9c1e4b614445dadf87280180d4008003bbf [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
11#ifndef WEBRTC_MODULES_VIDEO_CODING_ENCODED_FRAME_H_
12#define WEBRTC_MODULES_VIDEO_CODING_ENCODED_FRAME_H_
13
stefan@webrtc.orgc5300432012-10-08 07:06:53 +000014#include <vector>
15
pbos@webrtc.orga4407322013-07-16 12:32:05 +000016#include "webrtc/common_types.h"
nisseea3a7982017-05-15 02:42:11 -070017#include "webrtc/common_video/include/video_frame.h"
Henrik Kjellanderff761fb2015-11-04 08:31:52 +010018#include "webrtc/modules/include/module_common_types.h"
Henrik Kjellander2557b862015-11-18 22:00:21 +010019#include "webrtc/modules/video_coding/include/video_codec_interface.h"
20#include "webrtc/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();
27 explicit VCMEncodedFrame(const webrtc::EncodedImage& rhs);
28 VCMEncodedFrame(const VCMEncodedFrame& rhs);
niklase@google.com470e71d2011-07-07 08:21:25 +000029
philipel9d3ab612015-12-21 04:12:39 -080030 ~VCMEncodedFrame();
31 /**
32 * Delete VideoFrame and resets members to zero
33 */
34 void Free();
35 /**
36 * Set render time in milliseconds
37 */
38 void SetRenderTime(const int64_t renderTimeMs) {
39 _renderTimeMs = renderTimeMs;
40 }
niklase@google.com470e71d2011-07-07 08:21:25 +000041
philipel9d3ab612015-12-21 04:12:39 -080042 /**
43 * Set the encoded frame size
44 */
45 void SetEncodedSize(uint32_t width, uint32_t height) {
46 _encodedWidth = width;
47 _encodedHeight = height;
48 }
gnishb2a318b2017-05-10 09:21:33 -070049
50 void SetPlayoutDelay(PlayoutDelay playout_delay) {
51 playout_delay_ = playout_delay;
52 }
53
philipel9d3ab612015-12-21 04:12:39 -080054 /**
55 * Get the encoded image
56 */
57 const webrtc::EncodedImage& EncodedImage() const {
58 return static_cast<const webrtc::EncodedImage&>(*this);
59 }
60 /**
61 * Get pointer to frame buffer
62 */
63 const uint8_t* Buffer() const { return _buffer; }
64 /**
65 * Get frame length
66 */
67 size_t Length() const { return _length; }
68 /**
69 * Get frame timestamp (90kHz)
70 */
71 uint32_t TimeStamp() const { return _timeStamp; }
72 /**
73 * Get render time in milliseconds
74 */
75 int64_t RenderTimeMs() const { return _renderTimeMs; }
76 /**
77 * Get frame type
78 */
79 webrtc::FrameType FrameType() const { return _frameType; }
80 /**
81 * Get frame rotation
82 */
perkj414dda12016-07-04 01:45:23 -070083 VideoRotation rotation() const { return rotation_; }
philipel9d3ab612015-12-21 04:12:39 -080084 /**
ilnik00d802b2017-04-11 10:34:31 -070085 * Get video content type
86 */
87 VideoContentType contentType() const { return content_type_; }
88 /**
89 * True if this frame is complete, false otherwise
90 */
philipel9d3ab612015-12-21 04:12:39 -080091 bool Complete() const { return _completeFrame; }
92 /**
93 * True if there's a frame missing before this frame
94 */
95 bool MissingFrame() const { return _missingFrame; }
96 /**
97 * Payload type of the encoded payload
98 */
99 uint8_t PayloadType() const { return _payloadType; }
100 /**
101 * Get codec specific info.
102 * The returned pointer is only valid as long as the VCMEncodedFrame
103 * is valid. Also, VCMEncodedFrame owns the pointer and will delete
104 * the object.
105 */
106 const CodecSpecificInfo* CodecSpecific() const { return &_codecSpecificInfo; }
niklase@google.com470e71d2011-07-07 08:21:25 +0000107
philipel9d3ab612015-12-21 04:12:39 -0800108 protected:
109 /**
110 * Verifies that current allocated buffer size is larger than or equal to the
111 * input size.
112 * If the current buffer size is smaller, a new allocation is made and the old
113 * buffer data
114 * is copied to the new buffer.
115 * Buffer size is updated to minimumSize.
116 */
117 void VerifyAndAllocate(size_t minimumSize);
niklase@google.com470e71d2011-07-07 08:21:25 +0000118
philipel9d3ab612015-12-21 04:12:39 -0800119 void Reset();
niklase@google.com470e71d2011-07-07 08:21:25 +0000120
philipel9d3ab612015-12-21 04:12:39 -0800121 void CopyCodecSpecific(const RTPVideoHeader* header);
henrik.lundin@webrtc.org473bac82011-08-17 09:47:33 +0000122
philipel9d3ab612015-12-21 04:12:39 -0800123 int64_t _renderTimeMs;
124 uint8_t _payloadType;
125 bool _missingFrame;
126 CodecSpecificInfo _codecSpecificInfo;
127 webrtc::VideoCodecType _codec;
guoweis@webrtc.org54d072e2015-03-17 21:54:50 +0000128
philipel9d3ab612015-12-21 04:12:39 -0800129 // Video rotation is only set along with the last packet for each frame
130 // (same as marker bit). This |_rotation_set| is only for debugging purpose
131 // to ensure we don't set it twice for a frame.
132 bool _rotation_set;
niklase@google.com470e71d2011-07-07 08:21:25 +0000133};
134
pbos@webrtc.orgd900e8b2013-07-03 15:12:26 +0000135} // namespace webrtc
niklase@google.com470e71d2011-07-07 08:21:25 +0000136
philipel9d3ab612015-12-21 04:12:39 -0800137#endif // WEBRTC_MODULES_VIDEO_CODING_ENCODED_FRAME_H_