亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? 如何在 java 應(yīng)用程序中讀取 8 位和 24 位 microsoft windows 位圖(轉(zhuǎn)).txt

?? Java技術(shù)收集很多各種技術(shù)總結(jié)
?? TXT
字號(hào):
作者:zergman
email: zergman@chinaasp.com
日期:2001-6-15 13:28:17
[b]如何在 Java 應(yīng)用程序中讀取 8 位和 24 位 Microsoft Windows 位圖
在 Java 應(yīng)用程序中加載位圖文件的逐步指南[/b]

[b]作者:[/b]Jeff West 和 John D. Mitchell
[BLOCKQUOTE][i][b]摘要[/b]
目前,標(biāo)準(zhǔn)的 getImage() 方法僅支持 GIF 和 JPEG 圖像。盡管存在用于讀取 PNG(可移植網(wǎng)絡(luò)圖形)格式的 Java 例程,但我們還沒聽說過有用于讀取 Microsoft Windows 位圖圖像的閱讀程序。Jeff West 撰寫的這篇技巧提供了加載 Windows 位圖圖像的代碼。[/i] [/BLOCKQUOTE]Java 的當(dāng)前發(fā)行版并不正式支持在 Java 應(yīng)用程序中讀取 Microsoft Windows 位圖文件。但別擔(dān)心,我們有辦法解決這個(gè)問題!這篇技巧將說明如何完成這一任務(wù) -- 我們首先說明讀取 Microsoft Windows 文件格式的基本步驟。 
Windows DIB(設(shè)備獨(dú)立的位圖)文件格式比較簡(jiǎn)單。與純位圖格式不同,DIB 格式保留著用于在內(nèi)存中存儲(chǔ)圖像的明確信息。問題是圖像格式的變體如此之多(1 位、4 位、8 位和 16 位,以及其他格式)。本篇 Java 技巧中提供的解決方案只處理 8 位和 24 位兩種格式。這兩種格式代表了最常見的變體。 
不管是哪種 Windows DIB 子類型,這種文件格式總是由 14 位文件頭和 40 位信息頭組成。這兩個(gè)標(biāo)頭精確包含有關(guān)文件的存儲(chǔ)內(nèi)容和存儲(chǔ)次序的信息。有關(guān)標(biāo)頭中每一項(xiàng)的確切含義,請(qǐng)參考 Microsoft Software Development Kit (SDK)。文件其余部分的內(nèi)容隨信息頭中數(shù)據(jù)的不同而不同。 
我們看一下本文要處理的兩種子類型。24 位格式很簡(jiǎn)單:RGB(紅-綠-藍(lán))顏色值(3 個(gè)字節(jié),并按 BGR 排序)緊接在信息頭之后。但是,每個(gè)掃描行都被補(bǔ)足到 4 個(gè)字節(jié)。按照說明文檔(請(qǐng)參閱 Microsoft SDK)的說法,這種“補(bǔ)足”是為了優(yōu)化 Windows 位圖繪圖 API。同時(shí),底部的掃描行是文件中的第一項(xiàng)內(nèi)容 -- 因此相對(duì)普通的圖形坐標(biāo)系統(tǒng)(其矢量方向的正向分別為向下和向右)而言,必須從后向前讀取圖像。 
8 位子類型由于在信息頭和象素?cái)?shù)據(jù)之間插入調(diào)色板信息而復(fù)雜化。因此,每個(gè)象素條目只是進(jìn)入 24 位 RGB 顏色的調(diào)色板數(shù)組的一個(gè) 8 位索引。在象素信息中,每個(gè)掃描行同樣被補(bǔ)足到 4 個(gè)字節(jié)。 
請(qǐng)注意,本文提供的位圖圖像加載方法不支持對(duì)壓縮位圖圖像進(jìn)行解壓縮。實(shí)際上,這個(gè)例程甚至不尋求這種可能性!如果遇到壓縮 Windows DIB 文件,該例程肯定會(huì)產(chǎn)生異常。Windows SDK 中有對(duì)壓縮 Windows DIB 格式的說明。 
至于性能,在運(yùn)行 Microsoft Windows 95 的 486-DX2-66MHz 系統(tǒng)上,該例程讀取 24 位 640 x 480 的文件(大約 920 千字節(jié))所需的時(shí)間不超過 10 秒。使用 BufferedInputStream 而不是 FileInputStream 可明顯提高性能。 
以下例程讀取兩種文件格式中的任一種,并生成一個(gè) Image 圖像。以下代碼并未包含全面的錯(cuò)誤和異常處理,以避免使該例程更加復(fù)雜。您總可用 Windows Paint 程序?qū)Σ恢С值?Windows DIB 子類型進(jìn)行轉(zhuǎn)換。 
    /**
 loadbitmap() 方法由 Windows C 代碼轉(zhuǎn)換而來。
 只能讀取未壓縮的 24 位和 8 位圖像。已在
 Windows 95 上用 Microsoft Paint 保存的圖像
對(duì)它進(jìn)行了測(cè)試。如果圖像不是 24 位或 8 位圖像,
 該程序拒絕進(jìn)行任何嘗試。我猜測(cè)如果先用 1100,
 然后用 0011 對(duì)字節(jié)執(zhí)行掩碼操作,則也可將 4 位
 圖像包括在內(nèi)。我實(shí)際上對(duì)這些圖像不感興趣。
 如果嘗試讀取壓縮圖像,該例程可能失敗,并產(chǎn)生
 一個(gè) IOException 異常。如果變量 ncompression 
 不為 0,則表示已經(jīng)過壓縮。

 參數(shù):
     sdir 和 sfile 是 FileDialog 的
     getDirectory() 和 getFile() 方法的結(jié)果。

 返回值:
     Image 對(duì)象,切記要檢查 (Image)null !!!!

    */
    public Image loadbitmap (String sdir, String sfile)
 {
 Image image;
 System.out.println("loading:"+sdir+sfile);
 try
     {
     FileInputStream fs=new FileInputStream(sdir+sfile);
     int bflen=14; // 14 字節(jié) BITMAPFILEHEADER
     byte bf[]=new byte[bflen];
     fs.read(bf,0,bflen);
     int bilen=40; // 40 字節(jié) BITMAPINFOHEADER
     byte bi[]=new byte[bilen];
     fs.read(bi,0,bilen);

     // 解釋數(shù)據(jù)。
     int nsize = (((int)bf[5]&0xff)<<24) 
  | (((int)bf[4]&0xff)<<16)
  | (((int)bf[3]&0xff)<<8)
  | (int)bf[2]&0xff;
     System.out.println("File type is :"+(char)bf[0]+(char)bf[1]);
     System.out.println("Size of file is :"+nsize);

     int nbisize = (((int)bi[3]&0xff)<<24)
  | (((int)bi[2]&0xff)<<16)
  | (((int)bi[1]&0xff)<<8)
  | (int)bi[0]&0xff;
     System.out.println("Size of bitmapinfoheader is :"+nbisize);

     int nwidth = (((int)bi[7]&0xff)<<24)
  | (((int)bi[6]&0xff)<<16)
  | (((int)bi[5]&0xff)<<8)
  | (int)bi[4]&0xff;
     System.out.println("Width is :"+nwidth);

     int nheight = (((int)bi[11]&0xff)<<24)
  | (((int)bi[10]&0xff)<<16)
  | (((int)bi[9]&0xff)<<8)
  | (int)bi[8]&0xff;
     System.out.println("Height is :"+nheight);

     int nplanes = (((int)bi[13]&0xff)<<8) | (int)bi[12]&0xff;
     System.out.println("Planes is :"+nplanes);

     int nbitcount = (((int)bi[15]&0xff)<<8) | (int)bi[14]&0xff;
     System.out.println("BitCount is :"+nbitcount);

     // 查找表明壓縮的非零值
     int ncompression = (((int)bi[19])<<24)
  | (((int)bi[18])<<16)
  | (((int)bi[17])<<8)
  | (int)bi[16];
     System.out.println("Compression is :"+ncompression);

     int nsizeimage = (((int)bi[23]&0xff)<<24)
  | (((int)bi[22]&0xff)<<16)
  | (((int)bi[21]&0xff)<<8)
  | (int)bi[20]&0xff;
     System.out.println("SizeImage is :"+nsizeimage);

     int nxpm = (((int)bi[27]&0xff)<<24)
  | (((int)bi[26]&0xff)<<16)
  | (((int)bi[25]&0xff)<<8)
  | (int)bi[24]&0xff;
     System.out.println("X-Pixels per meter is :"+nxpm);

     int nypm = (((int)bi[31]&0xff)<<24)
  | (((int)bi[30]&0xff)<<16)
  | (((int)bi[29]&0xff)<<8)
  | (int)bi[28]&0xff;
     System.out.println("Y-Pixels per meter is :"+nypm);

     int nclrused = (((int)bi[35]&0xff)<<24)
  | (((int)bi[34]&0xff)<<16)
  | (((int)bi[33]&0xff)<<8)
  | (int)bi[32]&0xff;
     System.out.println("Colors used are :"+nclrused);

     int nclrimp = (((int)bi[39]&0xff)<<24)
  | (((int)bi[38]&0xff)<<16)
  | (((int)bi[37]&0xff)<<8)
  | (int)bi[36]&0xff;
     System.out.println("Colors important are :"+nclrimp);

     if (nbitcount==24)
  {
  // 24 位格式不包含調(diào)色板數(shù)據(jù),但掃描行被補(bǔ)足到
  // 4 個(gè)字節(jié)。
  int npad = (nsizeimage / nheight) - nwidth * 3;
  int ndata[] = new int [nheight * nwidth];
  byte brgb[] = new byte [( nwidth + npad) * 3 * nheight];
  fs.read (brgb, 0, (nwidth + npad) * 3 * nheight);
  int nindex = 0;
  for (int j = 0; j < nheight; j++)
      {
      for (int i = 0; i < nwidth; i++)
   {
   ndata [nwidth * (nheight - j - 1) + i] =
       (255&0xff)<<24
       | (((int)brgb[nindex+2]&0xff)<<16)
       | (((int)brgb[nindex+1]&0xff)<<8)
       | (int)brgb[nindex]&0xff;
   // System.out.println("Encoded Color at ("
       +i+","+j+")is:"+nrgb+" (R,G,B)= ("
       +((int)(brgb[2]) & 0xff)+","
       +((int)brgb[1]&0xff)+","
       +((int)brgb[0]&0xff)+")");
   nindex += 3;
   }
      nindex += npad;
      }

  image = createImage
      ( new MemoryImageSource (nwidth, nheight,
          ndata, 0, nwidth));
  }
     else if (nbitcount == 8)
  {
  // 必須確定顏色數(shù)。如果 clrsused 參數(shù)大于 0,
  // 則顏色數(shù)由它決定。如果它等于 0,則根據(jù)
  // bitsperpixel 計(jì)算顏色數(shù)。
  int nNumColors = 0;
  if (nclrused > 0)
      {
      nNumColors = nclrused;
      }
  else
      {
      nNumColors = (1&0xff)<<nbitcount;
      }
  System.out.println("The number of Colors is"+nNumColors);

  // 某些位圖不計(jì)算 sizeimage 域,請(qǐng)找出
  // 這些情況并對(duì)它們進(jìn)行修正。
  if (nsizeimage == 0)
      {
      nsizeimage = ((((nwidth*nbitcount)+31) & ~31 ) >> 3);
      nsizeimage *= nheight;
      System.out.println("nsizeimage (backup) is"+nsizeimage);
      }

  // 讀取調(diào)色板顏色。
  int npalette[] = new int [nNumColors];
  byte bpalette[] = new byte [nNumColors*4];
  fs.read (bpalette, 0, nNumColors*4);
  int nindex8 = 0;
  for (int n = 0; n < nNumColors; n++)
      {
      npalette[n] = (255&0xff)<<24
   | (((int)bpalette[nindex8+2]&0xff)<<16)
   | (((int)bpalette[nindex8+1]&0xff)<<8)
   | (int)bpalette[nindex8]&0xff;
      // System.out.println ("Palette Color "+n
   +" is:"+npalette[n]+" (res,R,G,B)= ("
   +((int)(bpalette[nindex8+3]) & 0xff)+","
   +((int)(bpalette[nindex8+2]) & 0xff)+","
   +((int)bpalette[nindex8+1]&0xff)+","
   +((int)bpalette[nindex8]&0xff)+")");
      nindex8 += 4;
      }

  // 讀取圖像數(shù)據(jù)(實(shí)際上是調(diào)色板的索引)
  // 掃描行仍被補(bǔ)足到 4 個(gè)字節(jié)。
  int npad8 = (nsizeimage / nheight) - nwidth;
  System.out.println("nPad is:"+npad8);

  int ndata8[] = new int [nwidth*nheight];
  byte bdata[] = new byte [(nwidth+npad8)*nheight];
  fs.read (bdata, 0, (nwidth+npad8)*nheight);
  nindex8 = 0;
  for (int j8 = 0; j8 < nheight; j8++)
      {
      for (int i8 = 0; i8 < nwidth; i8++)
   {
   ndata8 [nwidth*(nheight-j8-1)+i8] =
       npalette [((int)bdata[nindex8]&0xff)];
   nindex8++;
   }
      nindex8 += npad8;
      }

  image = createImage
      ( new MemoryImageSource (nwidth, nheight,
          ndata8, 0, nwidth));
  }
     else
  {
  System.out.println ("Not a 24-bit or 8-bit Windows Bitmap, aborting...");
  image = (Image)null;
  }

     fs.close();
     return image;
     }
 catch (Exception e)
     {
     System.out.println("Caught exception in loadbitmap!");
     }
 return (Image) null;
 }

您已掌握了讀取位圖文件的技巧。很容易對(duì)此方法進(jìn)行擴(kuò)展,使它能夠讀取單色和 16 色(4 位)格式。 
[TABLE][TR][TD][b]作者簡(jiǎn)介[/b]
Jeff West 是加州圣地亞哥市的一名工程學(xué)研究生。在研究燃燒和火焰擴(kuò)張的閑暇之余,他沉迷于 Java。 [/TD][/TR][/TABLE]

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国内精品国产成人国产三级粉色| 国产亚洲va综合人人澡精品| 亚洲资源中文字幕| 91日韩在线专区| 亚洲人成精品久久久久| 欧美中文字幕久久| 日韩专区在线视频| 精品久久久久一区二区国产| 国产麻豆成人精品| 亚洲欧美日韩国产综合| 欧美日韩国产在线观看| 日韩av电影天堂| 国产亚洲综合性久久久影院| 色综合久久中文综合久久97| 婷婷综合另类小说色区| 26uuu国产日韩综合| 成人av小说网| 日韩精品五月天| 久久久精品免费网站| 91热门视频在线观看| 日韩高清一级片| 国产欧美1区2区3区| 欧美在线一二三四区| 久久精品噜噜噜成人av农村| 国产精品美女一区二区| 精品视频一区二区三区免费| 久久99久久久久| 亚洲婷婷综合色高清在线| 欧美一区二区日韩| 白白色 亚洲乱淫| 喷水一区二区三区| 国产精品成人一区二区艾草 | 成人动漫一区二区| 亚洲va欧美va人人爽| 欧美国产激情二区三区| 欧美日韩国产另类一区| 99久久夜色精品国产网站| 日本成人中文字幕| 亚洲激情av在线| 国产亚洲欧美日韩俺去了| 欧美日韩在线播放三区四区| 国产精品1024| 日本欧洲一区二区| 亚洲激情自拍偷拍| 久久精品亚洲国产奇米99| 欧美精品自拍偷拍动漫精品| a在线欧美一区| 韩国视频一区二区| 日韩av一二三| 亚洲一区在线观看免费| 国产精品家庭影院| 2欧美一区二区三区在线观看视频| 欧美色电影在线| 99国产精品久久久| 国产精品 日产精品 欧美精品| 日本成人在线看| 亚洲超碰精品一区二区| 亚洲美女淫视频| 国产精品乱码人人做人人爱| 久久众筹精品私拍模特| 日韩欧美一卡二卡| 91精品国产综合久久精品麻豆| 在线亚洲一区观看| 91麻豆文化传媒在线观看| 成人免费视频一区| 国产精品伊人色| 国产在线不卡一卡二卡三卡四卡| 琪琪一区二区三区| 日韩av中文字幕一区二区| 亚洲成人在线观看视频| 亚洲成a人片在线不卡一二三区| 亚洲最色的网站| 一区二区欧美国产| 一二三区精品福利视频| 一区二区在线观看不卡| 伊人色综合久久天天人手人婷| 亚洲三级免费电影| 一区二区三区四区亚洲| 一区二区不卡在线播放| 亚洲一区二区三区四区不卡| 亚洲在线视频免费观看| 亚洲国产精品久久一线不卡| 亚洲影视在线播放| 午夜精品久久久久久久99水蜜桃| 亚洲综合丁香婷婷六月香| 香蕉久久一区二区不卡无毒影院| 午夜精品影院在线观看| 日韩电影网1区2区| 韩国v欧美v日本v亚洲v| 国产精品一二一区| 99精品热视频| 欧美日韩mp4| 日韩欧美一级特黄在线播放| 久久精品无码一区二区三区| 国产精品乱人伦中文| 一区二区高清视频在线观看| 日韩精品乱码av一区二区| 精品一区二区三区视频在线观看| 国产成人在线视频免费播放| 色综合天天综合狠狠| 欧美日韩国产一区| 久久综合久久综合久久| 国产精品色一区二区三区| 亚洲精品国产a久久久久久| 日日摸夜夜添夜夜添亚洲女人| 紧缚奴在线一区二区三区| fc2成人免费人成在线观看播放 | 亚洲欧洲综合另类| 日韩电影免费一区| 成人午夜免费电影| 欧美日本国产一区| 久久久久久夜精品精品免费| 亚洲色图欧洲色图| 极品美女销魂一区二区三区| voyeur盗摄精品| 91精品国产91久久久久久一区二区| 久久精品人人爽人人爽| 亚洲自拍偷拍av| 国产精品99久久久| 欧美日韩精品一区二区三区蜜桃| 国产偷国产偷精品高清尤物| 亚洲成a人片在线观看中文| 国产激情一区二区三区四区 | 日韩精品一区二区三区蜜臀 | 美女国产一区二区| 99精品久久99久久久久| 日韩视频永久免费| 亚洲女同ⅹxx女同tv| 国产一区二区在线影院| 欧美日韩国产一区| 中文字幕在线不卡国产视频| 蜜臀国产一区二区三区在线播放| 色偷偷久久一区二区三区| 久久久99精品久久| 日本欧美韩国一区三区| 一本色道久久综合狠狠躁的推荐| 久久久精品影视| 日韩和欧美一区二区三区| 色婷婷av一区二区三区大白胸| 久久婷婷综合激情| 丝袜美腿高跟呻吟高潮一区| 色婷婷综合五月| 国产精品国产三级国产aⅴ无密码| 另类调教123区| 欧美浪妇xxxx高跟鞋交| 亚洲精品中文在线| 成人av免费在线播放| 久久亚洲精精品中文字幕早川悠里| 天天av天天翘天天综合网色鬼国产| 91丨porny丨户外露出| 欧美极品美女视频| 粉嫩aⅴ一区二区三区四区五区| 日韩精品一区二区三区swag| 日本欧美久久久久免费播放网| 欧美日韩亚洲另类| 亚洲成在人线在线播放| 91久久奴性调教| 一区二区三区在线播放| 91啪在线观看| 亚洲美女屁股眼交| 色哟哟精品一区| 悠悠色在线精品| 91蜜桃免费观看视频| 亚洲精品网站在线观看| 91麻豆.com| 亚洲一区二区精品视频| 欧美中文字幕不卡| 午夜免费久久看| 欧美老年两性高潮| 日本aⅴ精品一区二区三区| 在线综合视频播放| 久色婷婷小香蕉久久| 久久先锋影音av| 岛国精品在线观看| 国产精品久久久久久久久免费丝袜| 成人av电影免费观看| 综合精品久久久| 欧美在线免费观看亚洲| 亚洲成av人片在线观看无码| 欧美顶级少妇做爰| 精品影视av免费| 国产欧美日韩精品一区| av在线不卡电影| 亚洲一区二区三区激情| 日韩色在线观看| 国产精品888| 亚洲私人黄色宅男| 欧美久久久久中文字幕| 国产美女一区二区三区| 国产精品沙发午睡系列990531| 色综合久久中文字幕| 日本不卡123| 国产精品久久久一区麻豆最新章节| 95精品视频在线| 日韩精品亚洲一区二区三区免费| 久久久青草青青国产亚洲免观| 色综合久久中文字幕| 成人在线综合网站| 亚洲欧美综合另类在线卡通| 欧美日本精品一区二区三区|