青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

bmp圖片格式學習(c++代碼)

 

//這個程序用來讀取256*256大小的單色bmp黑白圖片,適當修改就可讀取任意大小任意
//顏色的bmp圖片,在生成文件里,0和1表示黑白,不過用記事本查看會有亂碼
//可以用UE查看16進制形式,沒有問題的
#include <fstream>
#include 
<iostream>
using namespace std; 
typedef unsigned 
char var8;
typedef unsigned 
int uvar32;
typedef unsigned 
short int uvar16;
typedef  
struct  { var8 Blue,Green,Red,Reserved;}  Palette;
int main()
{
  uvar32 Size,Offset,Height,Width,Compress,Reserved,
  InfoHeaderSize,Colors,ImportantColors,DataSize,HResolution,VResolution;
  uvar16 Planes,Bit;
  
int i,j;
  var8 type[
2],imdata[256][256],imdata2[1024];
  Palette Rgbquad;
  ifstream fin;
  ofstream fout;
  fin.open(
"test.bmp",ios::binary);   
  
/*以二進制讀方式打開該文件,一定要二進制的!路徑為存儲圖片路徑*/
  fout.open(
"out.txt", ios::out|ios::binary);
  
//out.txt為保存結果文件,有趣的很,加上bmp數據,改了后綴就能顯示了,我試過
  if(!fin)
  
{
    cout
<<"No this file!\n";
    
return 1;
  }

  
  fin.read((
char*)&type ,2);
  cout
<<"file type: "<<type[0]<<type[1]<<endl;
  
/* 兩字節的內容用來識別位圖的類型,偏移量0,結果file type: BM*/
  fin.read((
char*)&Size ,sizeof(uvar32));
  cout
<<"file size: "<<Size<<endl;
  
/*整個文件的大小,偏移量2,結果file size: 8254*/
  fin.read((
char*)&Reserved,sizeof(uvar32));
  cout
<<"Reserved dword: "<<Reserved<<endl;
  
/*保留,必須設置為0, 偏移量6,結果Reserved dword: 0*/
  fin.read((
char*)&Offset  ,sizeof(uvar32));
  cout
<<"Offset: "<<Offset<<endl;
  
/*從文件開始到位圖數據開始之間的數據(bitmap data)之間的偏移量
   ,結果Offset: 62。位圖數據為256*256,
   65536(位圖數據)+62*8(偏移量)=(文件大小)記得是bit位
*/

  fin.read((
char*)&InfoHeaderSize,sizeof(uvar32));
  cout
<<"Bitmap Info Header Size: "<<InfoHeaderSize<<endl; 
  
/*位圖信息頭(Bitmap Info Header)的長度,偏移量14,
   結果 Bitmap Info Header Size: 40
*/

  fin.read((
char*)&Width,sizeof(uvar32));
  cout
<<"Bitmap Width: "<<Width<<endl;
  
/*位圖的寬度,以象素為單位,偏移量18,Bitmap Width: 256*/
  fin.read((
char*)&Height,sizeof(uvar32));
  cout
<<"Bitmap Height: "<<Height<<endl;
  
/*位圖的高度,以象素為單位,如果該值是一個正數,說明圖像是倒向的,
  如果該值是一個負數,則說明圖像是正向的。偏移量22,Bitmap Height: 256
*/

  fin.read((
char*)&Planes,sizeof(uvar16));
  cout
<<"Bitmap Planes: "<<Planes<<endl;
  
/*位圖的位面數(注:該值將總是1),偏移量26,Bitmap Planes: 1*/
  fin.read((
char*)&Bit,sizeof(uvar16));
  cout
<<"Bits per Pixel: "<<Bit<<endl;
  
/*每個象素的位數,偏移量28,單色應該1bit,Bits per Pixel: 1*/ 
  fin.read((
char*)&Compress,sizeof(uvar32));
  cout
<<"Compresssion Y or N: "<<Compress<<endl;
  
/*壓縮說明0為不壓縮,偏移量30,Compresssion Y or N: 0*/
  
if(Compress) { fin.close();return 2;}
  fin.read((
char*)&DataSize,sizeof(uvar32));
  cout
<<"Data Size: "<<DataSize<<endl;
  
/*用字節數表示的位圖數據的大小,偏移量34,256*256/8=8192,
   Data Size: 8192
*/

  fin.read((
char*)&HResolution,sizeof(uvar32)); 
  cout
<<"HResolution: "<<HResolution<<endl;
  
/*用象素/米表示的水平分辨率,偏移量38,HResolution: 0*/
  fin.read((
char*)&VResolution,sizeof(uvar32));
  cout
<<"VResolution: "<<VResolution<<endl;
  
/*用象素/米表示的垂直分辨率,偏移量42,VResolution: 0*/
  fin.read((
char*)&Colors,sizeof(uvar32));
  cout
<<"Colors: "<<Colors<<endl;
  
//fout<<Colors;
  /*位圖使用的顏色數,應該為2,不過我試過很多次都輸出0,不影響的*/
  fin.read((
char*)&ImportantColors,sizeof(uvar32));
  cout
<<"ImportantColors: "<<ImportantColors<<endl;
  
/*指定重要的顏色數。當該域的值等于顏色數時(或者等于0時),
  表示所有顏色都一樣重要。偏移量50,ImportantColors: 0
*/

  
for(i=0;i<2;i++)
  
{
      fin.read((
char*)&Rgbquad,sizeof(Palette));
      cout
<<int(Rgbquad.Blue)<<" "<<int(Rgbquad.Green)<<" "<<int(Rgbquad.Red)

<<"  "<<int(Rgbquad.Reserved)<<endl;
  
  }

  
/*調色板規范。對于調色板中的每個表項,這4個字節用下述方法來
  描述RGB的值:1字節用于藍色分量 ,1字節用于綠色分量 ,1字節用于紅色分量 
  1字節用于填充符(設置為0),對于彩色圖像R,G,B
  有各自的分量,對與黑白圖像,R=G=B=灰度級。輸出結果有 0 0 0 0,
  255 255 255 0
*/

  fin.seekg(Offset,ios::beg);
  
  
for( i=255;i>=0;i--)
  
{
     
for(j=0;j<32;j++)
     

      fin.read((
char*)&imdata[i][j],sizeof(var8));
   fout
<<imdata[i][j];
     }

  }

  
  fout.close();
  
/*直接把8254個像素的灰度讀入數組imdata中,由于前面調色板的格式,讀出的數據無
需 索引調色板。由于Height值大于零,圖像倒置的,開始讀入的數據是圖像最后一行的灰
度值。
*/

  
return 0;

}

posted on 2008-05-08 10:00 OIO 閱讀(5067) 評論(3)  編輯 收藏 引用

評論

# re: bmp圖片格式學習(c++代碼) 2009-04-23 17:33 老羊

真好!大有收獲!  回復  更多評論   

# re: bmp圖片格式學習(c++代碼) 2009-04-23 17:33 老羊

真好!大有收獲!
  回復  更多評論   

# re: bmp圖片格式學習(c++代碼) 2009-07-30 17:25 ablajan

nt main(int argc, char *argv[])
{
fstream fs;
fs.open(_T("文本.txt"));

fstream fw;
fw.open("text.txt");
char arr[LEN] = {0};
wchar_t temp[2*LEN+1] = {0};
int length;
if(!fs || !fw)
{
cout << "Error" << endl;
return -1;
}
while(!fs.eof())
{
fs.read(arr, sizeof(arr)-1);
cout << arr;
fw.write(arr, sizeof(arr)-1);
memset(arr, 0, sizeof(arr));

}
cout << endl;
fs.close();
fw.close();
return 0;
}
  回復  更多評論   


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


<2008年2月>
272829303112
3456789
10111213141516
17181920212223
2425262728291
2345678

導航

統計

常用鏈接

留言簿(1)

隨筆檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲网址在线| 欧美在线视频一区| 亚洲黄色影片| 欧美电影免费观看大全| 日韩视频在线一区二区三区| 亚洲人体1000| 国产精品毛片a∨一区二区三区| 亚洲综合成人婷婷小说| 亚洲无亚洲人成网站77777| 国产精品日韩在线观看| 久久久久国产精品www| 久久午夜电影网| 亚洲美女网站| 亚洲男人的天堂在线| 伊人婷婷欧美激情| 亚洲人成亚洲人成在线观看| 欧美特黄视频| 久久午夜影视| 欧美日韩一区在线观看视频| 欧美在线免费| 欧美成人免费全部观看天天性色| 亚洲视频欧美在线| 午夜精品三级视频福利| 在线免费不卡视频| 日韩五码在线| 在线播放视频一区| 夜夜嗨av一区二区三区网页| 国产又爽又黄的激情精品视频| 欧美第一黄色网| 国产精品视频福利| 亚洲第一久久影院| 国产午夜久久久久| 91久久夜色精品国产九色| 国产精品亚洲成人| 亚洲国产一区二区精品专区| 国产农村妇女精品一区二区| 亚洲欧洲一区二区三区| 国产在线不卡精品| 在线一区欧美| 日韩亚洲国产欧美| 久久精品理论片| 午夜久久久久| 欧美日韩国产小视频| 久久香蕉精品| 国产日韩欧美视频| 亚洲亚洲精品在线观看 | 久久久精品视频成人| 正在播放亚洲一区| 牛人盗摄一区二区三区视频| 久久久在线视频| 国产伦精品一区二区三区高清版| 亚洲精品在线视频| 亚洲精品一区二区三区四区高清| 欧美一区亚洲| 久久精品国亚洲| 国产老女人精品毛片久久| 99天天综合性| 亚洲最新中文字幕| 欧美精品日韩一区| 亚洲国产裸拍裸体视频在线观看乱了 | 欧美国产日韩一区二区在线观看| 国产日韩欧美黄色| 亚洲女性裸体视频| 欧美亚洲色图校园春色| 国产精品成人一区二区网站软件| 亚洲精品综合在线| 一本色道综合亚洲| 欧美韩国日本综合| 日韩视频一区二区三区在线播放免费观看| 影音先锋在线一区| 巨乳诱惑日韩免费av| 欧美高潮视频| 亚洲精品久久久蜜桃| 欧美+亚洲+精品+三区| 亚洲日韩视频| 一区二区三区欧美在线| 欧美日韩成人一区二区| 日韩视频在线观看一区二区| 一本色道久久综合亚洲精品按摩| 欧美伦理影院| 亚洲视频在线看| 先锋影音久久久| 国产一区91| 欧美大片免费久久精品三p| 亚洲人屁股眼子交8| 亚洲淫性视频| 国产一区久久久| 免费高清在线视频一区·| 亚洲精品一区在线| 午夜久久tv| 在线精品亚洲| 欧美另类极品videosbest最新版本| 夜夜嗨av一区二区三区网站四季av | 国外成人在线| 欧美极品在线观看| 亚洲在线一区二区三区| 久久午夜羞羞影院免费观看| 亚洲六月丁香色婷婷综合久久| 欧美日韩一区二区在线视频| 午夜视频在线观看一区二区三区| 久久综合狠狠综合久久综合88| 亚洲精选中文字幕| 国产精品一区免费观看| 久热精品视频在线观看一区| 亚洲另类视频| 久久亚洲一区二区| 亚洲一区二区三区欧美 | 国产精品久久久久久久久久ktv| 91久久久久| 日韩视频免费在线| 国产欧美日韩在线| 欧美高清hd18日本| 欧美亚洲视频在线观看| 亚洲美女av网站| 久久综合图片| 午夜精品美女久久久久av福利| 亚洲国产精品久久人人爱蜜臀| 欧美日韩国产在线| 另类欧美日韩国产在线| 亚洲欧美另类中文字幕| 91久久在线播放| 美女网站在线免费欧美精品| 午夜精品在线| 亚洲一级网站| 一区二区三区精品视频在线观看| 韩国av一区二区| 国产精品一区免费观看| 欧美日韩伊人| 欧美乱妇高清无乱码| 欧美成年人视频网站| 久久国产精品色婷婷| 亚洲制服av| 亚洲一区日韩| 亚洲色在线视频| 日韩视频在线观看一区二区| 亚洲黄色影院| 亚洲国产欧美在线| 欧美电影在线免费观看网站| 免费不卡视频| 老司机亚洲精品| 狂野欧美一区| 狂野欧美激情性xxxx| 麻豆成人av| 麻豆av一区二区三区| 久久米奇亚洲| 久久人人爽人人爽爽久久| 久久久美女艺术照精彩视频福利播放| 欧美亚洲在线| 久久精品视频在线看| 欧美在线观看天堂一区二区三区| 亚洲欧美日韩国产综合在线| 香蕉久久a毛片| 久久国产加勒比精品无码| 性欧美1819性猛交| 久久精品国产亚洲精品| 久久亚洲风情| 亚洲大片精品永久免费| 亚洲精品久久| 亚洲天堂激情| 久久久激情视频| 欧美顶级少妇做爰| 欧美美女操人视频| 国产精品都在这里| 国产一区二区精品| 亚洲国产欧美一区二区三区久久 | 欧美日韩亚洲一区二区三区在线观看| 欧美日韩成人在线视频| 国产精品久久久久久久久久免费| 国产精品亚洲综合天堂夜夜| 国产亚洲欧洲一区高清在线观看| 一区久久精品| 99这里只有精品| 欧美亚洲免费电影| 欧美成人自拍| 亚洲一区二区在线看| 久久国产一区二区三区| 欧美大片一区二区| 国产精品免费小视频| 亚洲福利视频网| 亚洲男女自偷自拍图片另类| 裸体一区二区三区| 亚洲精选在线| 久久麻豆一区二区| 欧美三级视频在线| 在线看片欧美| 亚洲欧美日韩网| 亚洲福利视频三区| 亚洲在线日韩| 欧美精品国产| 在线观看欧美亚洲| 午夜精品久久久久99热蜜桃导演| 欧美sm视频| 亚洲欧美综合国产精品一区| 欧美精品三级日韩久久| 国内揄拍国内精品久久| 亚洲欧美精品| 最新日韩中文字幕| 久久免费精品视频| 国产精品视频免费一区| 日韩写真视频在线观看|