// Copyright (c) Six Labors. // Licensed under the Six Labors Split License. using SixLabors.ImageSharp.Formats; using SixLabors.ImageSharp.Formats.Png; using SixLabors.ImageSharp.Memory; namespace SixLabors.ImageSharp.Tests.TestUtilities.ReferenceCodecs; /// /// A Png encoder that uses the ImageSharp core encoder but the default configuration. /// This allows encoding under environments with restricted memory. /// public sealed class ImageSharpPngEncoderWithDefaultConfiguration : PngEncoder { /// /// Encodes the image to the specified stream from the . /// /// The pixel format. /// The to encode from. /// The to encode the image data to. public override void Encode(Image image, Stream stream) { Configuration configuration = Configuration.Default; MemoryAllocator allocator = configuration.MemoryAllocator; using PngEncoderCore encoder = new(allocator, configuration, this); encoder.Encode(image, stream); } /// /// Encodes the image to the specified stream from the . /// /// The pixel format. /// The to encode from. /// The to encode the image data to. /// The token to monitor for cancellation requests. /// A representing the asynchronous operation. public override async Task EncodeAsync(Image image, Stream stream, CancellationToken cancellationToken) { Configuration configuration = Configuration.Default; MemoryAllocator allocator = configuration.MemoryAllocator; // The introduction of a local variable that refers to an object the implements // IDisposable means you must use async/await, where the compiler generates the // state machine and a continuation. using PngEncoderCore encoder = new(allocator, configuration, this); await encoder.EncodeAsync(image, stream, cancellationToken).ConfigureAwait(false); } }