|
|
|
@ -1,6 +1,8 @@ |
|
|
|
// Copyright (c) Six Labors and contributors.
|
|
|
|
// Licensed under the Apache License, Version 2.0.
|
|
|
|
|
|
|
|
using System; |
|
|
|
using System.Runtime.CompilerServices; |
|
|
|
using SixLabors.ImageSharp.ColorSpaces.Conversion.Implementation; |
|
|
|
|
|
|
|
namespace SixLabors.ImageSharp.ColorSpaces.Conversion |
|
|
|
@ -28,6 +30,27 @@ namespace SixLabors.ImageSharp.ColorSpaces.Conversion |
|
|
|
return this.ToCieLchuv(xyzColor); |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Performs the bulk conversion from <see cref="CieLab"/> into <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="source">The span to the source colors</param>
|
|
|
|
/// <param name="destination">The span to the destination colors</param>
|
|
|
|
/// <param name="count">The number of colors to convert.</param>
|
|
|
|
public void Convert(Span<CieLab> source, Span<CieLchuv> destination, int count) |
|
|
|
{ |
|
|
|
Guard.SpansMustBeSizedAtLeast(source, nameof(source), destination, nameof(destination), count); |
|
|
|
|
|
|
|
ref CieLab sourceRef = ref source.DangerousGetPinnableReference(); |
|
|
|
ref CieLchuv destRef = ref destination.DangerousGetPinnableReference(); |
|
|
|
|
|
|
|
for (int i = 0; i < count; i++) |
|
|
|
{ |
|
|
|
ref CieLab sp = ref Unsafe.Add(ref sourceRef, i); |
|
|
|
ref CieLchuv dp = ref Unsafe.Add(ref destRef, i); |
|
|
|
dp = this.ToCieLchuv(sp); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Converts a <see cref="CieLch"/> into a <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
@ -41,6 +64,27 @@ namespace SixLabors.ImageSharp.ColorSpaces.Conversion |
|
|
|
return this.ToCieLchuv(xyzColor); |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Performs the bulk conversion from <see cref="CieLch"/> into <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="source">The span to the source colors</param>
|
|
|
|
/// <param name="destination">The span to the destination colors</param>
|
|
|
|
/// <param name="count">The number of colors to convert.</param>
|
|
|
|
public void Convert(Span<CieLch> source, Span<CieLchuv> destination, int count) |
|
|
|
{ |
|
|
|
Guard.SpansMustBeSizedAtLeast(source, nameof(source), destination, nameof(destination), count); |
|
|
|
|
|
|
|
ref CieLch sourceRef = ref source.DangerousGetPinnableReference(); |
|
|
|
ref CieLchuv destRef = ref destination.DangerousGetPinnableReference(); |
|
|
|
|
|
|
|
for (int i = 0; i < count; i++) |
|
|
|
{ |
|
|
|
ref CieLch sp = ref Unsafe.Add(ref sourceRef, i); |
|
|
|
ref CieLchuv dp = ref Unsafe.Add(ref destRef, i); |
|
|
|
dp = this.ToCieLchuv(sp); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Converts a <see cref="CieLuv"/> into a <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
@ -57,6 +101,27 @@ namespace SixLabors.ImageSharp.ColorSpaces.Conversion |
|
|
|
return CieLuvToCieLchuvConverter.Convert(adapted); |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Performs the bulk conversion from <see cref="CieLuv"/> into <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="source">The span to the source colors</param>
|
|
|
|
/// <param name="destination">The span to the destination colors</param>
|
|
|
|
/// <param name="count">The number of colors to convert.</param>
|
|
|
|
public void Convert(Span<CieLuv> source, Span<CieLchuv> destination, int count) |
|
|
|
{ |
|
|
|
Guard.SpansMustBeSizedAtLeast(source, nameof(source), destination, nameof(destination), count); |
|
|
|
|
|
|
|
ref CieLuv sourceRef = ref source.DangerousGetPinnableReference(); |
|
|
|
ref CieLchuv destRef = ref destination.DangerousGetPinnableReference(); |
|
|
|
|
|
|
|
for (int i = 0; i < count; i++) |
|
|
|
{ |
|
|
|
ref CieLuv sp = ref Unsafe.Add(ref sourceRef, i); |
|
|
|
ref CieLchuv dp = ref Unsafe.Add(ref destRef, i); |
|
|
|
dp = this.ToCieLchuv(sp); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Converts a <see cref="CieXyy"/> into a <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
@ -70,6 +135,27 @@ namespace SixLabors.ImageSharp.ColorSpaces.Conversion |
|
|
|
return this.ToCieLchuv(xyzColor); |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Performs the bulk conversion from <see cref="CieXyy"/> into <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="source">The span to the source colors</param>
|
|
|
|
/// <param name="destination">The span to the destination colors</param>
|
|
|
|
/// <param name="count">The number of colors to convert.</param>
|
|
|
|
public void Convert(Span<CieXyy> source, Span<CieLchuv> destination, int count) |
|
|
|
{ |
|
|
|
Guard.SpansMustBeSizedAtLeast(source, nameof(source), destination, nameof(destination), count); |
|
|
|
|
|
|
|
ref CieXyy sourceRef = ref source.DangerousGetPinnableReference(); |
|
|
|
ref CieLchuv destRef = ref destination.DangerousGetPinnableReference(); |
|
|
|
|
|
|
|
for (int i = 0; i < count; i++) |
|
|
|
{ |
|
|
|
ref CieXyy sp = ref Unsafe.Add(ref sourceRef, i); |
|
|
|
ref CieLchuv dp = ref Unsafe.Add(ref destRef, i); |
|
|
|
dp = this.ToCieLchuv(sp); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Converts a <see cref="CieXyz"/> into a <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
@ -83,6 +169,27 @@ namespace SixLabors.ImageSharp.ColorSpaces.Conversion |
|
|
|
return this.ToCieLchuv(labColor); |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Performs the bulk conversion from <see cref="CieXyz"/> into <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="source">The span to the source colors</param>
|
|
|
|
/// <param name="destination">The span to the destination colors</param>
|
|
|
|
/// <param name="count">The number of colors to convert.</param>
|
|
|
|
public void Convert(Span<CieXyz> source, Span<CieLchuv> destination, int count) |
|
|
|
{ |
|
|
|
Guard.SpansMustBeSizedAtLeast(source, nameof(source), destination, nameof(destination), count); |
|
|
|
|
|
|
|
ref CieXyz sourceRef = ref source.DangerousGetPinnableReference(); |
|
|
|
ref CieLchuv destRef = ref destination.DangerousGetPinnableReference(); |
|
|
|
|
|
|
|
for (int i = 0; i < count; i++) |
|
|
|
{ |
|
|
|
ref CieXyz sp = ref Unsafe.Add(ref sourceRef, i); |
|
|
|
ref CieLchuv dp = ref Unsafe.Add(ref destRef, i); |
|
|
|
dp = this.ToCieLchuv(sp); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Converts a <see cref="Cmyk"/> into a <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
@ -96,6 +203,27 @@ namespace SixLabors.ImageSharp.ColorSpaces.Conversion |
|
|
|
return this.ToCieLchuv(xyzColor); |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Performs the bulk conversion from <see cref="Cmyk"/> into <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="source">The span to the source colors</param>
|
|
|
|
/// <param name="destination">The span to the destination colors</param>
|
|
|
|
/// <param name="count">The number of colors to convert.</param>
|
|
|
|
public void Convert(Span<Cmyk> source, Span<CieLchuv> destination, int count) |
|
|
|
{ |
|
|
|
Guard.SpansMustBeSizedAtLeast(source, nameof(source), destination, nameof(destination), count); |
|
|
|
|
|
|
|
ref Cmyk sourceRef = ref source.DangerousGetPinnableReference(); |
|
|
|
ref CieLchuv destRef = ref destination.DangerousGetPinnableReference(); |
|
|
|
|
|
|
|
for (int i = 0; i < count; i++) |
|
|
|
{ |
|
|
|
ref Cmyk sp = ref Unsafe.Add(ref sourceRef, i); |
|
|
|
ref CieLchuv dp = ref Unsafe.Add(ref destRef, i); |
|
|
|
dp = this.ToCieLchuv(sp); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Converts a <see cref="Hsl"/> into a <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
@ -109,6 +237,27 @@ namespace SixLabors.ImageSharp.ColorSpaces.Conversion |
|
|
|
return this.ToCieLchuv(xyzColor); |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Performs the bulk conversion from <see cref="Hsl"/> into <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="source">The span to the source colors</param>
|
|
|
|
/// <param name="destination">The span to the destination colors</param>
|
|
|
|
/// <param name="count">The number of colors to convert.</param>
|
|
|
|
public void Convert(Span<Hsl> source, Span<CieLchuv> destination, int count) |
|
|
|
{ |
|
|
|
Guard.SpansMustBeSizedAtLeast(source, nameof(source), destination, nameof(destination), count); |
|
|
|
|
|
|
|
ref Hsl sourceRef = ref source.DangerousGetPinnableReference(); |
|
|
|
ref CieLchuv destRef = ref destination.DangerousGetPinnableReference(); |
|
|
|
|
|
|
|
for (int i = 0; i < count; i++) |
|
|
|
{ |
|
|
|
ref Hsl sp = ref Unsafe.Add(ref sourceRef, i); |
|
|
|
ref CieLchuv dp = ref Unsafe.Add(ref destRef, i); |
|
|
|
dp = this.ToCieLchuv(sp); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Converts a <see cref="Hsv"/> into a <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
@ -122,6 +271,27 @@ namespace SixLabors.ImageSharp.ColorSpaces.Conversion |
|
|
|
return this.ToCieLchuv(xyzColor); |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Performs the bulk conversion from <see cref="Hsv"/> into <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="source">The span to the source colors</param>
|
|
|
|
/// <param name="destination">The span to the destination colors</param>
|
|
|
|
/// <param name="count">The number of colors to convert.</param>
|
|
|
|
public void Convert(Span<Hsv> source, Span<CieLchuv> destination, int count) |
|
|
|
{ |
|
|
|
Guard.SpansMustBeSizedAtLeast(source, nameof(source), destination, nameof(destination), count); |
|
|
|
|
|
|
|
ref Hsv sourceRef = ref source.DangerousGetPinnableReference(); |
|
|
|
ref CieLchuv destRef = ref destination.DangerousGetPinnableReference(); |
|
|
|
|
|
|
|
for (int i = 0; i < count; i++) |
|
|
|
{ |
|
|
|
ref Hsv sp = ref Unsafe.Add(ref sourceRef, i); |
|
|
|
ref CieLchuv dp = ref Unsafe.Add(ref destRef, i); |
|
|
|
dp = this.ToCieLchuv(sp); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Converts a <see cref="HunterLab"/> into a <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
@ -135,6 +305,27 @@ namespace SixLabors.ImageSharp.ColorSpaces.Conversion |
|
|
|
return this.ToCieLchuv(xyzColor); |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Performs the bulk conversion from <see cref="HunterLab"/> into <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="source">The span to the source colors</param>
|
|
|
|
/// <param name="destination">The span to the destination colors</param>
|
|
|
|
/// <param name="count">The number of colors to convert.</param>
|
|
|
|
public void Convert(Span<HunterLab> source, Span<CieLchuv> destination, int count) |
|
|
|
{ |
|
|
|
Guard.SpansMustBeSizedAtLeast(source, nameof(source), destination, nameof(destination), count); |
|
|
|
|
|
|
|
ref HunterLab sourceRef = ref source.DangerousGetPinnableReference(); |
|
|
|
ref CieLchuv destRef = ref destination.DangerousGetPinnableReference(); |
|
|
|
|
|
|
|
for (int i = 0; i < count; i++) |
|
|
|
{ |
|
|
|
ref HunterLab sp = ref Unsafe.Add(ref sourceRef, i); |
|
|
|
ref CieLchuv dp = ref Unsafe.Add(ref destRef, i); |
|
|
|
dp = this.ToCieLchuv(sp); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Converts a <see cref="LinearRgb"/> into a <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
@ -148,6 +339,27 @@ namespace SixLabors.ImageSharp.ColorSpaces.Conversion |
|
|
|
return this.ToCieLchuv(xyzColor); |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Performs the bulk conversion from <see cref="LinearRgb"/> into <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="source">The span to the source colors</param>
|
|
|
|
/// <param name="destination">The span to the destination colors</param>
|
|
|
|
/// <param name="count">The number of colors to convert.</param>
|
|
|
|
public void Convert(Span<LinearRgb> source, Span<CieLchuv> destination, int count) |
|
|
|
{ |
|
|
|
Guard.SpansMustBeSizedAtLeast(source, nameof(source), destination, nameof(destination), count); |
|
|
|
|
|
|
|
ref LinearRgb sourceRef = ref source.DangerousGetPinnableReference(); |
|
|
|
ref CieLchuv destRef = ref destination.DangerousGetPinnableReference(); |
|
|
|
|
|
|
|
for (int i = 0; i < count; i++) |
|
|
|
{ |
|
|
|
ref LinearRgb sp = ref Unsafe.Add(ref sourceRef, i); |
|
|
|
ref CieLchuv dp = ref Unsafe.Add(ref destRef, i); |
|
|
|
dp = this.ToCieLchuv(sp); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Converts a <see cref="Lms"/> into a <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
@ -161,6 +373,27 @@ namespace SixLabors.ImageSharp.ColorSpaces.Conversion |
|
|
|
return this.ToCieLchuv(xyzColor); |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Performs the bulk conversion from <see cref="Lms"/> into <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="source">The span to the source colors</param>
|
|
|
|
/// <param name="destination">The span to the destination colors</param>
|
|
|
|
/// <param name="count">The number of colors to convert.</param>
|
|
|
|
public void Convert(Span<Lms> source, Span<CieLchuv> destination, int count) |
|
|
|
{ |
|
|
|
Guard.SpansMustBeSizedAtLeast(source, nameof(source), destination, nameof(destination), count); |
|
|
|
|
|
|
|
ref Lms sourceRef = ref source.DangerousGetPinnableReference(); |
|
|
|
ref CieLchuv destRef = ref destination.DangerousGetPinnableReference(); |
|
|
|
|
|
|
|
for (int i = 0; i < count; i++) |
|
|
|
{ |
|
|
|
ref Lms sp = ref Unsafe.Add(ref sourceRef, i); |
|
|
|
ref CieLchuv dp = ref Unsafe.Add(ref destRef, i); |
|
|
|
dp = this.ToCieLchuv(sp); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Converts a <see cref="Rgb"/> into a <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
@ -174,6 +407,27 @@ namespace SixLabors.ImageSharp.ColorSpaces.Conversion |
|
|
|
return this.ToCieLchuv(xyzColor); |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Performs the bulk conversion from <see cref="Rgb"/> into <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="source">The span to the source colors</param>
|
|
|
|
/// <param name="destination">The span to the destination colors</param>
|
|
|
|
/// <param name="count">The number of colors to convert.</param>
|
|
|
|
public void Convert(Span<Rgb> source, Span<CieLchuv> destination, int count) |
|
|
|
{ |
|
|
|
Guard.SpansMustBeSizedAtLeast(source, nameof(source), destination, nameof(destination), count); |
|
|
|
|
|
|
|
ref Rgb sourceRef = ref source.DangerousGetPinnableReference(); |
|
|
|
ref CieLchuv destRef = ref destination.DangerousGetPinnableReference(); |
|
|
|
|
|
|
|
for (int i = 0; i < count; i++) |
|
|
|
{ |
|
|
|
ref Rgb sp = ref Unsafe.Add(ref sourceRef, i); |
|
|
|
ref CieLchuv dp = ref Unsafe.Add(ref destRef, i); |
|
|
|
dp = this.ToCieLchuv(sp); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Converts a <see cref="YCbCr"/> into a <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
@ -186,5 +440,26 @@ namespace SixLabors.ImageSharp.ColorSpaces.Conversion |
|
|
|
var xyzColor = this.ToCieXyz(color); |
|
|
|
return this.ToCieLchuv(xyzColor); |
|
|
|
} |
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Performs the bulk conversion from <see cref="YCbCr"/> into <see cref="CieLchuv"/>
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="source">The span to the source colors</param>
|
|
|
|
/// <param name="destination">The span to the destination colors</param>
|
|
|
|
/// <param name="count">The number of colors to convert.</param>
|
|
|
|
public void Convert(Span<YCbCr> source, Span<CieLchuv> destination, int count) |
|
|
|
{ |
|
|
|
Guard.SpansMustBeSizedAtLeast(source, nameof(source), destination, nameof(destination), count); |
|
|
|
|
|
|
|
ref YCbCr sourceRef = ref source.DangerousGetPinnableReference(); |
|
|
|
ref CieLchuv destRef = ref destination.DangerousGetPinnableReference(); |
|
|
|
|
|
|
|
for (int i = 0; i < count; i++) |
|
|
|
{ |
|
|
|
ref YCbCr sp = ref Unsafe.Add(ref sourceRef, i); |
|
|
|
ref CieLchuv dp = ref Unsafe.Add(ref destRef, i); |
|
|
|
dp = this.ToCieLchuv(sp); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |