libcamera
v0.3.2+116-83c5ad0f
Supporting cameras in Linux since 2019
|
Class to describe a color space. More...
Public Types | |
enum | Primaries { Raw, Smpte170m, Rec709, Rec2020 } |
The color primaries for this color space. | |
enum | TransferFunction { Linear, Srgb, Rec709 } |
The transfer function used for this color space. | |
enum | YcbcrEncoding { None, Rec601, Rec709, Rec2020 } |
The Y'CbCr encoding. | |
enum | Range { Full, Limited } |
The range (sometimes "quantisation") for this color space. | |
Public Member Functions | |
constexpr | ColorSpace (Primaries p, TransferFunction t, YcbcrEncoding e, Range r) |
Construct a ColorSpace from explicit values. More... | |
std::string | toString () const |
Assemble and return a readable string representation of the ColorSpace. More... | |
bool | adjust (PixelFormat format) |
Adjust the color space to match a pixel format. More... | |
Static Public Member Functions | |
static std::string | toString (const std::optional< ColorSpace > &colorSpace) |
Assemble and return a readable string representation of an optional ColorSpace. More... | |
static std::optional< ColorSpace > | fromString (const std::string &str) |
Construct a color space from a string. More... | |
Public Attributes | |
Primaries | primaries |
The color primaries of this color space. | |
TransferFunction | transferFunction |
The transfer function used by this color space. | |
YcbcrEncoding | ycbcrEncoding |
The Y'CbCr encoding used by this color space. | |
Range | range |
The pixel range used with by color space. | |
Static Public Attributes | |
static const ColorSpace | Raw |
A constant representing a raw color space (from a sensor) More... | |
static const ColorSpace | Srgb |
A constant representing the sRGB color space (RGB formats only) More... | |
static const ColorSpace | Sycc |
A constant representing the sYCC color space, typically used for encoding JPEG images. More... | |
static const ColorSpace | Smpte170m |
A constant representing the SMPTE170M color space. More... | |
static const ColorSpace | Rec709 |
A constant representing the Rec.709 color space. More... | |
static const ColorSpace | Rec2020 |
A constant representing the Rec.2020 color space. More... | |
Class to describe a color space.
The ColorSpace class defines the color primaries, the transfer function, the Y'CbCr encoding associated with the color space, and the range (sometimes also referred to as the quantisation) of the color space.
Certain combinations of these fields form well-known standard color spaces such as "sRGB" or "Rec709".
In the strictest sense a "color space" formally only refers to the color primaries and white point. Here, however, the ColorSpace class adopts the common broader usage that includes the transfer function, Y'CbCr encoding method and quantisation.
More information on color spaces is available in the V4L2 documentation, see in particular
Note that there is no guarantee of a 1:1 mapping between color space names and definitions in libcamera and V4L2. Two notable differences are
|
inline |
Construct a ColorSpace from explicit values.
[in] | p | The color primaries |
[in] | t | The transfer function for the color space |
[in] | e | The Y'CbCr encoding |
[in] | r | The range of the pixel values in this color space |
bool libcamera::ColorSpace::adjust | ( | PixelFormat | format | ) |
Adjust the color space to match a pixel format.
[in] | format | The pixel format |
Not all combinations of pixel formats and color spaces make sense. For instance, nobody uses a limited quantization range with raw Bayer formats, and the YcbcrEncoding::None encoding isn't valid for YUV formats. This function adjusts the ColorSpace to make it compatible with the given format, by applying the following rules:
|
static |
Construct a color space from a string.
[in] | str | The string |
The string str can contain the name of a well-known color space, or be made of the four color space components separated by a '/' character, ordered as
primaries '/' transferFunction '/' ycbcrEncoding '/' range
Any failure to parse the string, either because it doesn't match the expected format, or because the one of the names isn't recognized, will cause this function to return std::nullopt.
std::string libcamera::ColorSpace::toString | ( | ) | const |
Assemble and return a readable string representation of the ColorSpace.
If the color space matches a standard ColorSpace (such as ColorSpace::Sycc) then the short name of the color space ("sYCC") is returned. Otherwise the four constituent parts of the ColorSpace are assembled into a longer string.
|
static |
Assemble and return a readable string representation of an optional ColorSpace.
This is a convenience helper to easily obtain a string representation for a ColorSpace in parts of the libcamera API where it is stored in a std::optional<>. If the ColorSpace is set, this function returns colorSpace.toString(), otherwise it returns "Unset".
|
static |
A constant representing a raw color space (from a sensor)
|
static |
A constant representing the Rec.2020 color space.
|
static |
A constant representing the Rec.709 color space.
|
static |
A constant representing the SMPTE170M color space.
|
static |
A constant representing the sRGB color space (RGB formats only)
|
static |
A constant representing the sYCC color space, typically used for encoding JPEG images.