diff --git a/Userland/Libraries/LibGfx/ICC/BinaryWriter.cpp b/Userland/Libraries/LibGfx/ICC/BinaryWriter.cpp index d08b89d381..6af21719d5 100644 --- a/Userland/Libraries/LibGfx/ICC/BinaryWriter.cpp +++ b/Userland/Libraries/LibGfx/ICC/BinaryWriter.cpp @@ -180,6 +180,21 @@ static ErrorOr encode_text(TextTagData const& tag_data) return bytes; } +static ErrorOr encode_viewing_conditions(ViewingConditionsTagData const& tag_data) +{ + // ICC v4, 10.30 viewingConditionsType + auto bytes = TRY(ByteBuffer::create_uninitialized(2 * sizeof(u32) + sizeof(ViewingConditionsHeader))); + *bit_cast*>(bytes.data()) = (u32)ViewingConditionsTagData::Type; + *bit_cast*>(bytes.data() + 4) = 0; + + auto& header = *bit_cast(bytes.data() + 8); + header.unnormalized_ciexyz_values_for_illuminant = tag_data.unnormalized_ciexyz_values_for_illuminant(); + header.unnormalized_ciexyz_values_for_surround = tag_data.unnormalized_ciexyz_values_for_surround(); + header.illuminant_type = tag_data.illuminant_type(); + + return bytes; +} + static ErrorOr encode_xyz(XYZTagData const& tag_data) { // ICC v4, 10.31 XYZType @@ -215,6 +230,8 @@ static ErrorOr encode_tag_data(TagData const& tag_data) return encode_signature(static_cast(tag_data)); case TextTagData::Type: return encode_text(static_cast(tag_data)); + case ViewingConditionsTagData::Type: + return encode_viewing_conditions(static_cast(tag_data)); case XYZTagData::Type: return encode_xyz(static_cast(tag_data)); }