Tag Parser 12.4.0
C++ library for reading and writing MP4 (iTunes), ID3, Vorbis, Opus, FLAC and Matroska tags
|
The AbstractTrack class parses and stores technical information about video, audio and other kinds of media tracks. More...
#include <abstracttrack.h>
Public Member Functions | |
virtual | ~AbstractTrack () |
Destroys the track. | |
virtual TrackType | type () const |
Returns the type of the track if known; otherwise returns TrackType::Unspecified. | |
std::istream & | inputStream () |
Returns the associated input stream. | |
void | setInputStream (std::istream &stream) |
Assigns another input stream. | |
std::ostream & | outputStream () |
Returns the associated output stream. | |
void | setOutputStream (std::ostream &stream) |
Assigns another output stream. | |
CppUtilities::BinaryReader & | reader () |
Returns a binary reader for the associated stream. | |
CppUtilities::BinaryWriter & | writer () |
Returns a binary writer for the associated stream. | |
std::uint64_t | startOffset () const |
Returns the start offset of the track in the associated stream. | |
TrackFlags | flags () const |
Returns flags (various boolean properties) of this track. | |
MediaFormat | format () const |
Returns the format of the track if known; otherwise returns MediaFormat::Unknown. | |
double | version () const |
Returns the version/level of the track if known; otherwise returns 0. | |
std::string_view | formatName () const |
Returns the format of the track as C-style string if known; otherwise returns the format abbreviation or an empty string. | |
std::string_view | formatAbbreviation () const |
Returns the a more or less common abbreviation for the format of the track if known; otherwise returns an empty string. | |
const std::string & | formatId () const |
Returns the format/codec ID. | |
MediaType | mediaType () const |
Returns the media type if known; otherwise returns MediaType::Other. | |
std::string_view | mediaTypeName () const |
Returns the string representation of the media type of the track. | |
std::uint64_t | size () const |
Returns the size in bytes if known; otherwise returns 0. | |
void | setSize (std::uint64_t size) |
Sets the size in bytes. | |
std::uint32_t | trackNumber () const |
Returns the track number if known; otherwise returns 0. | |
void | setTrackNumber (std::uint32_t trackNumber) |
Sets the track number. | |
std::uint64_t | id () const |
Returns the track ID if known; otherwise returns 0. | |
void | setId (std::uint64_t id) |
Sets the track ID. | |
const std::string | name () const |
Returns the track name if known; otherwise returns an empty string. | |
void | setName (std::string_view name) |
Sets the name. | |
const CppUtilities::TimeSpan & | duration () const |
Returns the duration if known; otherwise returns a TimeSpan of zero ticks. | |
double | bitrate () const |
Returns the average bitrate in kbit/s if known; otherwise returns zero. | |
double | maxBitrate () const |
Returns the maximum bitrate in kbit/s if known; otherwise returns zero. | |
const CppUtilities::DateTime & | creationTime () const |
Returns the creation time if known; otherwise returns a DateTime of zero ticks. | |
const CppUtilities::DateTime & | modificationTime () const |
Returns the time of the last modification if known; otherwise returns a DateTime of zero ticks. | |
const Locale & | locale () const |
Returns the locale of the track if known; otherwise returns an empty locale. | |
void | setLocale (const Locale &locale) |
Sets the locale of the track. | |
std::uint32_t | samplingFrequency () const |
Returns the number of samples per second if known; otherwise returns 0. | |
std::uint32_t | extensionSamplingFrequency () const |
Returns the number of samples per second if known; otherwise returns 0. | |
std::uint16_t | bitsPerSample () const |
Returns the number of bits per sample; otherwise returns 0. | |
std::uint16_t | channelCount () const |
Returns the number of channels if known; otherwise returns 0. | |
std::uint8_t | channelConfig () const |
Returns the channel configuration. | |
std::string_view | channelConfigString () const |
Returns a string with the channel configuration if available; otherwise returns nullptr. | |
std::uint8_t | extensionChannelConfig () const |
Returns the extension channel configuration if available; otherwise returns nullptr. | |
std::string_view | extensionChannelConfigString () const |
Returns a string with the extension channel configuration if available; otherwise returns nullptr. | |
std::uint64_t | sampleCount () const |
Returns the number of samples/frames if known; otherwise returns 0. | |
int | quality () const |
Returns the quality if known; otherwise returns 0. | |
const Size & | pixelSize () const |
Returns the size of the encoded video frames if known; otherwise returns a zero size. | |
const Size & | displaySize () const |
Returns the size of the video frames to display if known; otherwise returns a zero size. | |
const Size & | resolution () const |
Returns the resolution if known; otherwise returns a zero size. | |
const std::string & | compressorName () const |
Returns the compressor name if known; otherwise returns an empty string. | |
void | setCompressorName (std::string_view compressorName) |
Returns the compressor name if known; otherwise returns an empty string. | |
std::uint16_t | depth () const |
Returns the bit depth if known; otherwise returns 0. | |
std::uint32_t | fps () const |
Returns the number of frames per second if known; otherwise returns 0. | |
std::string_view | chromaFormat () const |
Returns the chroma subsampling format if known; otherwise returns nullptr. | |
const AspectRatio & | pixelAspectRatio () const |
Returns the pixel aspect ratio (PAR). | |
bool | isInterlaced () const |
Returns true if the video is interlaced; otherwise returns false. | |
std::uint32_t | timeScale () const |
Returns the time scale if known; otherwise returns 0. | |
bool | isEnabled () const |
Returns true if the track is marked as enabled; otherwise returns false. | |
void | setEnabled (bool enabled) |
Sets whether the track is enabled. | |
bool | isDefault () const |
Returns true if the track is marked as default; otherwise returns false. | |
void | setDefault (bool isDefault) |
Sets whether the track is a default track. | |
bool | isForced () const |
Returns true if the track is marked as forced; otherwise returns false. | |
void | setForced (bool forced) |
Sets whether the track is forced. | |
bool | hasLacing () const |
Returns true if the track has lacing; otherwise returns false. | |
bool | isEncrypted () const |
Returns true if the track is marked as encrypted; otherwise returns false. | |
std::uint32_t | colorSpace () const |
Returns the color space if known; otherwise returns 0. | |
const Margin & | cropping () const |
Returns the cropping if known; otherwise returns zero margins. | |
std::string | label () const |
Returns a label for the track. | |
std::string | description () const |
Returns a description about the track. | |
std::string | shortDescription () const |
Returns a short description about the track. | |
void | parseHeader (Diagnostics &diag, AbortableProgressFeedback &progress) |
Parses technical information about the track from the header. | |
bool | isHeaderValid () const |
Returns an indication whether the track header is valid. | |
Protected Member Functions | |
AbstractTrack (std::istream &inputStream, std::ostream &outputStream, std::uint64_t startOffset) | |
Constructs a new track. | |
AbstractTrack (std::iostream &stream, std::uint64_t startOffset) | |
Constructs a new track. | |
virtual void | internalParseHeader (Diagnostics &diag, AbortableProgressFeedback &progress)=0 |
This method is internally called to parse header information. | |
Friends | |
class | MpegAudioFrameStream |
class | WaveAudioStream |
class | Mp4Track |
The AbstractTrack class parses and stores technical information about video, audio and other kinds of media tracks.
The tag class only provides the interface and common functionality. It is meant to be subclassed.
|
virtual |
Destroys the track.
Definition at line 84 of file abstracttrack.cpp.
|
protected |
Constructs a new track.
inputStream | Specifies the stream the track will read from to perform particular operations such as reading header information. |
outputStream | Specifies the stream the track will write to to perform particular operations such as updating or making header information. |
startOffset | The start offset of the track in the specified stream. |
Definition at line 33 of file abstracttrack.cpp.
|
protected |
Constructs a new track.
stream | Specifies the stream the track will read from or write to to perform particular operations such as reading header information. |
startOffset | The start offset of the track in the specified stream. |
Definition at line 76 of file abstracttrack.cpp.
|
inline |
Returns the average bitrate in kbit/s if known; otherwise returns zero.
Definition at line 475 of file abstracttrack.h.
|
inline |
Returns the number of bits per sample; otherwise returns 0.
Definition at line 543 of file abstracttrack.h.
|
inline |
Returns the channel configuration.
This is the MPEG-4 channel config for MPEG-4 audio.
Definition at line 564 of file abstracttrack.h.
std::string_view TagParser::AbstractTrack::channelConfigString | ( | ) | const |
Returns a string with the channel configuration if available; otherwise returns nullptr.
Definition at line 91 of file abstracttrack.cpp.
|
inline |
Returns the number of channels if known; otherwise returns 0.
This value only makes sense for audio tracks.
Definition at line 553 of file abstracttrack.h.
|
inline |
Returns the chroma subsampling format if known; otherwise returns nullptr.
This value only makes sense for video tracks.
Definition at line 657 of file abstracttrack.h.
|
inline |
Returns the color space if known; otherwise returns 0.
Definition at line 760 of file abstracttrack.h.
|
inline |
Returns the compressor name if known; otherwise returns an empty string.
Definition at line 620 of file abstracttrack.h.
|
inline |
Returns the creation time if known; otherwise returns a DateTime of zero ticks.
Definition at line 491 of file abstracttrack.h.
|
inline |
Returns the cropping if known; otherwise returns zero margins.
Definition at line 768 of file abstracttrack.h.
|
inline |
Returns the bit depth if known; otherwise returns 0.
Definition at line 637 of file abstracttrack.h.
string TagParser::AbstractTrack::description | ( | ) | const |
Returns a description about the track.
The description contains the abbreviated format and further information depending on the media type (eg. display size in case of video, language in case of audio/text). It is intended to be joined with descriptions of other tracks to get a short technical description about the file.
Examples (exact format might change in the future!):
Definition at line 212 of file abstracttrack.cpp.
|
inline |
Returns the size of the video frames to display if known; otherwise returns a zero size.
This value only makes sense for video tracks.
Definition at line 602 of file abstracttrack.h.
|
inline |
Returns the duration if known; otherwise returns a TimeSpan of zero ticks.
Definition at line 467 of file abstracttrack.h.
std::uint8_t TagParser::AbstractTrack::extensionChannelConfig | ( | ) | const |
Returns the extension channel configuration if available; otherwise returns nullptr.
Definition at line 107 of file abstracttrack.cpp.
std::string_view TagParser::AbstractTrack::extensionChannelConfigString | ( | ) | const |
Returns a string with the extension channel configuration if available; otherwise returns nullptr.
Definition at line 115 of file abstracttrack.cpp.
|
inline |
Returns the number of samples per second if known; otherwise returns 0.
Definition at line 535 of file abstracttrack.h.
|
inline |
Returns flags (various boolean properties) of this track.
Definition at line 325 of file abstracttrack.h.
|
inline |
Returns the format of the track if known; otherwise returns MediaFormat::Unknown.
Definition at line 333 of file abstracttrack.h.
|
inline |
Returns the a more or less common abbreviation for the format of the track if known; otherwise returns an empty string.
Definition at line 361 of file abstracttrack.h.
|
inline |
Returns the format/codec ID.
This is usually the raw format identifier extracted from the container) if known; otherwise returns an empty string.
Definition at line 371 of file abstracttrack.h.
|
inline |
Returns the format of the track as C-style string if known; otherwise returns the format abbreviation or an empty string.
Definition at line 352 of file abstracttrack.h.
|
inline |
Returns the number of frames per second if known; otherwise returns 0.
This value only makes sense for video tracks.
Definition at line 647 of file abstracttrack.h.
|
inline |
Returns true if the track has lacing; otherwise returns false.
Definition at line 744 of file abstracttrack.h.
|
inline |
Returns the track ID if known; otherwise returns 0.
Definition at line 433 of file abstracttrack.h.
|
inline |
Returns the associated input stream.
Definition at line 248 of file abstracttrack.h.
|
protectedpure virtual |
This method is internally called to parse header information.
It needs to be implemented when subclassing this class.
Throws | std::ios_base::failure when an IO error occurs. |
Throws | TagParser::Failure or a derived exception when a parsing error occurs. |
Implemented in TagParser::AdtsStream, TagParser::FlacStream, TagParser::IvfStream, TagParser::MatroskaTrack, TagParser::Mp4Track, TagParser::MpegAudioFrameStream, TagParser::OggStream, and TagParser::WaveAudioStream.
|
inline |
Returns true if the track is marked as default; otherwise returns false.
Definition at line 710 of file abstracttrack.h.
|
inline |
Returns true if the track is marked as enabled; otherwise returns false.
Definition at line 693 of file abstracttrack.h.
|
inline |
Returns true if the track is marked as encrypted; otherwise returns false.
Definition at line 752 of file abstracttrack.h.
|
inline |
Returns true if the track is marked as forced; otherwise returns false.
Definition at line 727 of file abstracttrack.h.
|
inline |
Returns an indication whether the track header is valid.
Definition at line 776 of file abstracttrack.h.
|
inline |
Returns true if the video is interlaced; otherwise returns false.
This value only makes sense for video tracks.
Definition at line 675 of file abstracttrack.h.
string TagParser::AbstractTrack::label | ( | ) | const |
Returns a label for the track.
The label contains the ID, type, name and language of the track. It is intended to be used in a menu for selecting a track from the file.
Definition at line 131 of file abstracttrack.cpp.
|
inline |
Returns the locale of the track if known; otherwise returns an empty locale.
The format of the locale depends on the particular format/implementation.
Definition at line 509 of file abstracttrack.h.
|
inline |
Returns the maximum bitrate in kbit/s if known; otherwise returns zero.
Definition at line 483 of file abstracttrack.h.
|
inline |
Returns the media type if known; otherwise returns MediaType::Other.
Definition at line 379 of file abstracttrack.h.
|
inline |
Returns the string representation of the media type of the track.
Definition at line 387 of file abstracttrack.h.
|
inline |
Returns the time of the last modification if known; otherwise returns a DateTime of zero ticks.
Definition at line 499 of file abstracttrack.h.
|
inline |
Returns the track name if known; otherwise returns an empty string.
Definition at line 450 of file abstracttrack.h.
|
inline |
Returns the associated output stream.
Definition at line 267 of file abstracttrack.h.
void TagParser::AbstractTrack::parseHeader | ( | Diagnostics & | diag, |
AbortableProgressFeedback & | progress ) |
Parses technical information about the track from the header.
The information will be read from the associated stream. The stream and the start offset of the track have been specified when constructing the Track.
The parsed information can be accessed using the corresponding methods.
Throws | std::ios_base::failure when an IO error occurs. |
Throws | TagParser::Failure or a derived exception when a parsing error occurs. |
Definition at line 243 of file abstracttrack.cpp.
|
inline |
Returns the pixel aspect ratio (PAR).
Definition at line 665 of file abstracttrack.h.
|
inline |
Returns the size of the encoded video frames if known; otherwise returns a zero size.
This value only makes sense for video tracks.
Definition at line 592 of file abstracttrack.h.
|
inline |
Returns the quality if known; otherwise returns 0.
The scale depends on the format.
Definition at line 582 of file abstracttrack.h.
|
inline |
Returns a binary reader for the associated stream.
Definition at line 289 of file abstracttrack.h.
|
inline |
Returns the resolution if known; otherwise returns a zero size.
This value only makes sense for video tracks.
Definition at line 612 of file abstracttrack.h.
|
inline |
Returns the number of samples/frames if known; otherwise returns 0.
Definition at line 572 of file abstracttrack.h.
|
inline |
Returns the number of samples per second if known; otherwise returns 0.
Definition at line 526 of file abstracttrack.h.
|
inline |
Returns the compressor name if known; otherwise returns an empty string.
Definition at line 629 of file abstracttrack.h.
|
inline |
Sets whether the track is a default track.
Definition at line 719 of file abstracttrack.h.
|
inline |
Sets whether the track is enabled.
Definition at line 702 of file abstracttrack.h.
|
inline |
Sets whether the track is forced.
Definition at line 736 of file abstracttrack.h.
|
inline |
Sets the track ID.
Definition at line 442 of file abstracttrack.h.
|
inline |
Assigns another input stream.
The track will read from the stream to perform particular operations such as reading header information.
Definition at line 259 of file abstracttrack.h.
|
inline |
Sets the locale of the track.
Definition at line 518 of file abstracttrack.h.
|
inline |
Sets the name.
Definition at line 459 of file abstracttrack.h.
|
inline |
Assigns another output stream.
The track will write to the stream to perform particular operations such as updating or making header information.
Definition at line 278 of file abstracttrack.h.
|
inline |
Sets the size in bytes.
Definition at line 408 of file abstracttrack.h.
|
inline |
Sets the track number.
Definition at line 425 of file abstracttrack.h.
string TagParser::AbstractTrack::shortDescription | ( | ) | const |
Returns a short description about the track.
See description() for details.
Examples (exact format might change in the future!):
Definition at line 226 of file abstracttrack.cpp.
|
inline |
Returns the size in bytes if known; otherwise returns 0.
Definition at line 395 of file abstracttrack.h.
|
inline |
Returns the start offset of the track in the associated stream.
Definition at line 316 of file abstracttrack.h.
|
inline |
Returns the time scale if known; otherwise returns 0.
The time scale depends on the format.
Definition at line 685 of file abstracttrack.h.
|
inline |
Returns the track number if known; otherwise returns 0.
Definition at line 416 of file abstracttrack.h.
|
inlinevirtual |
Returns the type of the track if known; otherwise returns TrackType::Unspecified.
Reimplemented in TagParser::AdtsStream, TagParser::FlacStream, TagParser::IvfStream, TagParser::MatroskaTrack, TagParser::Mp4Track, TagParser::MpegAudioFrameStream, TagParser::OggStream, and TagParser::WaveAudioStream.
Definition at line 308 of file abstracttrack.h.
|
inline |
Returns the version/level of the track if known; otherwise returns 0.
Definition at line 341 of file abstracttrack.h.
|
inline |
Returns a binary writer for the associated stream.
Definition at line 300 of file abstracttrack.h.
|
friend |
Definition at line 113 of file abstracttrack.h.
|
friend |
Definition at line 111 of file abstracttrack.h.
|
friend |
Definition at line 112 of file abstracttrack.h.
|
protected |
Definition at line 236 of file abstracttrack.h.
|
protected |
Definition at line 238 of file abstracttrack.h.
|
protected |
Definition at line 208 of file abstracttrack.h.
|
protected |
Definition at line 215 of file abstracttrack.h.
|
protected |
Definition at line 216 of file abstracttrack.h.
|
protected |
Definition at line 218 of file abstracttrack.h.
|
protected |
Definition at line 217 of file abstracttrack.h.
|
protected |
Definition at line 229 of file abstracttrack.h.
|
protected |
Definition at line 220 of file abstracttrack.h.
|
protected |
Definition at line 232 of file abstracttrack.h.
|
protected |
Definition at line 226 of file abstracttrack.h.
|
protected |
Definition at line 210 of file abstracttrack.h.
|
protected |
Definition at line 233 of file abstracttrack.h.
|
protected |
Definition at line 227 of file abstracttrack.h.
|
protected |
Definition at line 224 of file abstracttrack.h.
|
protected |
Definition at line 237 of file abstracttrack.h.
|
protected |
Definition at line 207 of file abstracttrack.h.
|
protected |
Definition at line 219 of file abstracttrack.h.
|
protected |
Definition at line 214 of file abstracttrack.h.
|
protected |
Definition at line 234 of file abstracttrack.h.
|
protected |
Definition at line 197 of file abstracttrack.h.
|
protected |
Definition at line 198 of file abstracttrack.h.
|
protected |
Definition at line 199 of file abstracttrack.h.
|
protected |
Definition at line 200 of file abstracttrack.h.
|
protected |
Definition at line 228 of file abstracttrack.h.
|
protected |
Definition at line 205 of file abstracttrack.h.
|
protected |
Definition at line 192 of file abstracttrack.h.
|
protected |
Definition at line 212 of file abstracttrack.h.
|
protected |
Definition at line 209 of file abstracttrack.h.
|
protected |
Definition at line 201 of file abstracttrack.h.
|
protected |
Definition at line 211 of file abstracttrack.h.
|
protected |
Definition at line 206 of file abstracttrack.h.
|
protected |
Definition at line 193 of file abstracttrack.h.
|
protected |
Definition at line 239 of file abstracttrack.h.
|
protected |
Definition at line 230 of file abstracttrack.h.
|
protected |
Definition at line 223 of file abstracttrack.h.
|
protected |
Definition at line 222 of file abstracttrack.h.
|
protected |
Definition at line 194 of file abstracttrack.h.
|
protected |
Definition at line 225 of file abstracttrack.h.
|
protected |
Definition at line 221 of file abstracttrack.h.
|
protected |
Definition at line 213 of file abstracttrack.h.
|
protected |
Definition at line 203 of file abstracttrack.h.
|
protected |
Definition at line 196 of file abstracttrack.h.
|
protected |
Definition at line 235 of file abstracttrack.h.
|
protected |
Definition at line 231 of file abstracttrack.h.
|
protected |
Definition at line 204 of file abstracttrack.h.
|
protected |
Definition at line 202 of file abstracttrack.h.
|
protected |
Definition at line 195 of file abstracttrack.h.