24#include <vrs/Record.h>
146 static constexpr uint8_t kQualityUndefined = 255;
147 static constexpr double kInvalidTimestamp = -1E-308;
155 double keyFrameTimestamp,
156 uint32_t keyFrameIndex);
165 uint32_t stride2 = 0,
166 string codecName = {},
167 uint8_t codecQuality = kQualityUndefined,
168 double keyFrameTimestamp = kInvalidTimestamp,
169 uint32_t keyFrameIndex = 0);
175 uint32_t height = 0);
190 uint8_t codecQuality = kQualityUndefined,
195 uint32_t stride2 = 0);
200 uint8_t codecQuality,
205 uint32_t stride2 = 0);
217 uint32_t stride2 = 0,
218 string codecName = {},
219 uint8_t codecQuality = kQualityUndefined,
220 double keyFrameTimestamp = kInvalidTimestamp,
221 uint32_t keyFrameIndex = 0);
280 uint32_t getRawStride2()
const {
325 return isQualityValid(codecQuality_) ? codecQuality_ : kQualityUndefined;
330 return quality <= 100;
335 return keyFrameTimestamp_;
341 return keyFrameIndex_;
351 return toString(pixelFormat);
367 uint32_t stride2_{0};
370 double keyFrameTimestamp_{kInvalidTimestamp};
371 uint32_t keyFrameIndex_{0};
372 uint8_t codecQuality_{kQualityUndefined};
387 uint8_t channelCount = 0,
388 uint8_t sampleFrameStride = 0,
389 uint32_t sampleFrameRate = 0,
390 uint32_t sampleFrameCount = 0,
391 uint8_t stereoPairCount = 0);
409 return !operator==(rhs);
429 return sampleFormat_;
453 return channelCount_;
457 return sampleFrameRate_;
461 return sampleFrameCount_;
465 sampleFrameCount_ = sampleCount;
468 uint8_t getStereoPairCount()
const {
469 return stereoPairCount_;
486 return toString(sampleFormat);
492 uint8_t sampleFrameStride_{};
493 uint8_t channelCount_{};
494 uint32_t sampleFrameRate_{};
495 uint32_t sampleFrameCount_{};
496 uint8_t stereoPairCount_{};
527 std::string codecName,
528 uint8_t codecQuality,
533 uint32_t stride2 = 0);
541 uint32_t stride2 = 0);
549 double keyFrameTimestamp,
550 uint32_t keyFrameIndex);
560 uint8_t numChannels = 0,
561 uint8_t sampleFrameStride = 0,
562 uint32_t sampleRate = 0,
563 uint32_t sampleCount = 0,
564 uint8_t stereoPairCount = 0);
572 : contentType_{other.contentType_}, size_{size} {
574 imageSpec_ = other.imageSpec_;
576 audioSpec_ = other.audioSpec_;
578 customContentBlockFormat_ = other.customContentBlockFormat_;
582 ~ContentBlock() =
default;
584 ContentBlock& operator=(
const ContentBlock& rhs) =
default;
585 ContentBlock& operator=(ContentBlock&& rhs)
noexcept =
default;
601 return customContentBlockFormat_;
607 return !operator==(rhs);
611 RecordFormat
operator+(
const ContentBlock&)
const;
614 const ImageContentBlockSpec&
image()
const;
616 const AudioContentBlockSpec&
audio()
const;
621 ImageContentBlockSpec imageSpec_;
622 AudioContentBlockSpec audioSpec_;
623 string customContentBlockFormat_;
648 uint32_t formatVersionIn,
651 recordType(recordTypeIn),
652 formatVersion(formatVersionIn),
653 blockIndex(blockIndexIn) {}
663 uint32_t getFormatVersion()
const {
664 return formatVersion;
667 size_t getBlockIndex()
const {
674 uint32_t formatVersion;
713 blocks_.emplace_back(block);
717 blocks_.emplace_back(std::move(block));
721 blocks_.emplace_back(first);
722 blocks_.emplace_back(second);
726 blocks_.emplace_back(std::move(first));
727 blocks_.emplace_back(std::move(second));
734 blocks_.emplace_back(type, size);
739 blocks_.emplace_back(block);
744 blocks_.emplace_back(std::move(block));
750 return !operator==(rhs);
759 void set(
const string& format);
794 size_t getBlockSize(
size_t blockIndex,
size_t remainingSize)
const;
800 static string getDataLayoutTagName(
Record::Type type, uint32_t version,
size_t blockIndex);
804 const string& tagName,
806 uint32_t& formatVersion);
811 map<string, string>& inOutRecordFormatRegister,
813 uint32_t formatVersion,
815 const vector<const DataLayout*>& layouts);
817 static void getRecordFormats(
818 const map<string, string>& recordFormatRegister,
821 static unique_ptr<DataLayout> getDataLayout(
822 const map<string, string>& recordFormatRegister,
826 vector<ContentBlock> blocks_;
Specification of an audio content block.
Definition RecordFormat.h:376
uint8_t getChannelCount() const
Get the number of audio channels in each sample frame (not in the content block).
Definition RecordFormat.h:452
void setSampleCount(uint32_t sampleCount)
Set the number of audio sample frames in the content block.
Definition RecordFormat.h:464
string asString() const
Definition RecordFormat.cpp:787
uint8_t getBitsPerSample() const
Get the number of bits per audio sample.
Definition RecordFormat.h:442
AudioContentBlockSpec(const AudioContentBlockSpec &)=default
Default copy constructor.
bool isLittleEndian() const
Tell if the audio sample format is little endian.
Definition RecordFormat.h:434
bool isSampleBlockFormatDefined() const
Definition RecordFormat.cpp:840
size_t getPcmBlockSize() const
Assuming PCM, get the number of bytes for this content block, or ContentBlock::kSizeUnknown.
Definition RecordFormat.cpp:816
uint32_t getSampleCount() const
Get the number of audio sample frames in the content block.
Definition RecordFormat.h:460
void clear()
Clear/reset object to default values.
Definition RecordFormat.cpp:727
uint8_t getBytesPerSample() const
Get the number of bytes per audio sample.
Definition RecordFormat.h:446
uint8_t getSampleFrameStride() const
Number of bytes used by a group of synchronous audio samples, including padding.
Definition RecordFormat.cpp:934
uint32_t getSampleRate() const
Get the audio frame sample rate.
Definition RecordFormat.h:456
bool isIEEEFloat() const
Tell if the audio sample format is an IEEE float.
Definition RecordFormat.h:438
AudioFormat getAudioFormat() const
Get audio format.
Definition RecordFormat.h:424
AudioSampleFormat getSampleFormat() const
Get audio sample format.
Definition RecordFormat.h:428
size_t getBlockSize() const
Get the number of bytes for this content block, or ContentBlock::kSizeUnknown.
Definition RecordFormat.cpp:812
string getSampleFormatAsString() const
Get audio sample format as a string.
Definition RecordFormat.cpp:836
bool isCompatibleWith(const AudioContentBlockSpec &rhs) const
Tell if two audio block have identical audio formats.
Definition RecordFormat.cpp:830
static string getSampleFormatAsString(AudioSampleFormat sampleFormat)
Get an audio sample format as a string.
Definition RecordFormat.h:485
Specification of a VRS record content block.
Definition RecordFormat.h:511
size_t getBlockSize() const
Get the content block size, if available or calculable.
Definition RecordFormat.cpp:1078
ContentBlock(const ContentBlock &)=default
Default copy constructor.
string asString() const
Conversion to string, to store on disk & reconstruct later using constructor.
Definition RecordFormat.cpp:1048
const ImageContentBlockSpec & image() const
Get the image content spec. Requires the content block to be of type ContentType::IMAGE.
Definition RecordFormat.cpp:1120
ContentBlock(ContentType type=ContentType::EMPTY, size_t size=kSizeUnknown)
Very generic block description.
Definition RecordFormat.cpp:1000
ContentType getContentType() const
Get the ContentType of the block.
Definition RecordFormat.h:594
string getCustomContentBlockFormat() const
Definition RecordFormat.h:600
const AudioContentBlockSpec & audio() const
Get the audio content spec. Requires the content block to be of type ContentType::AUDIO.
Definition RecordFormat.cpp:1125
RecordFormat operator+(const ContentBlock &) const
Assembly operator, to construct a RecordFormat for ContentBlock parts.
Definition RecordFormat.cpp:1116
ContentBlock(std::string codecName, uint8_t codecQuality, PixelFormat pixelFormat=PixelFormat::UNDEFINED, uint32_t width=0, uint32_t height=0, uint32_t stride=0, uint32_t stride2=0)
Image formats with custom codec encoding.
static const size_t kSizeUnknown
Special value used to represent an unknown block size.
Definition RecordFormat.h:514
Helper to identify a particular content block within a file.
Definition RecordFormat.h:643
RecordFormat string parsing helper class.
Definition RecordFormat.cpp:37
Definition RecordFormat.h:626
Specification of an image content block.
Definition RecordFormat.h:144
ImageContentBlockSpec & operator=(const ImageContentBlockSpec &)=default
Default copy assignment.
void set(ContentParser &parser)
When constructing from a string.
Definition RecordFormat.cpp:388
void clear()
Clear/reset object to default values.
Definition RecordFormat.cpp:345
uint32_t getDefaultStride2() const
Get default stride for planes N > 0, when stride2 isn't specified (minimum stride2 value)
Definition RecordFormat.cpp:598
uint8_t getCodecQuality() const
Definition RecordFormat.h:324
string getPixelFormatAsString() const
Get pixel format presented as a readable string, from which it can be reconstructed.
Definition RecordFormat.cpp:649
uint32_t getKeyFrameIndex() const
Definition RecordFormat.h:340
string asString() const
Definition RecordFormat.cpp:433
size_t getBytesPerPixel() const
Definition RecordFormat.h:312
uint32_t getHeight() const
Get image height, or 0 if unknown/unspecified.
Definition RecordFormat.h:270
string getImageFormatAsString() const
Get Image format as string.
Definition RecordFormat.cpp:653
uint32_t getPlaneHeight(uint32_t planeIndex) const
Definition RecordFormat.cpp:612
uint32_t getStride() const
Get image stride (number of bytes between rows) for the first plane.
Definition RecordFormat.cpp:657
PixelFormat getPixelFormat() const
Get Pixel format.
Definition RecordFormat.h:260
static string getPixelFormatAsString(PixelFormat pixelFormat)
Get pixel format presented as a readable string, from which it can be reconstructed.
Definition RecordFormat.h:350
const string & getCodecName() const
Definition RecordFormat.h:318
uint32_t getPlaneStride(uint32_t planeIndex) const
Definition RecordFormat.cpp:588
bool sanityCheckStrides() const
Definition RecordFormat.cpp:575
size_t getRawImageSize() const
Definition RecordFormat.cpp:635
uint32_t getRawStride() const
Definition RecordFormat.h:277
size_t getBlockSize() const
Definition RecordFormat.cpp:631
ImageContentBlockSpec core() const
Return base of format (no codec quality nor key frame info)
Definition RecordFormat.cpp:356
double getKeyFrameTimestamp() const
Get timestamp of the key frame of the group of frames this video frame belongs to.
Definition RecordFormat.h:334
uint32_t getDefaultStride() const
Get default stride for plane 0 when stride isn't specified (minimum stride value)
Definition RecordFormat.cpp:662
static bool isQualityValid(uint8_t quality)
Validate that a quality value is valid.
Definition RecordFormat.h:329
uint8_t getChannelCountPerPixel() const
Definition RecordFormat.h:305
ImageFormat getImageFormat() const
Get image format.
Definition RecordFormat.h:252
uint32_t getPlaneCount() const
Get the number of planes for this pixel format.
Definition RecordFormat.h:289
uint32_t getWidth() const
Get image width, or 0 if unknown/unspecified.
Definition RecordFormat.h:266
Type
Definition Record.h:90
Definition Compressor.cpp:113
map< pair< Record::Type, uint32_t >, RecordFormat > RecordFormatMap
Map a pair of record type/format version to a record format, for a particular stream.
Definition RecordFormat.h:633
PixelFormat
Pixel format type, then the image format is ImageFormat::RAW.
Definition RecordFormat.h:63
@ GREY12
uses 16 bit little-endian values. 4 most significant bits are unused and set to 0.
@ UNDEFINED
Unknown/unrecognized.
@ GREY10
uses 16 bit little-endian values. 6 most significant bits are unused and set to 0.
@ RGB8
3 uint8_t values, red + green + blue.
@ DEPTH32F
1 32 bit float value, representing a depth.
@ YUV_420_NV21
Y plane + half width/half height chroma plane with weaved V and U values.
@ RAW10
https://developer.android.com/reference/android/graphics/ImageFormat#RAW10
@ RAW10_BAYER_RGGB
10 bit per pixel, RGGB bayer pattern.
@ YUV_I420_PLANAR
same as YUV_I420_SPLIT, but more conventional name.
@ YUV_I420_SPLIT
3 uint8_t values, 4:2:0. The 3 planes are stored separately.
@ RGBA32F
1 32 bit float value.
@ BAYER8_RGGB
8 bit per pixel, RGGB bayer pattern.
@ RAW10_BAYER_BGGR
10 bit per pixel, BGGR bayer pattern.
@ BAYER8_GBRG
8 bit per pixel, GBRG bayer pattern.
@ RGB10
uses 16 bit little-endian values. 6 most significant bits are unused and set to 0.
@ BAYER10_GBRG
10 bit per pixel, GBRG bayer pattern.
@ RGBA8
4 uint8_t values, red + blue + green + alpha.
@ YUY2
4 uint8_t values, 4:2:2, single plane.
@ YUV_420_NV12
Y plane + half width/half height chroma plane with weaved U and V values.
@ RGB12
uses 16 bit little-endian values. 4 most significant bits are unused and set to 0.
@ BAYER8_BGGR
8 bit per pixel, BGGR bayer pattern.
@ RGB32F
1 32 bit float value.
@ GREY10PACKED
10 bit per pixel, packed in successive little-endian bits, in 40 bits blocks.
@ SCALAR64F
1 64 bit float value, representing high precision image data.
@ BGR8
3 uint8_t values, blue + green + red.
@ GREY16
uses 16 bit little-endian values.
AudioSampleFormat
Audio sample format, when the audio type is AudioFormat::PCM.
Definition RecordFormat.h:112
@ U32_LE
LPCM, unsigned, 32 bit little endian.
@ F64_BE
LPCM, 64 bit float big endian.
@ U16_BE
LPCM, unsigned, 16 bit big endian.
@ U32_BE
LPCM, unsigned, 32 bit big endian.
@ F64_LE
LPCM, 64 bit float little endian.
@ S32_BE
LPCM, signed, 32 bit big endian.
@ U8
LPCM, unsigned, 8 bit.
@ S16_BE
LPCM, signed, 16 bit big endian.
@ F32_LE
LPCM, 32 bit float little endian.
@ S24_LE
LPCM, signed, 24 bit little endian.
@ S16_LE
LPCM, signed, 16 bit little endian.
@ U24_BE
LPCM, unsigned, 24 bit big endian.
@ S24_BE
LPCM, signed, 24 bit big endian.
@ MU_LAW
mu-law PCM, 8 bit.
@ U24_LE
LPCM, unsigned, 24 bit little endian.
@ U16_LE
LPCM, unsigned, 16 bit little endian.
@ F32_BE
LPCM, 32 bit float big endian.
@ S32_LE
LPCM, signed, 32 bit little endian.
ImageFormat
Definition RecordFormat.h:49
@ UNDEFINED
Unknown/unspecified.
@ CUSTOM_CODEC
Images encoded with a custom or experimental codec.
@ VIDEO
Video codec encoded images.
AudioFormat
Audio format type.
Definition RecordFormat.h:101
@ OPUS
Audio data compressed using Opus. https://opus-codec.org/.
RecordableTypeId
VRS stream type or class identifier enum.
Definition StreamId.h:51
ContentType
Type of a record's block.
Definition RecordFormat.h:35
@ DATA_LAYOUT
DataLayout block.
@ CUSTOM
Custom format, or unknown/unspecified data format.
@ EMPTY
No data (internal).