亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

printscreen讀取位圖轉為jpeg格式輸出

2019-11-18 13:13:43
字體:
來源:轉載
供稿:網友

  package screensaver;
  
  import java.awt.*;
  import java.awt.image.BufferedImage;
  import java.io.*;
  import java.util.*;
  import com.sun.image.codec.jpeg.*;
  import java.awt.Image;
  import java.awt.Toolkit;
  import java.awt.image.BufferedImage;
  import java.awt.image.MemoryImageSource;
  import java.io.FileInputStream;
  import java.io.FileOutputStream;
  import com.sun.image.codec.jpeg.JPEGCodec;
  import com.sun.image.codec.jpeg.JPEGImageEncoder;
  
  public class ScreenPicSaver
  {
   MediaTracker tracker = new MediaTracker(new Component()
   {});
  
   public ScreenPicSaver()
   {}
  
   public Image loadbitmap(String sdir, String sfile) //讀取8位或24位的位圖文件
   {
    Image image;
    System.out.    try
    {
     FileInputStream fs = new FileInputStream(sdir + sfile);
     int bflen = 14; // 14 字節 BITMAPFILEHEADER
     byte bf[] = new byte[bflen];
     fs.read(bf, 0, bflen);
     int bilen = 40; // 40 字節 BITMAPINFOHEADER
     byte bi[] = new byte[bilen];
     fs.read(bi, 0, bilen);
  
     // 解釋數據。
     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 位格式不包含調色板數據,但掃描行被補足到
      // 4 個字節。
      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 = Toolkit.getDefaultToolkit().createImage
        (new MemoryImageSource(nwidth, nheight,
                    ndata, 0, nwidth));
     }
     else if (nbitcount == 8)
     {
      // 必須確定顏色數。假如 clrsused 參數大于 0,
      // 則顏色數由它決定。假如它等于 0,則根據
      // bitsperpixel 計算顏色數。
      int nNumColors = 0;
      if (nclrused > 0)
      {
       nNumColors = nclrused;
      }
      else
      {
       nNumColors = (1 & 0xff) < < nbitcount;
      }
      System.out.println("The number of Colors is" + nNumColors);
  
      // 某些位圖不計算 sizeimage 域,請找出
      // 這些情況并對它們進行修正。
      if (nsizeimage == 0)
      {
       nsizeimage = ( ( ( (nwidth * nbitcount) + 31) & ~31) >> 3);
       nsizeimage *= nheight;
       System.out.println("nsizeimage (backup) is" + nsizeimage);
      }
  
      // 讀取調色板顏色。
      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) bpal

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
色婷婷综合久久久久| 91免费看国产| 日韩中文视频免费在线观看| 777国产偷窥盗摄精品视频| 亚洲四色影视在线观看| 成人a级免费视频| 久久国产精品久久久久久久久久| 国产乱人伦真实精品视频| 97在线精品国自产拍中文| 久久99久久99精品免观看粉嫩| 伦理中文字幕亚洲| 亚洲第一av网| 91亚洲精品在线观看| 久久精品在线播放| 91香蕉嫩草神马影院在线观看| 久久免费精品日本久久中文字幕| 久久久噜噜噜久久| 亚洲福利在线播放| 久久精品99国产精品酒店日本| 日本久久久久久久| 国模精品视频一区二区| 国产玖玖精品视频| 最新国产精品拍自在线播放| 欧美激情一区二区三区高清视频| 国产精品老女人视频| 国产精品免费一区二区三区都可以| 亚洲日韩欧美视频一区| 欧美午夜精品久久久久久浪潮| 欧美激情一区二区久久久| 2020久久国产精品| 亚洲电影在线观看| 国产精品美女免费看| 欧美老少配视频| 久久精品国产精品亚洲| 国产91露脸中文字幕在线| 欧美成人午夜激情视频| 亚洲精品电影网在线观看| 粉嫩老牛aⅴ一区二区三区| 欧美另类极品videosbest最新版本| 欧美成人精品影院| 欧美最猛性xxxxx亚洲精品| 亚洲第一视频网站| 欧美高跟鞋交xxxxxhd| 91亚洲精品久久久久久久久久久久| 欧美午夜视频在线观看| 久久国产色av| 日韩av在线电影网| 欧美日韩免费网站| 日韩av在线影院| 日韩中文字幕在线播放| 亚洲成人av中文字幕| 91国内揄拍国内精品对白| 久久99热这里只有精品国产| 亚洲福利在线看| 国产精品一区二区三区成人| 欧美床上激情在线观看| 国产精品一区二区三区在线播放| 狠狠爱在线视频一区| 欧美最猛性xxxxx(亚洲精品)| 精品久久久久人成| 亚洲成av人乱码色午夜| 日本成熟性欧美| 性欧美暴力猛交69hd| 日韩精品在线观看视频| 国模视频一区二区三区| 国产91精品青草社区| 国产精品igao视频| 亚洲最大在线视频| 全亚洲最色的网站在线观看| 国产日韩欧美影视| 久久久久久欧美| 精品无码久久久久久国产| 国产精品日韩欧美| 亚洲午夜精品久久久久久久久久久久| 视频在线一区二区| 亚洲视频axxx| 亚洲精品综合久久中文字幕| 久久亚洲国产成人| 日本最新高清不卡中文字幕| 成人激情视频小说免费下载| 亚洲激情中文字幕| 日韩av资源在线播放| 自拍偷拍免费精品| 亚洲国产精品久久久久| 国产精品一区二区三| 最近免费中文字幕视频2019| 亚洲欧美视频在线| 黑人极品videos精品欧美裸| 亚洲午夜精品久久久久久性色| 日本久久久久久久| 久久av在线播放| 久久青草福利网站| 亚洲第一天堂无码专区| 91精品久久久久久久久中文字幕| 日韩视频中文字幕| 欧美高清电影在线看| 欧美日韩国产在线| 国产成人一区二区三区| 黑人极品videos精品欧美裸| 91精品久久久久久久久久久| 久久精品中文字幕一区| 久久久999精品| 日韩在线免费视频观看| 日本一区二区三区在线播放| 日本免费在线精品| 日本高清+成人网在线观看| 日本一区二区在线播放| 午夜精品久久久久久久白皮肤| 欧美大尺度电影在线观看| 国产日韩精品视频| 亚洲欧洲黄色网| 亚洲精品中文字幕av| 国产精品一区二区三区久久| 这里只有精品视频| 中文字幕精品www乱入免费视频| 成人精品久久久| 国产一区香蕉久久| 国产精品成人免费电影| 国产精品美乳在线观看| 国产日韩欧美视频在线| 欧美成人性色生活仑片| 国产成人久久精品| 2019中文字幕全在线观看| 国产精品ⅴa在线观看h| 2019中文字幕在线| 91社区国产高清| 日韩免费中文字幕| 亚洲а∨天堂久久精品9966| 亚洲国产97在线精品一区| 亚洲一区二区三区四区在线播放| 欧美老女人在线视频| 亚洲欧美国产一本综合首页| 亚洲在线视频观看| 精品福利一区二区| 亚洲国产古装精品网站| 国产精品美女无圣光视频| 最好看的2019的中文字幕视频| 欧美在线性视频| 日韩av资源在线播放| 岛国av一区二区三区| 久久久久中文字幕2018| 精品亚洲一区二区三区四区五区| 91久久精品一区| 国产盗摄xxxx视频xxx69| 亚洲国产欧美精品| 欧美自拍视频在线观看| 国产精品视频大全| 91免费人成网站在线观看18| 日韩亚洲精品视频| 另类专区欧美制服同性| 国产一区二区日韩| 亚洲一区二区三区视频| 亚洲欧洲中文天堂| 91超碰中文字幕久久精品| 中文字幕久精品免费视频| 国产精品h片在线播放| 亚洲摸下面视频| 青青在线视频一区二区三区| 91欧美日韩一区| 国产精品成人一区二区| 亚洲免费人成在线视频观看| 国产一区欧美二区三区| 久久综合久久美利坚合众国| 国产精品精品视频一区二区三区|