Копирование плиток с одного tiff на другой (4-полосный) - PullRequest
1 голос
/ 27 февраля 2012

Я пытаюсь просто использовать смещение, чтобы выбрать плитки из одного изображения tiff и записать их в другое изображение.Я использую libtiff.net.Вместо каждого пикселя, имеющего значение ARGB, есть один пиксель, который является альфа-каналом, затем пиксель справа от него является красным пикселем, тот, который справа от этого, является зеленым, и, конечно, тот, который справа от этого, являетсясиний.Мне нужно хранить эти 4 пикселя в одном, и что-то происходит по пути.Вы видите что-то не так с этой логикой?

using (Tiff output = Tiff.Open(@"C:\base.tif", "w"))
{
    if (output == null)
    {
        System.Console.Error.WriteLine("Could not open outgoing image");
        return;
    }


    // We need to know the width and the height before we can malloc
    int[] raster = new int[tileWidth * tileHeight];

    // Write the tiff tags to the file
    output.SetField(TiffTag.IMAGEWIDTH, 1024);
    output.SetField(TiffTag.IMAGELENGTH, 1024);
    output.SetField(TiffTag.TILEWIDTH, 256);
    output.SetField(TiffTag.TILELENGTH, 256);
    output.SetField(TiffTag.COMPRESSION, Compression.DEFLATE);
    output.SetField(TiffTag.PLANARCONFIG, PlanarConfig.CONTIG);
    output.SetField(TiffTag.PHOTOMETRIC, Photometric.RGB);
    output.SetField(TiffTag.BITSPERSAMPLE, 8);
    output.SetField(TiffTag.SAMPLESPERPIXEL, numOfBands);

    byte[] inputBuffer = new byte[tileWidth * tileHeight * numOfBands];

    // loop through every tile column
    for (int x = 0; x < 1024 / tileWidth; x++)
    {
        // loop through every tile row in the current column
        for (int y = 0; y < 1024 / tileHeight; y++)
        {
            image.ReadRGBATile((x + xOffset) * tileWidth, (y + yOffset) * tileHeight, raster);
            Tiff.IntsToByteArray(raster, 0, raster.Length, inputBuffer, 0);
            output.WriteEncodedTile(getTileIndex(x, y, 1024 / tileWidth), inputBuffer, 0, raster.Length);
        }
    }
}
...