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

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   管理


<2025年11月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

導航

統計

常用鏈接

留言簿(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>
            毛片av中文字幕一区二区| 蜜臀av一级做a爰片久久| 欧美午夜不卡| 亚洲图色在线| av成人老司机| 国产精品久久久久一区二区三区 | 91久久久久久久久| 欧美激情一区二区三区蜜桃视频| 玖玖国产精品视频| 妖精成人www高清在线观看| 亚洲区第一页| 欧美视频一区二区三区在线观看 | 一区二区三区我不卡| 久久综合狠狠| 欧美高清视频一区二区| 亚洲天堂男人| 欧美综合第一页| 亚洲精品国久久99热| 一区二区三区黄色| 狠狠色综合色综合网络| 亚洲黄色av| 国产精品免费在线| 欧美国产日本韩| 国产精品美女久久福利网站| 久久亚洲美女| 国产精品v日韩精品| 欧美h视频在线| 欧美日韩在线观看视频| 久久久成人网| 欧美日韩99| 久久蜜臀精品av| 欧美视频精品一区| 欧美成人精品| 国产日韩精品一区二区浪潮av| 欧美黄色影院| 国产一区二三区| 亚洲老司机av| 亚洲国产精品电影| 先锋资源久久| 亚洲一区二区三区精品在线| 免费不卡在线观看| 久久久久国产一区二区三区四区| 欧美日韩黄视频| 媚黑女一区二区| 国产欧美在线观看| 一区二区三区日韩在线观看| 91久久在线视频| 欧美中文字幕精品| 欧美一区二粉嫩精品国产一线天| 欧美精品日韩一本| 能在线观看的日韩av| 国产一区91| 午夜精品视频在线观看| 亚洲图片在区色| 欧美日韩欧美一区二区| 亚洲第一网站| 91久久精品国产91久久性色| 久久精品一区二区三区中文字幕 | 一区二区三区在线视频播放| 在线亚洲自拍| 亚洲午夜久久久久久久久电影网| 欧美.日韩.国产.一区.二区| 久久一区欧美| 精品999久久久| 欧美主播一区二区三区美女 久久精品人| 亚洲性感美女99在线| 欧美色欧美亚洲高清在线视频| 亚洲精品免费看| 一区二区三区欧美成人| 欧美日韩一区国产| 正在播放欧美视频| 亚洲综合欧美日韩| 国产精品私拍pans大尺度在线| 亚洲一区二区三区高清| 久久av一区| 国自产拍偷拍福利精品免费一| 欧美一区二区三区啪啪| 久久成人资源| 影音先锋欧美精品| 另类春色校园亚洲| 亚洲国产三级网| 亚洲图片自拍偷拍| 国产欧美日韩精品a在线观看| 欧美一区二区视频在线观看| 美女尤物久久精品| 亚洲精品中文字幕在线观看| 欧美精品久久久久久久免费观看| 一本久久精品一区二区| 欧美在线一二三四区| 在线观看日产精品| 欧美日韩精品一区二区天天拍小说| 夜夜爽夜夜爽精品视频| 久久国产综合精品| 亚洲三级免费电影| 国产精品美女久久久浪潮软件| 欧美一级久久久久久久大片| 欧美高清在线观看| 亚洲欧美日韩网| 在线观看欧美一区| 国产精品久久久久久久久久久久| 性久久久久久久| 亚洲国产欧美一区| 久久大逼视频| 日韩午夜电影在线观看| 国产日韩在线视频| 欧美激情精品久久久六区热门 | 久久久www成人免费毛片麻豆| 欧美国产高潮xxxx1819| 亚洲综合视频一区| 亚洲国产日韩欧美在线图片| 国产精品成人一区二区| 另类国产ts人妖高潮视频| 亚洲图片欧洲图片av| 亚洲成人在线视频网站| 久久成人人人人精品欧| 亚洲成色777777在线观看影院| 午夜国产精品视频免费体验区| 亚洲成色精品| 国产精品五月天| 欧美日韩成人| 久久综合给合久久狠狠色| 亚洲一区二区在线播放| 亚洲欧洲综合另类在线| 裸体一区二区三区| 欧美在线国产精品| 亚洲一区二区三区免费视频| 亚洲人成毛片在线播放| 国产一区二区三区四区| 欧美午夜在线| 欧美日韩另类丝袜其他| 免费观看一级特黄欧美大片| 欧美在线视频一区| 香蕉亚洲视频| 亚洲欧美不卡| 中文在线一区| 正在播放亚洲| 中文亚洲欧美| 亚洲系列中文字幕| 一区二区欧美日韩| 亚洲最新在线| 这里只有精品在线播放| 99re热这里只有精品免费视频| 亚洲成人资源网| 欧美激情一区二区三区在线视频观看| 久久综合九色综合欧美狠狠| 久久亚洲一区二区三区四区| 久久久久高清| 麻豆av一区二区三区| 久久综合免费视频影院| 久久综合九色九九| 牛夜精品久久久久久久99黑人| 免费成人性网站| 欧美国产激情| 亚洲六月丁香色婷婷综合久久| 亚洲国产婷婷香蕉久久久久久99| 亚洲国产精品综合| 亚洲乱码国产乱码精品精可以看| 亚洲国产小视频| 99成人在线| 香蕉国产精品偷在线观看不卡| 欧美一区二区视频在线观看2020 | 亚洲精品国产拍免费91在线| 亚洲日本中文字幕区| 一本色道88久久加勒比精品| 亚洲一级在线| 久久久精品一区| 欧美成人69| 国产精品美女久久久免费| 国产一区二区三区日韩| 亚洲欧洲日韩综合二区| 亚洲视频中文字幕| 久久久久五月天| 亚洲国产导航| 亚洲图片欧洲图片日韩av| 欧美在线观看网址综合| 欧美成人亚洲成人| 国产欧美日本| 亚洲精品久久久久久久久久久| 亚洲综合日韩中文字幕v在线| 久久久精品久久久久| 亚洲经典自拍| 欧美在线亚洲在线| 欧美人与性动交cc0o| 国产一区二区三区久久久| 日韩一本二本av| 久久人人九九| 亚洲网站啪啪| 欧美mv日韩mv国产网站app| 国产精品久久久久久久浪潮网站| 在线观看视频免费一区二区三区| 亚洲午夜激情网站| 欧美成人一区在线| 午夜影院日韩| 国产精品二区在线观看| 亚洲国产精品一区二区三区| 性久久久久久| av成人免费在线观看| 理论片一区二区在线| 国产亚洲一二三区| 亚洲欧美综合精品久久成人|