//打开位图文件,得到位图句柄
  HBITMAP OpenBmpFile(HDC hDC, LPSTR lpszFileName)
  {
      HBITMAP hBmp = NULL;
      //读位图文件,得到位图句柄
      HANDLE hFile = CreateFile(
          lpszFileName,
          GENERIC_READ,
          FILE_SHARE_READ,
          NULL,
          OPEN_EXISTING,
          FILE_ATTRIBUTE_NORMAL,
          NULL);
      if(hFile == INVALID_HANDLE_VALUE)
          return NULL;
      //读位图文件头
      BITMAPFILEHEADER bmpFileHeader;
      DWORD dwNumberOfBytesRead;
      if(ReadFile(hFile, (LPVOID)&bmpFileHeader, sizeof(BITMAPFILEHEADER), &dwNumberOfBytesRead, NULL) == 0)
      {  
          CloseHandle(hFile);
          return NULL;
      }
      //读位图信息
      BITMAPINFO *pBmpInfo = new BITMAPINFO;
      if(ReadFile(hFile, pBmpInfo, sizeof(BITMAPINFOHEADER), &dwNumberOfBytesRead, NULL) == 0)
      {  
          CloseHandle(hFile);
          return NULL;
      }
      //读位图数据
      LPVOID pBmpData;
      //创建DIB位图句柄
      hBmp = CreateDIBSection(hDC, pBmpInfo, DIB_PAL_COLORS, &pBmpData, NULL, 0);
      if(hBmp == NULL)
      {
          DWORD dwErr = GetLastError();
          return NULL;
      }
      else  //读位图数据
          if(ReadFile(hFile, pBmpData, pBmpInfo->bmiHeader.biSizeImage, &dwNumberOfBytesRead, NULL) == 0)
          {  
              CloseHandle(hFile);
              return NULL;
          }      
      CloseHandle(hFile);
      return hBmp;
  }
  
  //下面的代码是把一张位图保存于文件中,参考MSDN
  PBITMAPINFO CreateBitmapInfoStruct(HWND hwnd, HBITMAP hBmp)
  {
      BITMAP bmp;
      PBITMAPINFO pbmi;
      WORD    cClrBits;
  
      // Retrieve the bitmap's color format, width, and height.
      if (!GetObject(hBmp, sizeof(BITMAP), (LPSTR)&bmp))
          return NULL;
  
      // Convert the color format to a count of bits.
      cClrBits = (WORD)(bmp.bmPlanes * bmp.bmBitsPixel);
      if (cClrBits == 1)
          cClrBits = 1;
      else if (cClrBits <= 4)
          cClrBits = 4;
      else if (cClrBits <= 8)
          cClrBits = 8;
      else if (cClrBits <= 16)
          cClrBits = 16;
      else if (cClrBits <= 24)
          cClrBits = 24;
      else cClrBits = 32;
  
      // Allocate memory for the BITMAPINFO structure. (This structure
      // contains a BITMAPINFOHEADER structure and an array of RGBQUAD
      // data structures.)
 
      if (cClrBits != 24)
          pbmi = (PBITMAPINFO) LocalAlloc(LPTR,
                     sizeof(BITMAPINFOHEADER) +
                     sizeof(RGBQUAD) * (1<< cClrBits));
 
      // There is no RGBQUAD array for the 24-bit-per-pixel format.
 
      else
          pbmi = (PBITMAPINFO) LocalAlloc(LPTR,
                     sizeof(BITMAPINFOHEADER));
 
     // Initialize the fields in the BITMAPINFO structure.
 
     pbmi->bmiHeader.biSize = sizeof(BITMAPINFOHEADER);
     pbmi->bmiHeader.biWidth = bmp.bmWidth;
     pbmi->bmiHeader.biHeight = bmp.bmHeight;
     pbmi->bmiHeader.biPlanes = bmp.bmPlanes;
     pbmi->bmiHeader.biBitCount = bmp.bmBitsPixel;
     if (cClrBits < 24)
         pbmi->bmiHeader.biClrUsed = (1<<cClrBits);
 
     // If the bitmap is not compressed, set the BI_RGB flag.
     pbmi->bmiHeader.biCompression = BI_RGB;
 
     // Compute the number of bytes in the array of color
     // indices and store the result in biSizeImage.
     // For Windows NT/2000, the width must be DWORD aligned unless
     // the bitmap is RLE compressed. This example shows this.
     // For Windows 95/98, the width must be WORD aligned unless the
     // bitmap is RLE compressed.
     pbmi->bmiHeader.biSizeImage = ((pbmi->bmiHeader.biWidth * cClrBits +31) & ~31) /8
                                   * pbmi->bmiHeader.biHeight;
     // Set biClrImportant to 0, indicating that all of the
     // device colors are important.
      pbmi->bmiHeader.biClrImportant = 0;
      return pbmi;
  }
 
 void CreateBMPFile(HWND hwnd, LPTSTR pszFile, PBITMAPINFO pbi,
                   HBITMAP hBMP, HDC hDC)
  {
      HANDLE hf;                 // file handle
     BITMAPFILEHEADER hdr;       // bitmap file-header
     PBITMAPINFOHEADER pbih;     // bitmap info-header
     LPBYTE lpBits;              // memory pointer
     DWORD dwTotal;              // total count of bytes
     DWORD cb;                   // incremental count of bytes
     BYTE *hp;                   // byte pointer
     DWORD dwTmp;
 
     pbih = (PBITMAPINFOHEADER) pbi;
     lpBits = (LPBYTE) GlobalAlloc(GMEM_FIXED, pbih->biSizeImage);
 
     if (!lpBits)
          return ;
 
     // Retrieve the color table (RGBQUAD array) and the bits
     // (array of palette indices) from the DIB.
     if (!GetDIBits(hDC, hBMP, 0, (WORD) pbih->biHeight, lpBits, pbi,
         DIB_RGB_COLORS))
     {
         return ;
     }
 
     // Create the .BMP file.
     hf = CreateFile(pszFile,
                    GENERIC_READ | GENERIC_WRITE,
                    (DWORD) 0,
                     NULL,
                    CREATE_ALWAYS,
                    FILE_ATTRIBUTE_NORMAL,
                    (HANDLE) NULL);
     if (hf == INVALID_HANDLE_VALUE)
         return ;
     hdr.bfType = 0x4d42;        // 0x42 = "B" 0x4d = "M"
     // Compute the size of the entire file.
     hdr.bfSize = (DWORD) (sizeof(BITMAPFILEHEADER) +
                  pbih->biSize + pbih->biClrUsed
                  * sizeof(RGBQUAD) + pbih->biSizeImage);
     hdr.bfReserved1 = 0;
     hdr.bfReserved2 = 0;
 
     // Compute the offset to the array of color indices.
     hdr.bfOffBits = (DWORD) sizeof(BITMAPFILEHEADER) +
                     pbih->biSize + pbih->biClrUsed
                    * sizeof (RGBQUAD);
 
    // Copy the BITMAPFILEHEADER into the .BMP file.
    if (!WriteFile(hf, (LPVOID) &hdr, sizeof(BITMAPFILEHEADER),
        (LPDWORD) &dwTmp,  NULL))
     {
        return ;
     }
 
   // Copy the BITMAPINFOHEADER and RGBQUAD array into the file.
    if (!WriteFile(hf, (LPVOID) pbih, sizeof(BITMAPINFOHEADER)
                  + pbih->biClrUsed * sizeof (RGBQUAD),
                  (LPDWORD) &dwTmp, ( NULL)))
        return ;
 
     // Copy the array of color indices into the .BMP file.
     dwTotal = cb = pbih->biSizeImage;
     hp = lpBits;
     if (!WriteFile(hf, (LPSTR) hp, (int) cb, (LPDWORD) &dwTmp,NULL))
           return ;
 
     // Close the .BMP file.
      if (!CloseHandle(hf))
            return ;
GlobalFree((HGLOBAL)lpBits);
}

void CTextOnbmpDlg::OnButton1()
{
 // TODO: Add your control notification handler code here
    // TODO: Add your control notification handler code here   
HDC hDC = ::GetDC(GetSafeHwnd());
HDC hMemDC = CreateCompatibleDC(hDC);
//打开位图文件
HBITMAP hBmp = OpenBmpFile(hDC, "d:\\temp\\6370烧写\\6484884.bmp");
SelectObject(hMemDC, hBmp);
//在位图上写字
RECT rect = {50, 50, 200, 200};
SetBkMode(hMemDC, TRANSPARENT);
DrawText(hMemDC, "你好", -1, &rect, DT_VCENTER);
//保存位图到文件
PBITMAPINFO pBmpInfo = CreateBitmapInfoStruct(GetSafeHwnd(), hBmp);
CreateBMPFile(GetSafeHwnd(), "Test.bmp", pBmpInfo, hBmp, hDC);
DeleteDC(hMemDC);
DeleteObject(hBmp);

}

在bmp上添加字符的更多相关文章

  1. 在bmp上添加字符2

    void CTextOnbmpDlg::OnButton2() {  // TODO: Add your control notification handler code here  FILE *f ...

  2. linux shell 用sed命令在文本的行尾或行首添加字符

    转自 http://www.cnblogs.com/aaronwxb/archive/2011/08/19/2145364.html 昨天写一个脚本花了一天的2/3的时间,而且大部分时间都耗在了sed ...

  3. C#在图片上添加文字代码

    创建.NET WinForm程序,设置项目的默认命名空间为Keleyi.Com,在窗体上添加一个PictureBox控件pictureBox_keleyi_com和一个Button控件button_A ...

  4. 4.关于QT中的QFile文件操作,QBuffer,Label上添加QPixmap,QByteArray和QString之间的区别,QTextStream和QDataStream的区别,QT内存映射(

     新建项目13IO 13IO.pro HEADERS += \ MyWidget.h SOURCES += \ MyWidget.cpp QT += gui widgets network CON ...

  5. [Kernel]内核版本添加字符和内核版本'+'解决

    转自:http://blog.csdn.net/adaptiver/article/details/7225980 之前每次由于git仓库编译出来每次都带有'+', 导致都需要使用git archiv ...

  6. notepad++ 行首行尾添加字符

    有一次要处理SQL,拿到了脚本.但是要将其写入java 代码中,要在行首和行尾添加上引号.利用notepad++进行编辑. $表示行尾,^表示行首. 如上图,就这样.很高效. 如果只是在行尾添加字符, ...

  7. Linux sed命令操作 删除文件每一行的前k个字符、在文本的行尾或行首添加字符

    删除文件每一行的前k个字符 $ cat tmp.txt # 删除每行第一个字符 $ sed 's/.//' tmp.txt # 删除每行前两个字符 $ sed 's/..//' tmp.txt # 删 ...

  8. Linux shell sed命令在文件行首行尾添加字符

    昨天写一个脚本花了一天的2/3的时间,而且大部分时间都耗在了sed命令上,今天不总结一下都对不起昨天流逝的时间啊~~~ 用sed命令在行首或行尾添加字符的命令有以下几种: 假设处理的文本为test.f ...

  9. 如何在MyEclipse上添加更换JRE

    如何在myeclipse上添加更换JRE 由于兼容性的问题,有些WEB项目会依赖jdk的版本.如果需要更换jdk,那么,知道如何更换JRE的方法很有必要. 一种在myeclipse上添加和更换JRE的 ...

随机推荐

  1. ZOJ 3492 模拟循环链表线性查找

    WA了好几次最后找到错因是因为数组开小了! = = string whose length never exceeds 20 所以至少要开到21 = = ,我却一直开20 ╮(╯▽╰)╭ AC代码: ...

  2. gethostbyname()函数说明

    gethostbyname()函数说明——用域名或主机名获取IP地址 包含头文件    #include <netdb.h>    #include <sys/socket.h> ...

  3. Gradle的简介与安装

    Gradle介绍 Gradle是一个基于JVM的构建工具,它提供了: 像Ant一样,通用灵活的构建工具 可以切换的,基于约定的构建框架 强大的多工程构建支持 基于Apache Ivy的强大的依赖管理 ...

  4. 基于visual Studio2013解决算法导论之001插入排序

     题目 插入排序 解决代码及点评 #include <stdio.h> #include <time.h> #include <stdlib.h> void ...

  5. centos7安装codeblocks教程

    author:lidabo 装了好多次系统,每次装的时候都有要在网上各种查,太麻烦了.所以决定记录一下,以后用到的时候会方便一些.当然,本文来源于网络,取百家之长,最重要的是本人已验证过,说明对本系统 ...

  6. c++怎样让返回对象的函数不调用拷贝构造函数

    我们知道拷贝构造函数有两种“默默”的方式被调用 1. 想函数传入 值参数 2. 函数返回 值类型 今天我们讨论函数返回值类型的情况. 得到结论是 1. 当对象有拷贝构造函数(系统为我们生成.或者我们自 ...

  7. 3890: [Usaco2015 Jan]Meeting Time( dp )

    简单的拓扑图dp.. A(i, j), B(i, j) 表示从点 i 长度为 j 的两种路径是否存在. 用bitset就行了 时间复杂度O(m) --------------------------- ...

  8. 【HTTP】Fiddler(二) - 使用Fiddler做抓包分析

    上文( http://blog.csdn.net/ohmygirl/article/details/17846199 )中已经介绍了Fiddler的原理和软件界面.本文主要针对Fiddler的抓包处理 ...

  9. unix shell: ksh fundamental(Korn Shell)

    Korn Shell 参考:ksh 学习 http://bbs.chinaunix.net/thread-1749811-1-1.html 1.语法 特殊的文件 /etc/profile 在登录时首先 ...

  10. JAVA 操作 DBF 文件数据库

    1.依赖夹包 javadbf-[].4.1.jar jconn3.jar 2.添加属性文件 jdbc.properties jdbc.driverClassName=com.sybase.jdbc3. ...