mirror of https://github.com/SixLabors/ImageSharp
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
40 lines
1.6 KiB
40 lines
1.6 KiB
// <copyright file="BmpEncoder.cs" company="James Jackson-South">
|
|
// Copyright (c) James Jackson-South and contributors.
|
|
// Licensed under the Apache License, Version 2.0.
|
|
// </copyright>
|
|
|
|
namespace ImageSharp.Formats
|
|
{
|
|
using System;
|
|
using System.IO;
|
|
|
|
/// <summary>
|
|
/// Image encoder for writing an image to a stream as a Windows bitmap.
|
|
/// </summary>
|
|
/// <remarks>The encoder can currently only write 24-bit rgb images to streams.</remarks>
|
|
public class BmpEncoder : IImageEncoder
|
|
{
|
|
/// <inheritdoc/>
|
|
public void Encode<TColor>(Image<TColor> image, Stream stream, IEncoderOptions options)
|
|
where TColor : struct, IPixel<TColor>
|
|
{
|
|
IBmpEncoderOptions bmpOptions = BmpEncoderOptions.Create(options);
|
|
|
|
this.Encode(image, stream, bmpOptions);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Encodes the image to the specified stream from the <see cref="Image{TColor}"/>.
|
|
/// </summary>
|
|
/// <typeparam name="TColor">The pixel format.</typeparam>
|
|
/// <param name="image">The <see cref="Image{TColor}"/> to encode from.</param>
|
|
/// <param name="stream">The <see cref="Stream"/> to encode the image data to.</param>
|
|
/// <param name="options">The options for the encoder.</param>
|
|
public void Encode<TColor>(Image<TColor> image, Stream stream, IBmpEncoderOptions options)
|
|
where TColor : struct, IPixel<TColor>
|
|
{
|
|
BmpEncoderCore encoder = new BmpEncoderCore(options);
|
|
encoder.Encode(image, stream);
|
|
}
|
|
}
|
|
}
|
|
|