现在的位置: 首页 > 综合 > 正文

OpenCV的ppm到bmp图片格式转换

2013年11月06日 ⁄ 综合 ⁄ 共 1731字 ⁄ 字号 评论关闭
#include <iostream>
#include <string>
#include <cstdlib>
#include <fstream>
#include <iomanip>
using namespace std;

int main(int argc, char * argv[])
{


    char* pFilename="54.ppm";
	ifstream ifile;//input ppm file
	ofstream ofile;//output bmp file
	ifile.open(pFilename,ios::binary);
	if (!ifile) {
		cout<<"open error!"<<endl;
	}
	ofile.open("1.bmp",ios::binary);

	
	string FileType;//file type-p6
	int Width,Height,Count;//count is the number of pixels
	int DataSize,HeadSize,FileSize;
	ifile>>FileType>>Width>>Height>>Count;//get the para of the ppm file

	cout<<FileType<<"!"<<Width<<"!"<<Height<<endl;

	DataSize=Width*Height*3;//every pixel need 3 byte to store
	HeadSize=0x36;//54 Bype
	FileSize=HeadSize+DataSize;
	Count=Width*Height;

	cout<<Count<<endl;

	
	unsigned char BmpHead[54];

	for(int i=0;i<53;i++){
	    BmpHead[i]=0;
	}
    
	BmpHead[0]=0x42;
	BmpHead[1]=0x4D;//type
	cout<<FileSize<<endl;
	
	int SizeNum=2;//the size of bmp file
    while (FileSize!=0) {
		BmpHead[SizeNum++]=FileSize % 256; 
		FileSize = FileSize / 256;
    }

 	cout<<BmpHead[2]<<BmpHead[3]<<BmpHead[4]<<BmpHead[5]<<endl;
  
	BmpHead[0x0A]=0x36;//data begin here
	BmpHead[0x0E]=0x28;//size of bitmap information head
    
	int FileWidthCount = 0x12;//width 
	while (Width != 0)
	{

		BmpHead[FileWidthCount++] = Width % 256;
		Width = Width / 256;

	}
	int FileHeightCount = 0x16;//height
    while (Height != 0)
	{

		BmpHead[FileHeightCount++] = Height % 256;
		Height = Height / 256;
	}
    
	BmpHead[0x1A]=0x1;//device
	BmpHead[0x1C]=0x18;//every pixel need 3 byte

    
    int FileSizeCount=0x22;
	while (DataSize!=0) {
		BmpHead[FileSizeCount++]=DataSize%256;
		DataSize=DataSize/256;
	}

	int i,j;

	for (i=0; i<54; i++)
	{ofile << BmpHead[i];
	 cout<<BmpHead[i]<<endl;
	}

    char blue,green,red;

	ifile.ignore();
	cout<<"ok"<<endl;
	for(int j = Count;j >=1 ;j--){
		//cout<<"begin"<<endl;
		ifile.get(blue);
		ifile.get(green);
		ifile.get(red);

        ofile<<hex;
		ofile.put(red);
		ofile.put(green);
		ofile.put(blue);
		//cout<<j<<endl;
	}

	ifile.close();
	ofile.close();	
	return 0;
}

抱歉!评论已关闭.