Обработка 16-битного TIFF (увеличение яркости) - PullRequest
0 голосов
/ 31 октября 2018

Я получаю сообщение об ошибке 'System.IndexOutOfRangeException:' Индекс находился за пределами массива. ' на выходе строки. WriteScanline (scanline, i);

Я хочу взять файл из одной папки и после обработки сохранить в новую папку. Скажите, как это сделать. Это пример кода, приведенный на libtiff.net.Link https://bitmiracle.github.io/libtiff.net/html/91d736ff-8648-4c2f-a87a-9d8d215416b8.htm

using System;
using System.Configuration;
using System.Diagnostics;
using System.Drawing;
using System.IO;
using BitMiracle.LibTiff.Classic;


namespace TiffConverterApp
{
   internal class Program   {

            public static void Main()
            {

            using (Tiff tiff = Tiff.Open(@"SampleData\abc.tiff", "r"))
                {
                    int width = tiff.GetField(TiffTag.IMAGEWIDTH)[0].ToInt();
                    int height = tiff.GetField(TiffTag.IMAGELENGTH)[0].ToInt();
                    double dpiX = tiff.GetField(TiffTag.XRESOLUTION)[0].ToDouble();
                    double dpiY = tiff.GetField(TiffTag.YRESOLUTION)[0].ToDouble();

                    byte[] scanline = new byte[tiff.ScanlineSize()];
                    ushort[] scanline16Bit = new ushort[tiff.ScanlineSize() / 2];

                    using (Tiff output = Tiff.Open("processed.tif", "w"))
                    {
                        if (output == null)
                            return;

                        output.SetField(TiffTag.IMAGEWIDTH, width);
                        output.SetField(TiffTag.IMAGELENGTH, height);
                        output.SetField(TiffTag.BITSPERSAMPLE, 16);
                        output.SetField(TiffTag.SAMPLESPERPIXEL, 1);
                        output.SetField(TiffTag.PHOTOMETRIC, Photometric.MINISBLACK);
                        output.SetField(TiffTag.PLANARCONFIG, PlanarConfig.CONTIG);
                        output.SetField(TiffTag.ROWSPERSTRIP, 1);
                        output.SetField(TiffTag.COMPRESSION, Compression.LZW);

                        for (int i = 0; i < height; i++)
                        {
                            tiff.ReadScanline(scanline, i);
                            MultiplyScanLineAs16BitSamples(scanline, scanline16Bit, 16);
                            output.WriteScanline(scanline, i);

                        }
                    }

                    Process.Start("processed.tif");
                }
            }

            private static void MultiplyScanLineAs16BitSamples(byte[] scanline, ushort[] temp, ushort factor)
            {
                if (scanline.Length % 2 != 0)
                {
                    // each two bytes define one sample so there should be even number of bytes
                    throw new ArgumentException();
                }

                // pack all bytes to ushorts
                Buffer.BlockCopy(scanline, 0, temp, 0, scanline.Length);

                for (int i = 0; i < temp.Length; i++)
                    temp[i] *= factor;

                // unpack all ushorts to bytes
                Buffer.BlockCopy(temp, 0, scanline, 0, scanline.Length);
            }

    public static void AddToLog(string Msg)
        {
            try
            {
                string path = ConfigurationSettings.AppSettings["LogFilePath"];
                string TodayDate = DateTime.Now.ToString("ddMMyyyy");
                string LogPath = path + "\\" + TodayDate;
                if (!Directory.Exists(LogPath))
                    Directory.CreateDirectory(LogPath);
                FileStream fileStream = new FileStream(LogPath + "\\Log.log", FileMode.Append);
                StreamWriter streamWriter = new StreamWriter((Stream)fileStream);
                streamWriter.WriteLine(DateTime.Now.ToString() + ": " + Msg);
                streamWriter.Close();
                fileStream.Close();
            }
            catch (Exception ex)
            {
                string message = ex.Message;
            }
        }
    }
}

Ниже приводится трассировка стека

at BitMiracle.LibTiff.Classic.Internal.LZWCodec.LZWEncode(Byte[] buffer, Int32 offset, Int32 count, Int16 plane)
at BitMiracle.LibTiff.Classic.Internal.LZWCodec.predictor_encoderow(Byte[] buffer, Int32 offset, Int32 count, Int16 plane)
at BitMiracle.LibTiff.Classic.Internal.CodecWithPredictor.EncodeRow(Byte[] buffer, Int32 offset, Int32 count, Int16 plane)
at BitMiracle.LibTiff.Classic.Tiff.WriteScanline(Byte[] buffer, Int32 offset, Int32 row, Int16 plane)
at BitMiracle.LibTiff.Classic.Tiff.WriteScanline(Byte[] buffer, Int32 row)
at TiffConverterApp.Program.Main() in D:\TiffProject\TiffConverterApp\TiffConverterApp\Program.cs:line 52
...