Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(354)

Side by Side Diff: webrtc/api/video/video_frame.h

Issue 2517173004: Move VideoFrame and related declarations to webrtc/api/video. (Closed)
Patch Set: Address include and comment nits. Created 4 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2014 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2014 The WebRTC project authors. All Rights Reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 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 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 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
11 #ifndef WEBRTC_VIDEO_FRAME_H_ 11 #ifndef WEBRTC_API_VIDEO_VIDEO_FRAME_H_
12 #define WEBRTC_VIDEO_FRAME_H_ 12 #define WEBRTC_API_VIDEO_VIDEO_FRAME_H_
13 13
14 #include "webrtc/base/scoped_ref_ptr.h" 14 #include <stdint.h>
15 #include "webrtc/base/timeutils.h" 15
16 #include "webrtc/common_types.h" 16 #include "webrtc/api/video/rotation.h"
17 #include "webrtc/common_video/include/video_frame_buffer.h" 17 #include "webrtc/api/video/video_frame_buffer.h"
18 #include "webrtc/common_video/rotation.h"
19 #include "webrtc/typedefs.h"
20 18
21 namespace webrtc { 19 namespace webrtc {
22 20
23 class VideoFrame { 21 class VideoFrame {
24 public: 22 public:
25 // TODO(nisse): Deprecated. Using the default constructor violates the 23 // TODO(nisse): Deprecated. Using the default constructor violates the
26 // reasonable assumption that video_frame_buffer() returns a valid buffer. 24 // reasonable assumption that video_frame_buffer() returns a valid buffer.
27 VideoFrame(); 25 VideoFrame();
28 26
29 // TODO(nisse): This constructor is consistent with 27 // TODO(nisse): This constructor is consistent with
30 // cricket::WebRtcVideoFrame. After the class 28 // cricket::WebRtcVideoFrame. After the class
31 // cricket::WebRtcVideoFrame and its baseclass cricket::VideoFrame 29 // cricket::WebRtcVideoFrame and its baseclass cricket::VideoFrame
32 // are deleted, we should consider whether or not we want to stick 30 // are deleted, we should consider whether or not we want to stick
33 // to this style and deprecate the other constructors. 31 // to this style and deprecate the other constructors.
34 VideoFrame(const rtc::scoped_refptr<VideoFrameBuffer>& buffer, 32 VideoFrame(const rtc::scoped_refptr<VideoFrameBuffer>& buffer,
35 webrtc::VideoRotation rotation, 33 webrtc::VideoRotation rotation,
36 int64_t timestamp_us); 34 int64_t timestamp_us);
37 35
38 // Preferred constructor. 36 // Preferred constructor.
39 VideoFrame(const rtc::scoped_refptr<VideoFrameBuffer>& buffer, 37 VideoFrame(const rtc::scoped_refptr<VideoFrameBuffer>& buffer,
40 uint32_t timestamp, 38 uint32_t timestamp,
41 int64_t render_time_ms, 39 int64_t render_time_ms,
42 VideoRotation rotation); 40 VideoRotation rotation);
43 41
42 ~VideoFrame();
43
44 // Support move and copy. 44 // Support move and copy.
45 VideoFrame(const VideoFrame&) = default; 45 VideoFrame(const VideoFrame&);
46 VideoFrame(VideoFrame&&) = default; 46 VideoFrame(VideoFrame&&);
47 VideoFrame& operator=(const VideoFrame&) = default; 47 VideoFrame& operator=(const VideoFrame&);
48 VideoFrame& operator=(VideoFrame&&) = default; 48 VideoFrame& operator=(VideoFrame&&);
49 49
50 // Get frame width. 50 // Get frame width.
51 int width() const; 51 int width() const;
52 52
53 // Get frame height. 53 // Get frame height.
54 int height() const; 54 int height() const;
55 55
56 // System monotonic clock, same timebase as rtc::TimeMicros(). 56 // System monotonic clock, same timebase as rtc::TimeMicros().
57 int64_t timestamp_us() const { return timestamp_us_; } 57 int64_t timestamp_us() const { return timestamp_us_; }
58 void set_timestamp_us(int64_t timestamp_us) { 58 void set_timestamp_us(int64_t timestamp_us) { timestamp_us_ = timestamp_us; }
59 timestamp_us_ = timestamp_us;
60 }
61 59
62 // TODO(nisse): After the cricket::VideoFrame and webrtc::VideoFrame 60 // TODO(nisse): After the cricket::VideoFrame and webrtc::VideoFrame
63 // merge, timestamps other than timestamp_us will likely be 61 // merge, timestamps other than timestamp_us will likely be
64 // deprecated. 62 // deprecated.
65 63
66 // Set frame timestamp (90kHz). 64 // Set frame timestamp (90kHz).
67 void set_timestamp(uint32_t timestamp) { timestamp_rtp_ = timestamp; } 65 void set_timestamp(uint32_t timestamp) { timestamp_rtp_ = timestamp; }
68 66
69 // Get frame timestamp (90kHz). 67 // Get frame timestamp (90kHz).
70 uint32_t timestamp() const { return timestamp_rtp_; } 68 uint32_t timestamp() const { return timestamp_rtp_; }
71 69
72 // For now, transport_frame_id and rtp timestamp are the same. 70 // For now, transport_frame_id and rtp timestamp are the same.
73 // TODO(nisse): Must be handled differently for QUIC. 71 // TODO(nisse): Must be handled differently for QUIC.
74 uint32_t transport_frame_id() const { return timestamp(); } 72 uint32_t transport_frame_id() const { return timestamp(); }
75 73
76 // Set capture ntp time in milliseconds. 74 // Set capture ntp time in milliseconds.
77 void set_ntp_time_ms(int64_t ntp_time_ms) { 75 void set_ntp_time_ms(int64_t ntp_time_ms) { ntp_time_ms_ = ntp_time_ms; }
78 ntp_time_ms_ = ntp_time_ms;
79 }
80 76
81 // Get capture ntp time in milliseconds. 77 // Get capture ntp time in milliseconds.
82 int64_t ntp_time_ms() const { return ntp_time_ms_; } 78 int64_t ntp_time_ms() const { return ntp_time_ms_; }
83 79
84 // Naming convention for Coordination of Video Orientation. Please see 80 // Naming convention for Coordination of Video Orientation. Please see
85 // http://www.etsi.org/deliver/etsi_ts/126100_126199/126114/12.07.00_60/ts_126 114v120700p.pdf 81 // http://www.etsi.org/deliver/etsi_ts/126100_126199/126114/12.07.00_60/ts_126 114v120700p.pdf
86 // 82 //
87 // "pending rotation" or "pending" = a frame that has a VideoRotation > 0. 83 // "pending rotation" or "pending" = a frame that has a VideoRotation > 0.
88 // 84 //
89 // "not pending" = a frame that has a VideoRotation == 0. 85 // "not pending" = a frame that has a VideoRotation == 0.
90 // 86 //
91 // "apply rotation" = modify a frame from being "pending" to being "not 87 // "apply rotation" = modify a frame from being "pending" to being "not
92 // pending" rotation (a no-op for "unrotated"). 88 // pending" rotation (a no-op for "unrotated").
93 // 89 //
94 VideoRotation rotation() const { return rotation_; } 90 VideoRotation rotation() const { return rotation_; }
95 void set_rotation(VideoRotation rotation) { 91 void set_rotation(VideoRotation rotation) { rotation_ = rotation; }
96 rotation_ = rotation;
97 }
98 92
99 // Set render time in milliseconds. 93 // Set render time in milliseconds.
100 void set_render_time_ms(int64_t render_time_ms) { 94 void set_render_time_ms(int64_t render_time_ms);
101 set_timestamp_us(render_time_ms * rtc::kNumMicrosecsPerMillisec);;
102 }
103 95
104 // Get render time in milliseconds. 96 // Get render time in milliseconds.
105 int64_t render_time_ms() const { 97 int64_t render_time_ms() const;
106 return timestamp_us() / rtc::kNumMicrosecsPerMillisec;
magjed_webrtc 2016/11/29 15:43:49 Why are some implementations (but not all) moved t
nisse-webrtc 2016/11/29 15:56:15 I moved this one, because I wanted to avoid having
magjed_webrtc 2016/11/29 16:40:26 Ok, then I understand. No you can leave the other
107 }
108 98
109 // Return true if and only if video_frame_buffer() is null. Which is possible 99 // Return true if and only if video_frame_buffer() is null. Which is possible
110 // only if the object was default-constructed. 100 // only if the object was default-constructed.
111 // TODO(nisse): Deprecated. Should be deleted in the cricket::VideoFrame and 101 // TODO(nisse): Deprecated. Should be deleted in the cricket::VideoFrame and
112 // webrtc::VideoFrame merge. The intention is that video_frame_buffer() never 102 // webrtc::VideoFrame merge. The intention is that video_frame_buffer() never
113 // should return nullptr. To handle potentially uninitialized or non-existent 103 // should return nullptr. To handle potentially uninitialized or non-existent
114 // frames, consider using rtc::Optional. Otherwise, IsZeroSize() can be 104 // frames, consider using rtc::Optional. Otherwise, IsZeroSize() can be
115 // replaced by video_frame_buffer() == nullptr. 105 // replaced by video_frame_buffer() == nullptr.
116 bool IsZeroSize() const; 106 bool IsZeroSize() const;
117 107
118 // Return the underlying buffer. Never nullptr for a properly 108 // Return the underlying buffer. Never nullptr for a properly
119 // initialized VideoFrame. 109 // initialized VideoFrame.
120 rtc::scoped_refptr<webrtc::VideoFrameBuffer> video_frame_buffer() const; 110 rtc::scoped_refptr<webrtc::VideoFrameBuffer> video_frame_buffer() const;
121 111
122 // Return true if the frame is stored in a texture. 112 // Return true if the frame is stored in a texture.
123 bool is_texture() const { 113 bool is_texture() const {
124 return video_frame_buffer() && 114 return video_frame_buffer() &&
125 video_frame_buffer()->native_handle() != nullptr; 115 video_frame_buffer()->native_handle() != nullptr;
126 } 116 }
127 117
128 private: 118 private:
129 // An opaque reference counted handle that stores the pixel data. 119 // An opaque reference counted handle that stores the pixel data.
130 rtc::scoped_refptr<webrtc::VideoFrameBuffer> video_frame_buffer_; 120 rtc::scoped_refptr<webrtc::VideoFrameBuffer> video_frame_buffer_;
131 uint32_t timestamp_rtp_; 121 uint32_t timestamp_rtp_;
132 int64_t ntp_time_ms_; 122 int64_t ntp_time_ms_;
133 int64_t timestamp_us_; 123 int64_t timestamp_us_;
134 VideoRotation rotation_; 124 VideoRotation rotation_;
135 }; 125 };
136 126
127 } // namespace webrtc
137 128
138 // TODO(pbos): Rename EncodedFrame and reformat this class' members. 129 #endif // WEBRTC_API_VIDEO_VIDEO_FRAME_H_
139 class EncodedImage {
140 public:
141 static const size_t kBufferPaddingBytesH264;
142
143 // Some decoders require encoded image buffers to be padded with a small
144 // number of additional bytes (due to over-reading byte readers).
145 static size_t GetBufferPaddingBytes(VideoCodecType codec_type);
146
147 EncodedImage() : EncodedImage(nullptr, 0, 0) {}
148
149 EncodedImage(uint8_t* buffer, size_t length, size_t size)
150 : _buffer(buffer), _length(length), _size(size) {}
151
152 struct AdaptReason {
153 AdaptReason()
154 : quality_resolution_downscales(-1),
155 bw_resolutions_disabled(-1) {}
156
157 int quality_resolution_downscales; // Number of times this frame is down
158 // scaled in resolution due to quality.
159 // Or -1 if information is not provided.
160 int bw_resolutions_disabled; // Number of resolutions that are not sent
161 // due to bandwidth for this frame.
162 // Or -1 if information is not provided.
163 };
164 uint32_t _encodedWidth = 0;
165 uint32_t _encodedHeight = 0;
166 uint32_t _timeStamp = 0;
167 // NTP time of the capture time in local timebase in milliseconds.
168 int64_t ntp_time_ms_ = 0;
169 int64_t capture_time_ms_ = 0;
170 FrameType _frameType = kVideoFrameDelta;
171 uint8_t* _buffer;
172 size_t _length;
173 size_t _size;
174 VideoRotation rotation_ = kVideoRotation_0;
175 bool _completeFrame = false;
176 AdaptReason adapt_reason_;
177 int qp_ = -1; // Quantizer value.
178
179 // When an application indicates non-zero values here, it is taken as an
180 // indication that all future frames will be constrained with those limits
181 // until the application indicates a change again.
182 PlayoutDelay playout_delay_ = {-1, -1};
183 };
184
185 } // namespace webrtc
186 #endif // WEBRTC_VIDEO_FRAME_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698