如何使用libtiff获取DIB并将其转换为tif

时间:2009-06-15 18:35:19

标签: c++ image tiff

我正在尝试读取扫描图像并将其从内存中的DIB压缩到TIF文件中。我正在使用libtiff库,并在网上找到了几个例子,但没有一个像我需要的那样真正做到了。我需要从DIB拍摄图像并将其转换为B& W图像。

这是我从在线示例修改的代码。它确实把它变成了黑白,但它也只显示了扫描的一部分而不是整个部分。任何帮助将不胜感激。

编辑*:我注意到如果我将其作为灰色图像扫描,如果我将其扫描为黑白,则返回的图像完全是黑色,我不知道是否这有助于所有

// set up the image tags 
TIFFSetField(tif, TIFFTAG_IMAGEWIDTH, w);
TIFFSetField(tif, TIFFTAG_IMAGELENGTH, h);
TIFFSetField(tif, TIFFTAG_BITSPERSAMPLE, 1);
TIFFSetField(tif, TIFFTAG_COMPRESSION, COMPRESSION_CCITTFAX4);
TIFFSetField(tif, TIFFTAG_PHOTOMETRIC, PHOTOMETRIC_MINISBLACK);
TIFFSetField(tif, TIFFTAG_FILLORDER, FILLORDER_MSB2LSB);
TIFFSetField(tif, TIFFTAG_SAMPLESPERPIXEL, 1);
TIFFSetField(tif, TIFFTAG_ROWSPERSTRIP, 1);
TIFFSetField(tif, TIFFTAG_PLANARCONFIG, PLANARCONFIG_CONTIG);
TIFFSetField(tif, TIFFTAG_RESOLUTIONUNIT, RESUNIT_NONE);
TIFFSetField(tif, TIFFTAG_ORIENTATION, ORIENTATION_TOPLEFT);

unsigned char * psrc = (unsigned char *)lpBits;
unsigned char * pdst = new unsigned char[(w)];

UINT32 src_index;
UINT32 dst_index;

// now go line by line to write out the image data
for (unsigned int row = 0; row < h; row++ )
{

    // initialize the scan line to zero
    memset(pdst,0,(size_t)(w));

    // moving the data from the dib to a row structure that
    // can be used by the tiff library
    for (unsigned int col = 0; col < w; col++){
        src_index = (h - row - 1) * total_width * bytecount
                                  + col * bytecount;
        dst_index = col;
        pdst[dst_index++] = psrc[src_index+2];
        pdst[dst_index++] = psrc[src_index+1];
        pdst[dst_index] = psrc[src_index];
        result++;
    }

    // now actually write the row data
    TIFFWriteScanline(tif, pdst, row, 0);
}

1 个答案:

答案 0 :(得分:0)

我可能错了,但我认为对于CCITTFAX4编码,libtiff每个字节需要8个像素,如果图像宽度不能被8整除,则填充到字节的末尾。

例如,如果图像的宽度为150,则扫描线应为19个字节,而不是150个。

有一个使用libtiff here的好例子,虽然它不包括在阈值处关闭颜色信息并且每个字节打包像素8。