?? jpg.cpp
字號:
/*******************************************************************************
Filename: JPG.cpp
Writer : Dai Zhiheng.
Time : 2005-5-14.
Description:
***************************************************************************/
#include <fstream.h>
#include "BitFileHead.h"
#include "readOrWriteFile.h"
#include "JPG.h"
void main()
{
//定義文件
char fileName[40]="lena256.bmp";
char outFileName[40]="lena256.JPG";
cout << "輸入要處理的源BMP文件名(如\"C:\\\\Path1\\\\bmp1.bmp\"),如果在當前文件" <<endl;
cout << "夾,直接寫文件名及擴展名(.BMP),要求圖片的長寬等于2的指數次方:" <<endl ;
cin >> fileName;
cout<<endl;
cout << "輸入輸出的JPG文件名(如\"C:\\\\Path1\\\\bmp1.JPG\"),如果在當前文件" <<endl;
cout << "夾,直接寫文件名及擴展名(.JPG):" <<endl ;
cin >> outFileName;
ifstream inFile;
inFile.open(fileName,ios::binary);
ofstream outFile;
outFile.open(outFileName,ios::binary);
cout <<endl << "………………………………………………………………………"<<endl;
//定義結構
tagBITMAPHEADER bmfh;
tagBITMAPINFOHEADER bmfih;
//讀取圖象相關信息
bmfh.bfSize = readBfSize(inFile);
cout <<" 文件大小為 : " <<dec <<bmfh.bfSize << " Bytes" <<endl;
bmfh.bfOffBits = readBfOffBits(inFile);
cout <<" 數據區偏移位置 : " <<bmfh.bfOffBits <<endl;
bmfih.biWidth = readBiWidth(inFile);
cout <<" 圖象寬度 :" <<bmfih.biWidth<<endl;
bmfih.biHeight = readBiHeight(inFile);
cout <<" 圖象長度 :" <<bmfih.biHeight<<endl;
bmfih.biPlanes = readBiPlanes(inFile);
cout <<" 位面個數:" <<bmfih.biPlanes <<endl;
bmfih.biBitCount = readBiBitCount(inFile);
cout <<" 位深度: "<<bmfih.biBitCount <<endl;
bmfih.biSizeImage = readBiSizeImage(inFile);
cout <<" 位圖陣列大小:" ;
//cout << bmfih.biSizeImage <<endl;
cout <<bmfh.bfSize-bmfh.bfOffBits <<endl <<endl;
unsigned char *pbmpHeadBUF = new unsigned char[bmfh.bfOffBits];
unsigned char *pbmpBits = new unsigned char[bmfh.bfSize-bmfh.bfOffBits];
double *X1 = new double[bmfih.biHeight*bmfih.biWidth];//讀取原圖
//從BMP文件讀取數據
inFile.seekg(0);
inFile.read(pbmpHeadBUF,bmfh.bfOffBits);
inFile.read(pbmpBits,bmfh.bfSize-bmfh.bfOffBits);
inFile.close();
//將數據變為double型:pbmpBits-->X1
for(int i=0; i<bmfih.biHeight; i++)
for(int j=0; j<bmfih.biWidth; j++)
{
*(X1 + i*bmfih.biWidth + j) = (double)(*(pbmpBits + (bmfih.biHeight-i-1)*bmfih.biWidth + j));
}
//JPG
jpg(X1, bmfih.biHeight, bmfih.biWidth, outFile);
delete []pbmpHeadBUF;
delete []pbmpBits;
delete []X1;
}
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -