快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

自己写了一个imagebuffer 转 bmp 流的代码段,希望对大家有用。

try {
   BufferedImage bi = null;
   if (isURL == true) {
    bi = ImageIO.read(new URL(inFileName));
   }
   else {
    bi = ImageIO.read(new File(inFileName));
   }
   
   int[] rgbArray = new int[101 * 29];//我测试用的图象文件象素值宽度是101宽,29长的
   
   bi.getRGB(0, 0, 101, 29, rgbArray, 0, 101);
   for (int i = 0; i < 101 * 29; i++) {//我做的只是双色图,所以这里查出每一个象素是1(黑)还是0(白)
    if ((rgbArray[i] & 0xffffff) == 0x000000)
     rgbArray[i] = 0;
    else
     rgbArray[i] = 1;
   }
   //以下是BMP文件格式的定义,更加详细的说明可以到http://www.wotsit.org找
   int[] identifier = { \\\'B\\\', \\\'M\\\' };
   int[] fileSize = { 0x0E, 0x02, 0x00, 0x00 };
   int[] reserved = { 0x00, 0x00, 0x00, 0x00 };
   int[] bitmapDataOffset = { 0x3E, 0x00, 0x00, 0x00 };
   int[] bitmapHeaderSize = { 0x28, 0x00, 0x00, 0x00 };
   int[] width = { 0x65, 0x00, 0x00, 0x00 };
   int[] height = { 0x1D, 0x00, 0x00, 0x00 };
   int[] planes = { 0x01, 0x00 };
   int[] bitsPerPixel = { 0x01, 0x00 };
   int[] compression = { 0x00, 0x00, 0x00, 0x00 };
   int[] bitmapDataSize = { 0xD0, 0x01, 0x00, 0x00 };
   int[] hResolution = { 0x00, 0x00, 0x00, 0x00 };
   int[] vResolution = { 0x00, 0x00, 0x00, 0x00 };
   int[] colors = { 0x00, 0x00, 0x00, 0x00 };
   int[] importantColors = { 0x00, 0x00, 0x00, 0x00 };
   int[] palette = { 0x00, 0x00, 0x00, 0x00, 0xFF, 0xFF, 0xFF, 0x00 };
   //记住bmp没一个扫描行都要扩充到下一个4bytes的倍数,如101就要变成128,扩充的byte补0即可
   int[] bitmapData = new int[(101 + 27) * 29 / 8];
   int n = 0;
   for (int i = 0; i < 29; i++) { //BMP格式是从最后一行开始scan的
    for (int j = 1; j <= 101; j++) {
     if (rgbArray[(28 - i) * 101 + j - 1] == 1) {
      bitmapData[n] = bitmapData[n] | (1 << (8 - j % 8) % 8);
     }
     if (j % 8 == 0) {
      n++;
     }
     if (j == 101) {
      n += 4;
     }
    }
   }
   RandomAccessFile o = new RandomAccessFile(outFileName, "rw");
   o.setLength(0);
   for (int i = 0; i < identifier.length; i++) {
    o.write(identifier[i]);
   }
   for (int i = 0; i < fileSize.length; i++) {
    o.write(fileSize[i]);
   }
   for (int i = 0; i < reserved.length; i++) {
    o.write(reserved[i]);
   }
   for (int i = 0; i < bitmapDataOffset.length; i++) {
    o.write(bitmapDataOffset[i]);
   }
   for (int i = 0; i < bitmapHeaderSize.length; i++) {
    o.write(bitmapHeaderSize[i]);
   }
   for (int i = 0; i < width.length; i++) {
    o.write(width[i]);
   }
   for (int i = 0; i < height.length; i++) {
    o.write(height[i]);
   }
   for (int i = 0; i < planes.length; i++) {
    o.write(planes[i]);
   }
   for (int i = 0; i < bitsPerPixel.length; i++) {
    o.write(bitsPerPixel[i]);
   }
   for (int i = 0; i < compression.length; i++) {
    o.write(compression[i]);
   }
   for (int i = 0; i < bitmapDataSize.length; i++) {
    o.write(bitmapDataSize[i]);
   }
   for (int i = 0; i < hResolution.length; i++) {
    o.write(hResolution[i]);
   }
   for (int i = 0; i < vResolution.length; i++) {
    o.write(vResolution[i]);
   }
   for (int i = 0; i < colors.length; i++) {
    o.write(colors[i]);
   }
   for (int i = 0; i < importantColors.length; i++) {
    o.write(importantColors[i]);
   }
   for (int i = 0; i < palette.length; i++) {
    o.write(palette[i]);
   }
   for (int i = 0; i < bitmapData.length; i++) {
    o.write(bitmapData[i]);
   }
   o.close();
  }
  catch (MalformedURLException e) {
   e.printStackTrace();
  }
  catch (IOException e) {
   e.printStackTrace();   
  }

假如有什么不明白的,请联系我flcc@263.sina.com,我将尽我所能的帮助你。



返回类别: 教程
上一教程: 利用Observer模式解决组件间通信问题
下一教程: JavaMail邮件主题乱码的解决方式

您可以阅读与"自己写了一个imagebuffer 转 bmp 流的代码段,希望对大家有用。"相关的教程:
· 和同事写了一个下午的递归读取数据库的javabean
· 一些无聊的代码之一:JAVA中的日期计算
· 问一个低级输入流的问题。。。
· 100行Java代码构建一个线程池
· 关于JAVA中连接各类数据库的代码及其补充说明
    微笑服务 优质保证 索取样品