乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      C# 將多個(gè)圖片合并成TIFF文件的兩種方法

       風(fēng)聲之家 2021-05-02

      dotNET跨平臺(tái) 今天

      以下文章來源于WPF UI ,作者Gxy

      WPF UI

      WPF UI

      WPF UI 設(shè)計(jì),WPF教程,MVVM,C#程序設(shè)計(jì)~

      最近需要用到TIF格式的文件,研究了一段時(shí)間,終于有點(diǎn)結(jié)果了,

      發(fā)現(xiàn)兩種方式,第一種是使用BitMiracle.LibTiff.NET,直接在Nuget上安裝即可

      ,第二種是使用RasterEdge.DocImageSDK,要從官網(wǎng)下載dll包

      第一種免費(fèi),但是生成的tiff文件大小比原始圖片大的多

      第二種收費(fèi),但是有試用期一個(gè)月,效果很好,生成的tiff文件比原圖小的多而且不失真。過期之后,只需要到官網(wǎng)下載最新dll,重新引用即可再來一個(gè)月試用。。。

      先說第二種RasterEdge.DocImageSDK的使用方法:

      官網(wǎng)地址:http://www./how-to/csharp-imaging/tiff-convert-bmp/
      //過期后打開上面 這個(gè)網(wǎng)址,重新下載 dll包,重新引用即可 bin x64 4.0

      新建一個(gè)cmd項(xiàng)目,測試代碼如下:


























































      class Program    {        private static byte[] CompressionImage(Stream fileStream, long quality)        {            using (System.Drawing.Image img = System.Drawing.Image.FromStream(fileStream))            {                using (Bitmap bitmap = new Bitmap(img))                {                    ImageCodecInfo CodecInfo = GetEncoder(img.RawFormat);                    System.Drawing.Imaging.Encoder myEncoder = System.Drawing.Imaging.Encoder.Quality;                    EncoderParameters myEncoderParameters = new EncoderParameters(1);                    EncoderParameter myEncoderParameter = new EncoderParameter(myEncoder, quality);                    myEncoderParameters.Param[0] = myEncoderParameter;                    using (MemoryStream ms = new MemoryStream())                    {                        bitmap.Save(ms, CodecInfo, myEncoderParameters);                        myEncoderParameters.Dispose();                        myEncoderParameter.Dispose();                        return ms.ToArray();                    }                }            }        }        private static ImageCodecInfo GetEncoder(ImageFormat format)        {            ImageCodecInfo[] codecs = ImageCodecInfo.GetImageDecoders();            foreach (ImageCodecInfo codec in codecs)            {                if (codec.FormatID == format.Guid)                { return codec; }            }            return null;        }        static void Main(string[] args)        {            string[] imagePaths = System.IO.Directory.GetFiles(@"D:\images\","*.jpg");                        Bitmap[] bmps = new Bitmap[imagePaths.Count()];            for (int i = 0; i < imagePaths.Length; i++)            {                var stream = new FileStream(imagePaths[i], FileMode.Open);                var by = CompressionImage(stream, 100);                stream.Close();
      Bitmap tmpBmp = new Bitmap(new MemoryStream(by));
      if (tmpBmp != null) bmps[i] = tmpBmp; } ImageOutputOption option = new ImageOutputOption() { Color = ColorType.Color, Compression = ImageCompress.CCITT }; TIFFDocument tifDoc = new TIFFDocument(bmps, option); if (tifDoc == null) throw new Exception("Fail to construct TIFF Document"); tifDoc.Save(@"D:\images\test.tif"); } }

      圖片

      下面說說第二種免費(fèi)的方式:

      新建一個(gè)TiffHelper幫助類:























































































































      using BitMiracle.LibTiff.Classic;using System;using System.Drawing;using System.Drawing.Imaging;using System.IO;namespace JpgToTiff{    public class UserErrorHandler : TiffErrorHandler    {        public override void WarningHandler(Tiff tif, string method, string format, params object[] args)        {            //base.WarningHandler(tif, method, format, args);        }        public override void WarningHandlerExt(Tiff tif, object clientData, string method, string format, params object[] args)        {            //base.WarningHandlerExt(tif, clientData, method, format, args);        }    }    public class TiffHelper    {        public static UserErrorHandler m_errorHandler = new UserErrorHandler();        static TiffHelper()        {            Tiff.SetErrorHandler(m_errorHandler);        }        /// <summary>        /// 合并jpg        /// </summary>        /// <param name="bmps">bitmap數(shù)組</param>        /// <param name="tiffSavePath">保存路徑</param>        /// <param name="quality">圖片質(zhì)量,1-100</param>        /// <returns></returns>        public static bool Jpegs2Tiff(Bitmap[] bmps, string tiffSavePath, int quality = 15)        {            try            {                MemoryStream ms = new MemoryStream();                using (Tiff tif = Tiff.ClientOpen(@"in-memory", "w", ms, new TiffStream()))                {                    foreach (var bmp in bmps)//                    {                        byte[] raster = GetImageRasterBytes(bmp, PixelFormat.Format24bppRgb);                        tif.SetField(TiffTag.IMAGEWIDTH, bmp.Width);                        tif.SetField(TiffTag.IMAGELENGTH, bmp.Height);                        tif.SetField(TiffTag.COMPRESSION, Compression.JPEG);                        tif.SetField(TiffTag.PHOTOMETRIC, Photometric.RGB);                        tif.SetField(TiffTag.JPEGQUALITY, quality);                        tif.SetField(TiffTag.ROWSPERSTRIP, bmp.Height);
      tif.SetField(TiffTag.XRESOLUTION, 90); tif.SetField(TiffTag.YRESOLUTION, 90);
      tif.SetField(TiffTag.BITSPERSAMPLE, 8); tif.SetField(TiffTag.SAMPLESPERPIXEL, 3);
      tif.SetField(TiffTag.PLANARCONFIG, PlanarConfig.CONTIG);
      int stride = raster.Length / bmp.Height; ConvertSamples(raster, bmp.Width, bmp.Height);
      for (int i = 0, offset = 0; i < bmp.Height; i++) { tif.WriteScanline(raster, offset, i, 0); offset += stride; }
      tif.WriteDirectory(); } System.IO.FileStream fs = new FileStream(tiffSavePath, FileMode.Create); ms.Seek(0, SeekOrigin.Begin); fs.Write(ms.ToArray(), 0, (int)ms.Length); fs.Close(); return true; } } catch (Exception ex) { return false; } } private static byte[] GetImageRasterBytes(Bitmap bmp, PixelFormat format) { Rectangle rect = new Rectangle(0, 0, bmp.Width, bmp.Height); byte[] bits = null; try { BitmapData bmpdata = bmp.LockBits(rect, ImageLockMode.ReadWrite, format); bits = new byte[bmpdata.Stride * bmpdata.Height]; System.Runtime.InteropServices.Marshal.Copy(bmpdata.Scan0, bits, 0, bits.Length); bmp.UnlockBits(bmpdata); } catch { return null; } return bits; } private static void ConvertSamples(byte[] data, int width, int height) { int stride = data.Length / height; const int samplesPerPixel = 3;
      for (int y = 0; y < height; y++) { int offset = stride * y; int strideEnd = offset + width * samplesPerPixel;
      for (int i = offset; i < strideEnd; i += samplesPerPixel) { byte temp = data[i + 2]; data[i + 2] = data[i]; data[i] = temp; } } } }}

      下面是測試代碼:





















































      class Program    {        private static byte[] CompressionImage(Stream fileStream, long quality)        {            using (System.Drawing.Image img = System.Drawing.Image.FromStream(fileStream))            {                using (Bitmap bitmap = new Bitmap(img))                {                    ImageCodecInfo CodecInfo = GetEncoder(img.RawFormat);                    System.Drawing.Imaging.Encoder myEncoder = System.Drawing.Imaging.Encoder.Quality;                    EncoderParameters myEncoderParameters = new EncoderParameters(1);                    EncoderParameter myEncoderParameter = new EncoderParameter(myEncoder, quality);                    myEncoderParameters.Param[0] = myEncoderParameter;                    using (MemoryStream ms = new MemoryStream())                    {                        bitmap.Save(ms, CodecInfo, myEncoderParameters);                        myEncoderParameters.Dispose();                        myEncoderParameter.Dispose();                        return ms.ToArray();                    }                }            }        }        private static ImageCodecInfo GetEncoder(ImageFormat format)        {            ImageCodecInfo[] codecs = ImageCodecInfo.GetImageDecoders();            foreach (ImageCodecInfo codec in codecs)            {                if (codec.FormatID == format.Guid)                { return codec; }            }            return null;        }        static void Main(string[] args)        {            string[] imagePaths = System.IO.Directory.GetFiles(@"D:\images\","*.jpg");                        Bitmap[] bmps = new Bitmap[imagePaths.Count()];            for (int i = 0; i < imagePaths.Length; i++)            {                var stream = new FileStream(imagePaths[i], FileMode.Open);                var by = CompressionImage(stream, 100);                stream.Close();
      Bitmap tmpBmp = new Bitmap(new MemoryStream(by));
      if (tmpBmp != null) bmps[i] = tmpBmp; } TiffHelper.Jpegs2Tiff(bmps, @"D:\images\test.tif", 100);        }    }

      圖片

      可以看到,兩個(gè)方式生成的tif文件大小簡直天壤之別。。。

      7個(gè)原圖大小4.8M,第一種1.36M,

      第二種直接23.5M…

      也可能是我沒有弄好壓縮方式。。。。

      那我就不曉得了。

      如果喜歡,點(diǎn)個(gè)贊唄

      圖片

        本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
        轉(zhuǎn)藏 分享 獻(xiàn)花(0

        0條評(píng)論

        發(fā)表

        請(qǐng)遵守用戶 評(píng)論公約

        類似文章 更多