Struct kagamijxl::BasicInfo[][src]

#[repr(C)]
pub struct BasicInfo {
Show 23 fields pub have_container: i32, pub xsize: u32, pub ysize: u32, pub bits_per_sample: u32, pub exponent_bits_per_sample: u32, pub intensity_target: f32, pub min_nits: f32, pub relative_to_max_display: i32, pub linear_below: f32, pub uses_original_profile: i32, pub have_preview: i32, pub have_animation: i32, pub orientation: u32, pub num_color_channels: u32, pub num_extra_channels: u32, pub alpha_bits: u32, pub alpha_exponent_bits: u32, pub alpha_premultiplied: i32, pub preview: JxlPreviewHeader, pub animation: JxlAnimationHeader, pub intrinsic_xsize: u32, pub intrinsic_ysize: u32, pub padding: [u8; 100],
}
Expand description

Basic image information. This information is available from the file signature and first part of the codestream header.

Fields

have_container: i32

Whether the codestream is embedded in the container format. If true, metadata information and extensions may be available in addition to the codestream.

xsize: u32

Width of the image in pixels, before applying orientation.

ysize: u32

Height of the image in pixels, before applying orientation.

bits_per_sample: u32

Original image color channel bit depth.

exponent_bits_per_sample: u32

Original image color channel floating point exponent bits, or 0 if they are unsigned integer. For example, if the original data is half-precision (binary16) floating point, bits_per_sample is 16 and exponent_bits_per_sample is 5, and so on for other floating point precisions.

intensity_target: f32

Upper bound on the intensity level present in the image in nits. For unsigned integer pixel encodings, this is the brightness of the largest representable value. The image does not necessarily contain a pixel actually this bright. An encoder is allowed to set 255 for SDR images without computing a histogram.

min_nits: f32

Lower bound on the intensity level present in the image. This may be loose, i.e. lower than the actual darkest pixel. When tone mapping, a decoder will map [min_nits, intensity_target] to the display range.

relative_to_max_display: i32

See the description of @see linear_below.

linear_below: f32

The tone mapping will leave unchanged (linear mapping) any pixels whose brightness is strictly below this. The interpretation depends on relative_to_max_display. If true, this is a ratio [0, 1] of the maximum display brightness [nits], otherwise an absolute brightness [nits].

uses_original_profile: i32

Whether the data in the codestream is encoded in the original color profile that is attached to the codestream metadata header, or is encoded in an internally supported absolute color space (which the decoder can always convert to linear or non-linear sRGB or to XYB). If the original profile is used, the decoder outputs pixel data in the color space matching that profile, but doesn’t convert it to any other color space. If the original profile is not used, the decoder only outputs the data as sRGB (linear if outputting to floating point, nonlinear with standard sRGB transfer function if outputting to unsigned integers) but will not convert it to to the original color profile. The decoder also does not convert to the target display color profile, but instead will always indicate which color profile the returned pixel data is encoded in when using @see JXL_COLOR_PROFILE_TARGET_DATA so that a CMS can be used to convert the data.

have_preview: i32

Indicates a preview image exists near the beginning of the codestream. The preview itself or its dimensions are not included in the basic info.

have_animation: i32

Indicates animation frames exist in the codestream. The animation information is not included in the basic info.

orientation: u32

Image orientation, value 1-8 matching the values used by JEITA CP-3451C (Exif version 2.3).

num_color_channels: u32

Number of color channels encoded in the image, this is either 1 for grayscale data, or 3 for colored data. This count does not include the alpha channel or other extra channels. To check presence of an alpha channel, such as in the case of RGBA color, check alpha_bits != 0. If and only if this is 1, the JxlColorSpace in the JxlColorEncoding is JXL_COLOR_SPACE_GRAY.

num_extra_channels: u32

Number of additional image channels. This includes the main alpha channel, but can also include additional channels such as depth, additional alpha channels, spot colors, and so on. Information about the extra channels can be queried with JxlDecoderGetExtraChannelInfo. The main alpha channel, if it exists, also has its information available in the alpha_bits, alpha_exponent_bits and alpha_premultiplied fields in this JxlBasicInfo.

alpha_bits: u32

Bit depth of the encoded alpha channel, or 0 if there is no alpha channel. If present, matches the alpha_bits value of the JxlExtraChannelInfo associated with this alpha channel.

alpha_exponent_bits: u32

Alpha channel floating point exponent bits, or 0 if they are unsigned. If present, matches the alpha_bits value of the JxlExtraChannelInfo associated with this alpha channel. integer.

alpha_premultiplied: i32

Whether the alpha channel is premultiplied. Only used if there is a main alpha channel. Matches the alpha_premultiplied value of the JxlExtraChannelInfo associated with this alpha channel.

preview: JxlPreviewHeader

Dimensions of encoded preview image, only used if have_preview is JXL_TRUE.

animation: JxlAnimationHeader

Animation header with global animation properties for all frames, only used if have_animation is JXL_TRUE.

intrinsic_xsize: u32

Intrinsic width of the image. The intrinsic size can be different from the actual size in pixels (as given by xsize and ysize) and it denotes the recommended dimensions for displaying the image, i.e. applications are advised to resample the decoded image to the intrinsic dimensions.

intrinsic_ysize: u32

Intrinsic heigth of the image. The intrinsic size can be different from the actual size in pixels (as given by xsize and ysize) and it denotes the recommended dimensions for displaying the image, i.e. applications are advised to resample the decoded image to the intrinsic dimensions.

padding: [u8; 100]

Padding for forwards-compatibility, in case more fields are exposed in a future version of the library.

Trait Implementations

Returns a copy of the value. Read more

Performs copy-assignment from source. Read more

Formats the value using the given formatter. Read more

Returns the “default value” for a type. Read more

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more

Immutably borrows from an owned value. Read more

Mutably borrows from an owned value. Read more

Performs the conversion.

Performs the conversion.

The resulting type after obtaining ownership.

Creates owned data from borrowed data, usually by cloning. Read more

🔬 This is a nightly-only experimental API. (toowned_clone_into)

Uses borrowed data to replace owned data, usually by cloning. Read more

The type returned in the event of a conversion error.

Performs the conversion.

The type returned in the event of a conversion error.

Performs the conversion.