前记:前前后后一年时间,有时间就扒资料,终于弄出来了。这个程序是读取一个彩色tiff图,将其像素提取出来,赋给新建的tiff文件。拷贝运行此程序前,先配置好libtiff环境(网上有很多资源,也可以下载我收藏的的源码文件:http://download.csdn.net/download/fx_odyssey/9838235,直接拷贝到工程目录下。),另外将lena.tif彩色文件放置在工程目录下。
#include <iostream>
#include <stdlib.h>
#include <Windows.h>
#include "tiffio.h"
using namespace std;
void CreatTiffFile(const char *FileName, unsigned char *Buf, uint32 width, uint32 height);
int main()
{
TIFF *tifFile = TIFFOpen("lena.tif", "r"); //提前在工程目录下放入 lena.tif 的文件,“r”表示读写权限为“读”
int width, height;
TIFFGetField(tifFile, TIFFTAG_IMAGEWIDTH, &width);
TIFFGetField(tifFile, TIFFTAG_IMAGELENGTH, &height);
int pixelCount = width * height;
unsigned int *image = new unsigned int[pixelCount];
TIFFReadRGBAImage(tifFile, width, height, image, 1);
unsigned char *R = new unsigned char[pixelCount];
unsigned char *G = new unsigned char[pixelCount];
unsigned char *B = new unsigned char[pixelCount];
unsigned char *A = new unsigned char[pixelCount];
for (int i = 0; i < pixelCount; i++)
{
R[i] = 0x00;
G[i] = 0x00;
B[i] = 0x00;
A[i] = 0x00;
}
unsigned int *rowPointerToSrc = image + width * (height - 1);
unsigned char *rowPointerToR = R;
unsigned char *rowPointerToG = G;
unsigned char *rowPointerToB = B;
unsigned char *rowPointerToA = A;
for (int y = 0; y < height; y++)
{
unsigned int *colPointerToSrc = rowPointerToSrc;
unsigned char *colPointerToR = rowPointerToR;
unsigned char *colPointerToG = rowPointerToG;
unsigned char *colPointerToB = rowPointerToB;
unsigned char *colPointerToA = rowPointerToA;
//cout << "第 " << y+1 << " 行:" << endl;
for (int x = 0; x < width; x++)
{
colPointerToR[0] = (unsigned char)TIFFGetR(colPointerToSrc[0]);
colPointerToG[0] = (unsigned char)TIFFGetG(colPointerToSrc[0]);
colPointerToB[0] = (unsigned char)TIFFGetB(colPointerToSrc[0]);
colPointerToA[0] = (unsigned char)TIFFGetA(colPointerToSrc[0]);
//cout << "\tR:" << (int)colPointerToR[0] << "\tG:" << (int)colPointerToG[0] << "\tB:" << (int)colPointerToB[0] << "\tA:" << (int)colPointerToA[0] << endl;
colPointerToSrc++;
colPointerToR++;
colPointerToG++;
colPointerToB++;
colPointerToA++;
}
rowPointerToSrc -= width;
rowPointerToR += width;
rowPointerToG += width;
rowPointerToB += width;
rowPointerToA += width;
}
delete image;
uint32 pixel = height * width * 3;
BYTE *pic = new BYTE[pixel];
for (uint32 i = 0; i < pixelCount; i++)
{
pic[i*3] = R[i];
pic[i*3+1] = G[i];
pic[i*3+2] = B[i];
}
delete R;
delete G;
delete B;
delete A;
const char *fileName = "test.tif";
CreatTiffFile(fileName, pic, width, height);
return 0;
}
void CreatTiffFile(const char *FileName, unsigned char *Buf, uint32 width, uint32 height)
{
TIFF *imageTest = TIFFOpen(FileName, "w");
if (imageTest == NULL) {
printf("Could not open output.tif for writing\n");
cout << "open is failed.\n";
system("pause");
exit(1);
}
TIFFSetField(imageTest, TIFFTAG_IMAGEWIDTH, width);
TIFFSetField(imageTest, TIFFTAG_IMAGELENGTH, height);
TIFFSetField(imageTest, TIFFTAG_BITSPERSAMPLE, 8);// bits per channel (sample) 每个通道(样本)
TIFFSetField(imageTest, TIFFTAG_SAMPLESPERPIXEL, 3);// samples per pixel 每像素采样
TIFFSetField(imageTest, TIFFTAG_ROWSPERSTRIP, height); // rows per strip of data 每条数据行(写入像素的高度限制)
//TIFFSetField(imageTest, TIFFTAG_COMPRESSION, COMPRESSION_CCITTFAX4);
TIFFSetField(imageTest, TIFFTAG_PHOTOMETRIC, PHOTOMETRIC_RGB);
TIFFSetField(imageTest, TIFFTAG_FILLORDER, FILLORDER_MSB2LSB);
TIFFSetField(imageTest, TIFFTAG_PLANARCONFIG, PLANARCONFIG_CONTIG);
TIFFSetField(imageTest, TIFFTAG_XRESOLUTION, 600.0);
TIFFSetField(imageTest, TIFFTAG_YRESOLUTION, 600.0);
TIFFSetField(imageTest, TIFFTAG_RESOLUTIONUNIT, RESUNIT_INCH);
//Write the information to the file
TIFFWriteEncodedStrip(imageTest, 0, Buf, width * height * 3);
TIFFClose(imageTest);
//return true;
}
如果是想写灰度图,将TIFFSetField(imageTest, TIFFTAG_SAMPLESPERPIXEL, 3);中3改为1,Buf的数据大小改为width*height即可。