// Copyright (c) Six Labors and contributors. // Licensed under the Apache License, Version 2.0. using System.Collections.Generic; using SixLabors.ImageSharp.ColorSpaces; using SixLabors.ImageSharp.ColorSpaces.Conversion; using Xunit; namespace SixLabors.ImageSharp.Tests.Colorspaces { /// /// Tests - conversions. /// /// /// Test data generated using: /// /// public class CieLabAndCieLchConversionTests { private static readonly IEqualityComparer FloatRoundingComparer = new FloatRoundingComparer(4); private static readonly ColorSpaceConverter Converter = new ColorSpaceConverter(); /// /// Tests conversion from to . /// [Theory] [InlineData(0, 0, 0, 0, 0, 0)] [InlineData(54.2917, 106.8391, 40.8526, 54.2917, 80.8125, 69.8851)] [InlineData(100, 0, 0, 100, 0, 0)] [InlineData(100, 50, 180, 100, -50, 0)] [InlineData(10, 36.0555, 56.3099, 10, 20, 30)] [InlineData(10, 36.0555, 123.6901, 10, -20, 30)] [InlineData(10, 36.0555, 303.6901, 10, 20, -30)] [InlineData(10, 36.0555, 236.3099, 10, -20, -30)] public void Convert_Lch_to_Lab(float l, float c, float h, float l2, float a, float b) { // Arrange CieLch input = new CieLch(l, c, h); // Act CieLab output = Converter.ToCieLab(input); // Assert Assert.Equal(l2, output.L, FloatRoundingComparer); Assert.Equal(a, output.A, FloatRoundingComparer); Assert.Equal(b, output.B, FloatRoundingComparer); } /// /// Tests conversion from to . /// [Theory] [InlineData(0, 0, 0, 0, 0, 0)] [InlineData(54.2917, 80.8125, 69.8851, 54.2917, 106.8391, 40.8526)] [InlineData(100, 0, 0, 100, 0, 0)] [InlineData(100, -50, 0, 100, 50, 180)] [InlineData(10, 20, 30, 10, 36.0555, 56.3099)] [InlineData(10, -20, 30, 10, 36.0555, 123.6901)] [InlineData(10, 20, -30, 10, 36.0555, 303.6901)] [InlineData(10, -20, -30, 10, 36.0555, 236.3099)] public void Convert_Lab_to_LCHab(float l, float a, float b, float l2, float c, float h) { // Arrange CieLab input = new CieLab(l, a, b); // Act CieLch output = Converter.ToCieLch(input); // Assert Assert.Equal(l2, output.L, FloatRoundingComparer); Assert.Equal(c, output.C, FloatRoundingComparer); Assert.Equal(h, output.H, FloatRoundingComparer); } } }