Also adds a set_buffer method, as the only public setter for capacity_. Bug: webrtc:9378 Change-Id: If0257c6d00bc8690f0428a3edc20b6da6dfa7119 Reviewed-on: https://webrtc-review.googlesource.com/c/112134 Commit-Queue: Niels Moller <nisse@webrtc.org> Reviewed-by: Philip Eliasson <philipel@webrtc.org> Reviewed-by: Erik Språng <sprang@webrtc.org> Cr-Commit-Position: refs/heads/master@{#25962}
43 lines
1.4 KiB
C++
43 lines
1.4 KiB
C++
/*
|
|
* Copyright (c) 2012 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.
|
|
*/
|
|
|
|
#include "api/video/encoded_image.h"
|
|
|
|
#include <string.h>
|
|
|
|
namespace webrtc {
|
|
|
|
// FFmpeg's decoder, used by H264DecoderImpl, requires up to 8 bytes padding due
|
|
// to optimized bitstream readers. See avcodec_decode_video2.
|
|
const size_t EncodedImage::kBufferPaddingBytesH264 = 8;
|
|
|
|
size_t EncodedImage::GetBufferPaddingBytes(VideoCodecType codec_type) {
|
|
switch (codec_type) {
|
|
case kVideoCodecH264:
|
|
return kBufferPaddingBytesH264;
|
|
default:
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
EncodedImage::EncodedImage() : EncodedImage(nullptr, 0, 0) {}
|
|
|
|
EncodedImage::EncodedImage(const EncodedImage&) = default;
|
|
|
|
EncodedImage::EncodedImage(uint8_t* buffer, size_t length, size_t capacity)
|
|
: _buffer(buffer), _length(length), capacity_(capacity) {}
|
|
|
|
void EncodedImage::SetEncodeTime(int64_t encode_start_ms,
|
|
int64_t encode_finish_ms) {
|
|
timing_.encode_start_ms = encode_start_ms;
|
|
timing_.encode_finish_ms = encode_finish_ms;
|
|
}
|
|
} // namespace webrtc
|