|  | /* | 
|  | *  Copyright (c) 2014 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 WEBRTC_VIDEO_FRAME_H_ | 
|  | #define WEBRTC_VIDEO_FRAME_H_ | 
|  |  | 
|  | // TODO(nisse): This header file should eventually be deleted. For | 
|  | // declarations of classes related to unencoded video frame, use the | 
|  | // headers under api/video instead. The EncodedImage class stays in | 
|  | // this file until we have figured out how to refactor and clean up | 
|  | // related interfaces. | 
|  |  | 
|  | #include "webrtc/api/video/video_frame.h" | 
|  | #include "webrtc/api/video/i420_buffer.h" | 
|  | #include "webrtc/common_types.h" | 
|  | #include "webrtc/typedefs.h" | 
|  |  | 
|  | namespace webrtc { | 
|  |  | 
|  | // TODO(pbos): Rename EncodedFrame and reformat this class' members. | 
|  | class EncodedImage { | 
|  | public: | 
|  | static const size_t kBufferPaddingBytesH264; | 
|  |  | 
|  | // Some decoders require encoded image buffers to be padded with a small | 
|  | // number of additional bytes (due to over-reading byte readers). | 
|  | static size_t GetBufferPaddingBytes(VideoCodecType codec_type); | 
|  |  | 
|  | EncodedImage() : EncodedImage(nullptr, 0, 0) {} | 
|  |  | 
|  | EncodedImage(uint8_t* buffer, size_t length, size_t size) | 
|  | : _buffer(buffer), _length(length), _size(size) {} | 
|  |  | 
|  | // TODO(kthelgason): get rid of this struct as it only has a single member | 
|  | // remaining. | 
|  | struct AdaptReason { | 
|  | AdaptReason() : bw_resolutions_disabled(-1) {} | 
|  | int bw_resolutions_disabled;  // Number of resolutions that are not sent | 
|  | // due to bandwidth for this frame. | 
|  | // Or -1 if information is not provided. | 
|  | }; | 
|  | uint32_t _encodedWidth = 0; | 
|  | uint32_t _encodedHeight = 0; | 
|  | uint32_t _timeStamp = 0; | 
|  | // NTP time of the capture time in local timebase in milliseconds. | 
|  | int64_t ntp_time_ms_ = 0; | 
|  | int64_t capture_time_ms_ = 0; | 
|  | FrameType _frameType = kVideoFrameDelta; | 
|  | uint8_t* _buffer; | 
|  | size_t _length; | 
|  | size_t _size; | 
|  | VideoRotation rotation_ = kVideoRotation_0; | 
|  | bool _completeFrame = false; | 
|  | AdaptReason adapt_reason_; | 
|  | int qp_ = -1;  // Quantizer value. | 
|  |  | 
|  | // When an application indicates non-zero values here, it is taken as an | 
|  | // indication that all future frames will be constrained with those limits | 
|  | // until the application indicates a change again. | 
|  | PlayoutDelay playout_delay_ = {-1, -1}; | 
|  | }; | 
|  |  | 
|  | }  // namespace webrtc | 
|  | #endif  // WEBRTC_VIDEO_FRAME_H_ |