From d471e33f452d03f83619da1cfd76f4f5dbed62c2 Mon Sep 17 00:00:00 2001 From: Kleis Auke Wolthuizen Date: Fri, 27 Oct 2023 14:40:33 +0200 Subject: [PATCH] Simplify `ThumbnailPipeline` sample --- .../Samples/ThumbnailPipeline.cs | 24 ++++++++----------- 1 file changed, 10 insertions(+), 14 deletions(-) diff --git a/samples/NetVips.Samples/Samples/ThumbnailPipeline.cs b/samples/NetVips.Samples/Samples/ThumbnailPipeline.cs index 0418216e..4c8057ac 100644 --- a/samples/NetVips.Samples/Samples/ThumbnailPipeline.cs +++ b/samples/NetVips.Samples/Samples/ThumbnailPipeline.cs @@ -35,7 +35,7 @@ public class ThumbnailPipeline : ISample public bool LoaderSupportPage(string loader) { return loader.StartsWith("VipsForeignLoadPdf") || - loader.StartsWith("VipsForeignLoadGif") || + loader.StartsWith("VipsForeignLoadNsgif") || loader.StartsWith("VipsForeignLoadTiff") || loader.StartsWith("VipsForeignLoadWebp") || loader.StartsWith("VipsForeignLoadHeif") || @@ -85,9 +85,7 @@ public void Execute(string[] args) int inputWidth; int inputHeight; int pageHeight; - bool isCmyk; - bool isLabs; - bool embeddedProfile; + bool hasIccProfile; Image image = null; try @@ -109,9 +107,7 @@ public void Execute(string[] args) } pageHeight = image.PageHeight; - isCmyk = image.Interpretation == Enums.Interpretation.Cmyk; - isLabs = image.Interpretation == Enums.Interpretation.Labs; - embeddedProfile = image.Contains(VipsMetaIccName); + hasIccProfile = image.Contains(VipsMetaIccName); } catch (VipsException e) { @@ -128,17 +124,17 @@ public void Execute(string[] args) string exportProfile = null; Enums.Intent? intent = null; - // Ensure we're using a device-independent color space - if ((embeddedProfile || isCmyk) && !isLabs) + // If there's some kind of import profile, we can transform to the + // output. + if (hasIccProfile) { - // Embedded profile; fallback in case the profile embedded in the image - // is broken. No embedded profile; import using default CMYK profile. - importProfile = isCmyk ? "cmyk" : "srgb"; + // Fallback to sRGB. + importProfile = "srgb"; // Convert to sRGB using embedded or import profile. exportProfile = "srgb"; - // Use "perceptual" intent to better match imagemagick. + // Use "perceptual" intent to better match *magick. intent = Enums.Intent.Perceptual; } @@ -209,7 +205,7 @@ public void Execute(string[] args) // shrink-on-load tricks are possible. This can make thumbnailing of large // images extremely slow. using var thumb = Image.ThumbnailBuffer(buffer, thumbnailWidth, stringOptions, thumbnailHeight, size, - false, importProfile: importProfile, exportProfile: exportProfile, intent: intent); + importProfile: importProfile, exportProfile: exportProfile, intent: intent); thumb.WriteToFile("thumbnail.webp", new VOption {