BOOL CTifImage_48Bits::BitmapConvertTo48BitsTif(CString strImagePath, int nWidth, int nHeight, int nBpp, BYTE* pData)
{
  if (nBpp != )
  {
    AfxMessageBox(L"只支持24位真彩图!");
    return FALSE;
  }   if (pData == NULL)
  {
    AfxMessageBox(L"内存段为空!");
    return FALSE;
  } // 调整文件路径名称
  int nFind = strImagePath.ReverseFind('.');
  if (nFind == -)
  {
    return FALSE;
  }   CString strExt = strImagePath.Mid(nFind + );
  strExt.MakeLower();
  if (strExt != L"tif" && strExt != L"tiff")
  {
    strImagePath = strImagePath.Left(nFind + );
    strImagePath += L"tiff";
  } // 转换图像文件路径格式
  LPSTR ppszA = '\0';
  UnicodeToAnsi(strImagePath.GetBuffer(),&ppszA);   TIFF *image; // 打开一个tif文件
  if((image = TIFFOpen(ppszA, "w")) == NULL)
  {
    AfxMessageBox(L"不能创建TIF文件!");
    return FALSE;
  }   const int nTifBit = ; // 分配内存
  DWORD dwImgSize = nWidth * nHeight * nTifBit;
  BYTE* pTifBuf = new BYTE[dwImgSize];
  if (pTifBuf == NULL)
  {
    AfxMessageBox(L"内存分配不足!");
    return FALSE;
  }   memset(pTifBuf, , dwImgSize);   int nWidthBytes24 = (( nWidth * nBpp + ) / ) * ;
  int nWidthBytes48 = nWidth * nTifBit; // 复制图像数据
  BYTE* pSrc = (pData);
  BYTE* pDst = (pTifBuf);   int tmpSrc = ;
  int tmpDst = ;   for (int j = ; j < nHeight; j++)
  {
    tmpSrc = ;
    tmpDst = ;     for (int i = ; i < nWidth; i++)
    {
// // RGBRGB,PhotoShop支持,但是未能实现
// pDst[tmpDst + 2] = pDst[tmpDst + 5] = pSrc[tmpSrc];
// pDst[tmpDst + 1] = pDst[tmpDst + 4] = pSrc[tmpSrc + 1];
// pDst[tmpDst + 0] = pDst[tmpDst + 3] = pSrc[tmpSrc + 2]; // RRGGBB
      pDst[tmpDst + ] = pDst[tmpDst + ] = pSrc[tmpSrc];
      pDst[tmpDst + ] = pDst[tmpDst + ] = pSrc[tmpSrc + ];
      pDst[tmpDst + ] = pDst[tmpDst + ] = pSrc[tmpSrc + ];       tmpSrc += ;
      tmpDst += ;
    }     pSrc -= nWidthBytes24;
    pDst += nWidthBytes48;
  }
// 设置图像宽度.
  TIFFSetField(image, TIFFTAG_IMAGEWIDTH, nWidth); // 设置图像高度.
  TIFFSetField(image, TIFFTAG_IMAGELENGTH, nHeight); // 设置一个样本所占内存的大小.
  TIFFSetField(image, TIFFTAG_BITSPERSAMPLE, ); // 设置一个像素点的样本数.
  TIFFSetField(image, TIFFTAG_SAMPLESPERPIXEL, nTifBit / ); // 设置图像的压缩方式.
  TIFFSetField(image, TIFFTAG_COMPRESSION, COMPRESSION_NONE); // 设置色彩模式.
  TIFFSetField(image, TIFFTAG_PHOTOMETRIC, PHOTOMETRIC_RGB); // 设置配置
  TIFFSetField(image, TIFFTAG_PLANARCONFIG, PLANARCONFIG_CONTIG); // 设置Planar配置.
  TIFFSetField(image, TIFFTAG_PLANARCONFIG, PLANARCONFIG_CONTIG);   int32 iTiffCount = TIFFWriteEncodedStrip(image, , pTifBuf, nWidth * nHeight * nTifBit);   TIFFClose(image);   delete pTifBuf;
  pTifBuf = NULL; // 如果返回值大于0,表示已经被压缩的数据大小
  return (iTiffCount > );
}

libtiff 生成48位色tif图片的更多相关文章

  1. 生成base64位图片验证码

    import org.springframework.util.Base64Utils; import javax.imageio.ImageIO; import java.awt.*; import ...

  2. 【安富莱专题教程第1期】基于STM32的硬件RGB888接口实现emWin的快速刷新方案,32位色或24

    说明:1. 首先感谢ST终于推出了ARGB格式的emWin库,可谓千呼万唤始出来,使用STM32的硬件RGB888接口刷新图片慢的问题终于得到解决.2. 这个问题由来已久,是之前为我们的STM32-V ...

  3. 颜色模式中8位,16位,24位,32位色彩是什么意思?会有什么区别?计算机颜色格式( 8位 16位 24位 32位色)<转>

    颜色模式中8位,16位,24位,32位色彩是什么意思?会有什么区别简单地说这里说的位数和windows系统显示器设置中的颜色位数是一样的.表示的是能够显示出来的颜色的多少. 8位的意思是说,能够显示出 ...

  4. Java使用ZXing生成/解析二维码图片

    ZXing是一种开源的多格式1D/2D条形码图像处理库,在Java中的实现.重点是在手机上使用内置摄像头来扫描和解码设备上的条码,而不与服务器通信.然而,该项目也可以用于对桌面和服务器上的条形码进行编 ...

  5. TensorFlow从1到2(十二)生成对抗网络GAN和图片自动生成

    生成对抗网络的概念 上一篇中介绍的VAE自动编码器具备了一定程度的创造特征,能够"无中生有"的由一组随机数向量生成手写字符的图片. 这个"创造能力"我们在模型中 ...

  6. Python基础(二):斐波那契数列、模拟cp操作、生成8位随机密码

    一.斐波那契数列 目标: 编写fib.py脚本,主要要求如下: 输出具有10个数字的斐波那契数列 使用for循环和range函数完成 改进程序,要求用户输入一个数字,可以生成用户需要长度的斐波那契数列 ...

  7. Highcharts结合PhantomJS在服务端生成高质量的图表图片

    项目背景 最近忙着给部门开发一套交互式的报表系统,来替换原有的静态报表系统. 老系统是基于dotnetCHARTING开发的,dotnetCHARTING的优势是图表类型丰富,接口调用简单,使用时只需 ...

  8. js 生成m位随机数入门实例

    1.根据时间生成m位随机数,最大13位随机数,并且不能保证首位不为0. 例子: function ran(m) { m = m > 13 ? 13 : m; var num = new Date ...

  9. java 生成8位数字作为UID

    java 生成8位数字作为UUID: /*** * 生成uid 8位数字 */public static String generateUID(){ Random random = new Rando ...

随机推荐

  1. Tor

    参考: http://www.douban.com/group/topic/67555786/ http://blog.sina.com.cn/s/blog_72a7ac670101km46.html ...

  2. mysql lower,upper实现大小写

    mysql的lower和uppper函数可以将指定字符串转换为小写和大写 select lower('OutSpringTd') as lowerCase, upper('OutSpringTd') ...

  3. Heap:左式堆的应用例(任意序列变单调性最小价值)

    首先来说一下什么是左式堆: A:左式堆是专门用来解优先队列合并的麻烦(任意二叉堆的合并都必须重新合并,O(N)的时间). 左式堆的性质: 1.定义零路经长:节点从没有两个两个儿子节点的路经长,把NUL ...

  4. ORACLE查询当前资产状态,和另一个数据库联查,(查询重复数据中第一条),子查询作为字段查询

    背景:ORACLE查询当前资产状态,包含资产信息(表1),资产维修状态(表2),资产报废状态(表3) 如下: 资产信息:

  5. HDU 4059 容斥原理+快速幂+逆元

    E - The Boss on Mars Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64 ...

  6. p235习题2

    List  成功添加 Set  添加失败

  7. [转]Java Thread Dump 性能分析

    Java and Thread 一个 web 服务器使用几十到几百个线程来处理大量并发用户,如果一个或多个线程使用相同的资源,线程之间的竞争就不可避免了,并且有时候可能会发生死锁. Thread co ...

  8. JavaScript开发中的一些问题

    1.求y和z的值是多少? <script type=”text/javascript”> var x = 1; var y = 0; var z = 0; function add(n){ ...

  9. js 默认行为取消

    js 默认行为取消   可以简单的  return false;   看需求吧 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transit ...

  10. Ps 之路 更改前景色

     用快速选中工具 选中要改变的图片,选中你喜欢的颜色,按Alt+Del