用c ++读取tiff图像

时间:2015-04-26 19:57:50

标签: c++ tiff

我试图从tiff图像文件中获取信息。 Endian的输出是正确的,但其余的都是错误的。 tiff文件的前8个字节是:

4d  4d  00  2a  00  02  03  60

我得到的魔法是10752,其中2A00是HEX。但我应该读第三个和字节,应该是002a。需要帮助!

这是我的代码。

#include <iostream>
#include <fstream>


using namespace std;

int main()
{
    char buffer[3];

    short magicno;
    int ifdaddress;
    short ifdcount;


    ifstream imfile;
    imfile.open("pooh.tif",ios::binary);

    imfile.seekg(0,ios::beg);

    imfile.read(buffer,2);
    imfile.read((char*)&magicno, 2);
    imfile.read((char*)&ifdaddress, 4);

    imfile.seekg(ifdaddress, ios::beg);
    imfile.read((char*)&ifdcount, 2);

    imfile.close();

    buffer[2]='\0';


    cout<<"Endian: "<<buffer<<endl;
    cout<<"Magic: "<<magicno<<endl;
    cout<<"IFD Address: "<<ifdaddress<<endl;
    cout<<"IFD CountL "<<ifdcount<<endl;

    return 0;

}

我的输出是:

Endian: MM
Magic: 10752
IFD Address: 1610809856
IFD CountL 0

1 个答案:

答案 0 :(得分:1)

您正确阅读了字节顺序标记,但您没有行动。来自Adobe的“TIFF 6”:

  

字节0-1:
  文件中使用的字节顺序。法律价值观是:
  “II”(4949.H)
  “MM”(4D4D.H)
  在“II”格式中,对于16位和32位整数,字节顺序始终从最低有效字节到最高有效字节。这称为little-endian字节顺序。在“MM”格式中,对于16位和32位整数,字节顺序始终从最高有效到最低有效。这称为big-endian字节顺序   (https://partners.adobe.com/public/developer/en/tiff/TIFF6.pdf

你需要两组例程来读取TIFF文件中的一个短整数(以及读取更长的整数类型):一个读取摩托罗拉(“MM”)大端数字,一个读取英特尔(“ II“)小端。

实际上,你必须是一个小端系统,而不是原生地阅读大端数字。

正确读取单词的代码可以像

一样简单
unsigned char d1,d2;
imfile.read (&d1,1);
imfile.read (&d2,1);
if (magicno == 0x4949)
   word = d1 + (d2<<8);
else
   word = (d1<<8)+d2;

未经测试,但总体思路应该清楚。最好使它成为一个函数,因为您需要为“LONG”数据类型设置类似的设置,而“RATIONAL”数据类型则需要这样的设置。

最终,对于TIFF文件,您可能需要一个通用的read_data函数,该函数首先检查文件中存储的数据类型,然后调用正确的例程。