1.读取图片数据

函数原型:bool LoadImage(const char *pName, unsigned char *pBitData);

函数功能,读取pName指向的图片文件的位图数据

bool LoadImage(const char *pName, unsigned char *pBitData) 

    HDC     hdcTemp; // DC用来保存位图 
    HBITMAP     hbmpTemp; // 保存临时位图 
    IPicture    *pPicture; // 定义IPicture Interface 
    OLECHAR     wszPath[MAX_PATH+1]; // 图片的完全路径 
    char        szPath[MAX_PATH+1]; // 图片的完全路径 
    long        lWidth; // 图像宽度 
    long        lHeight; // 图像高度 
    long        lWidthPixels; // 图像的宽带(以像素为单位) 
    long        lHeightPixels; // 图像的高带(以像素为单位) 
    GLint       glMaxTexDim ; // 保存纹理的最大尺寸 
  
    if (strstr(pName, "http://"))   // 如果路径包含 http:// 则… 
    { 
        strcpy(szPath, pName);  // 把路径拷贝到 szPath 
    } 
    else    // 否则从文件导入图片 
    { 
        GetCurrentDirectory(MAX_PATH, szPath);  // 取得当前路径 
        strcat(szPath, "\\");           // 添加字符"\" 
        strcat(szPath, pName);          // 添加图片的相对路径 
    } 
  
    MultiByteToWideChar(CP_ACP, 0, szPath, -1, wszPath, MAX_PATH);  // 把ASCII码转化为Unicode标准码 
    HRESULT hr = OleLoadPicturePath(wszPath, 0, 0, 0, IID_IPicture, (void**)&pPicture); 
  
    if(FAILED(hr))  // 如果导入失败 
    { 
        // 图片载入失败出错信息 
        MessageBox (HWND_DESKTOP, "图片导入失败!\n(TextureLoad Failed!)", "Error", MB_OK | MB_ICONEXCLAMATION); 
        return FALSE;   // 返回 FALSE 
    } 
  
    hdcTemp = CreateCompatibleDC(GetDC(0)); // 建立窗口设备描述表 
    if(!hdcTemp)    // 建立失败? 
    { 
        pPicture->Release(); // 释放IPicture 
        // 图片载入失败出错信息 
        MessageBox (HWND_DESKTOP, "图片导入失败!\n(TextureLoad Failed!)", "Error", MB_OK | MB_ICONEXCLAMATION); 
        return FALSE;       // 返回 FALSE 
    } 
  
    glGetIntegerv(GL_MAX_TEXTURE_SIZE, &glMaxTexDim);   // 取得支持的纹理最大尺寸 
    pPicture->get_Width(&lWidth);    // 取得IPicture 宽度 (转换为Pixels格式) 
    lWidthPixels = MulDiv(lWidth, GetDeviceCaps(hdcTemp, LOGPIXELSX), 2540); 
    pPicture->get_Height(&lHeight);  // 取得IPicture 高度 (转换为Pixels格式) 
    lHeightPixels = MulDiv(lHeight, GetDeviceCaps(hdcTemp, LOGPIXELSY), 2540); 
  
    // 调整图片到最好的效果 
    if (lWidthPixels <= glMaxTexDim) // 图片宽度是否超过显卡最大支持尺寸 
        lWidthPixels = 1 << (int)floor((log((double)lWidthPixels)/log(2.0f)) + 0.5f); 
    else    // 否则,将图片宽度设为显卡最大支持尺寸 
        lWidthPixels = glMaxTexDim; 
    if (lHeightPixels <= glMaxTexDim)    // 图片高度是否超过显卡最大支持尺寸 
        lHeightPixels = 1 << (int)floor((log((double)lHeightPixels)/log(2.0f)) + 0.5f); 
    else    // 否则,将图片高度设为显卡最大支持尺寸 
        lHeightPixels = glMaxTexDim; // 建立一个临时位图 
    BITMAPINFO  bi = {0};     // 位图的类型 
    DWORD       *pBits = 0; // 指向位图Bits的指针 
  
    bi.bmiHeader.biSize = sizeof(BITMAPINFOHEADER); // 设置结构大小 
    bi.bmiHeader.biBitCount = 32;                // 32 位 
    bi.bmiHeader.biWidth    = lWidthPixels; // 宽度像素值 
    bi.bmiHeader.biHeight   = lHeightPixels;    // 高度像素值 
    bi.bmiHeader.biCompression  = BI_RGB;            // RGB 格式 
    bi.bmiHeader.biPlanes   = 1;                    // 一个位平面 
  
    // 建立一个位图这样我们可以指定颜色和深度 并访问每位的值 
    hbmpTemp = CreateDIBSection(hdcTemp, &bi, DIB_RGB_COLORS, (void**)&pBits, 0, 0); 
  
    if(!hbmpTemp)   // 建立失败? 
    { 
        DeleteDC(hdcTemp);   // 删除设备描述表 
        pPicture->Release();   // 释放IPicture 
        // 图片载入失败出错信息 
        MessageBox (HWND_DESKTOP, "图片导入失败!\n(TextureLoad Failed!)", "Error", MB_OK | MB_ICONEXCLAMATION); 
        return FALSE;   // 返回 FALSE 
    }   
    SelectObject(hdcTemp, hbmpTemp); //选择临时DC句柄和临时位图对象 
  
    // 在位图上绘制IPicture 
    pPicture->Render(hdcTemp, 0, 0, lWidthPixels, lHeightPixels, 0, lHeight, lWidth, -lHeight, 0); 
  
    // 将BGR转换为RGB 将ALPHA值设为255 
    width = lWidthPixels; height = lHeightPixels; 
    pBitData = new unsigned char[lWidthPixels * lHeightPixels * 4]; 
                // 循环遍历所有的像素 
    for(long i = 0; i < lWidthPixels * lHeightPixels; i++)   
    { 
        BYTE* pPixel      = (BYTE*)(&pBits[i]);  // 获取当前像素 
        pBitData[i*4]     = pPixel[2]; 
        pBitData[i*4+1] = pPixel[1]; 
        pBitData[i*4+2] = pPixel[0]; 
        pBitData[i*4+3] = 255; 
    } 
    DeleteObject(hbmpTemp); // 删除对象 
    DeleteDC(hdcTemp);  // 删除设备描述表 
    pPicture->Release(); // 释放 IPicture 
    return true;        // 返回 TRUE 

2.显示图片

函数原型:HRESULT ShowPicture(CString lpImageFile, HWND hWnd, int nScrWidth, int nScrHeight)

函数功能,读取lpImageFile指向的图片文件,并且显示以nScrWidth*nScrHeight显示在hWnd中

HRESULT ShowPicture(CString lpImageFile, HWND hWnd, int nScrWidth, int nScrHeight)

    HDC hDC_Temp=::GetDC(hWnd); 
    IPicture *pPic; 
    IStream *pStm; 
    BOOL bResult; 
    HANDLE hFile=NULL; 
    DWORD dwFileSize,dwByteRead; 
    //打开硬盘中的图形文件 
    hFile=CreateFile(lpImageFile,GENERIC_READ, 
        FILE_SHARE_READ,NULL,OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL,NULL); 
    if (hFile!=INVALID_HANDLE_VALUE) 
    { 
        dwFileSize=GetFileSize(hFile,NULL);//获取文件字节数 
        if (dwFileSize==0xFFFFFFFF) 
            return E_FAIL; 
    } 
    else 
    { 
        return E_FAIL; 
    } 
    //分配全局存储空间 
    HGLOBAL hGlobal = GlobalAlloc(GMEM_MOVEABLE, dwFileSize); 
    LPVOID pvData = NULL; 
    if (hGlobal == NULL) 
    { 
        AfxMessageBox(_T("图片分配内存出错!")); 
        return E_FAIL; 
    } 
    if ((pvData = GlobalLock(hGlobal)) == NULL)//锁定分配内存块 
    { 
        AfxMessageBox(_T("内存块锁定出问题!")); 
        return E_FAIL; 
    } 
    ReadFile(hFile, pvData, dwFileSize, &dwByteRead, NULL);//把文件读入内存缓冲区 
    GlobalUnlock(hGlobal); 
    if(CreateStreamOnHGlobal(hGlobal, TRUE, &pStm) != S_OK) 
    { 
        AfxMessageBox(_T("流初始化失败!")); 
        return E_FAIL; 
    } 
    //装入图形文件 
    bResult=OleLoadPicture(pStm,dwFileSize,TRUE,IID_IPicture,(LPVOID*)&pPic); 
    if(FAILED(bResult)) 
    { 
        AfxMessageBox(_T("图形文件装载出错!")); 
        return E_FAIL; 
    } 
    OLE_XSIZE_HIMETRIC hmWidth;//图片的真实宽度 
    OLE_YSIZE_HIMETRIC hmHeight;//图片的真实高度 
    pPic->get_Width(&hmWidth); 
    pPic->get_Height(&hmHeight); 
    //将图形输出到屏幕上 
    bResult=pPic->Render(hDC_Temp,0,0,nScrWidth,nScrHeight, 
        0,hmHeight,hmWidth,-hmHeight,NULL); 
    CloseHandle(hFile);//关闭打开的文件 
  
    pPic->Release(); 
    // Free memory. 
    GlobalFree(hGlobal); 
    if (SUCCEEDED(bResult)) 
    { 
        return S_OK; 
    } 
    else 
    { 
        AfxMessageBox(_T("图形文件装载出错!")); 
        return E_FAIL; 
    } 
}

利用COM组件IPicture读取jpg、gif、bmp图片文件数据和显示图片的更多相关文章

  1. 基于SqlSugar的开发框架循序渐进介绍(10)-- 利用axios组件的封装,实现对后端API数据的访问和基类的统一封装处理

    在SqlSugar的开发框架的后端,我们基于Web API的封装了统一的返回结果,使得WebAPI的接口返回值更加简洁,而在前端,我们也需要统一对返回的结果进行解析,并获取和Web API接口对应的数 ...

  2. java读取目录下所有csv文件数据,存入三维数组并返回

    package dwzx.com.get; import java.io.BufferedReader; import java.io.File; import java.io.FileReader; ...

  3. Python中通过Image的open之后,去show结果打不开bmp图片,无法正常显示图片

    在windows的cmd命令行下,使用Python的PIL库打开并显示一个jpg图片: ? 1 2 3 openedImg = Image.open(saveToFile); print " ...

  4. ci框架读取上传的excel文件数据

    原文链接: https://blog.csdn.net/qq_38148394/article/details/87921373 此功能实现使用到PHPExcel类库,PHPExcel是一个PHP类库 ...

  5. 读取raw目录中的文件数据

    try { InputStream is2 = getResources().openRawResource(R.raw.info); InputStreamReader isr2 = new Inp ...

  6. 从数据库读取二进制图片,img标签显示图片

    引自 http://www.w3dev.cn/article/20110214/asp-net-csharp-image-base64-change.aspx      <img src=&qu ...

  7. 读取FTP 图片文件,并显示,非下载

    关于FTP,先从怎么创建开始说起,很简单,步骤就两个 ① 电脑-右键管理--本地用户组--添加用户名,密码(用于FTP的用户名.密码) ② IIS 新建FTP站点,命名,指定端口号.FTP文件路径 接 ...

  8. c# 用OpenXmL读取.xlsx格式的Excel文件 返回DataTable

    1.须要引用的dll :  DocumentFormat.OpenXml.dll  ---须要安装一下OpenXml再引用 WindowsBase  ---直接在项目里加入引用 2.方法: /// & ...

  9. 利用matplot简单显示图片

    import matplotlib.pyplot as plt from matplotlib.image import imread img = imread('F:\\ml\\DL\\source ...

随机推荐

  1. WPF笔记(2.2 DockPanel)——Layout

    原文:WPF笔记(2.2 DockPanel)--Layout 读完了这一节,发现DockPanel就是过去winform中的Dock属性.原来的Dock属性是子控件设置,而其父亲级别不用设置.现在W ...

  2. C# 操作IE浏览器

    最近的一个B/S系统中,用到了指模录入,当用户按了手指摸之后,要在IE浏览器的一个文本框上显示用户的姓名.由于要监控指模机的输入,因此客户端需要装一个.net控制台程序,通过此控制台程序监控指模机.这 ...

  3. grok 正则也支持常规正则

    2016-08-29 17:40:01,19 INFO com.zjzc.common.utils.HttpUtil - 请求接口: https://www.zjcap.cn/pay/interfac ...

  4. Linux进程笔记

    进程及作业管理 Uninterruptible sleep: 不可中断的睡眠Interruptible sleep:可中断睡眠 kernel:init: COW: Copy On Write, 写时复 ...

  5. TI芯片android环境搭建和编译

    1>. Reading package lists... Done Building dependency tree        Reading state information... Do ...

  6. poj 3370 Halloween treats(鸽巢原理)

    Description Every year there is the same problem at Halloween: Each neighbour is only willing to giv ...

  7. pthread_t definition

    近期在看google的chromium的代码,认为其基础库base中的对于与平台有关的线程的数据结构的定义与其代码中的凝视部分不匹配. // PlatformThreadHandle should n ...

  8. 用Unity做的一个小游戏,仿照一个样例写的,个人认为文章写的不错,哈哈

  9. What should we do when meet a crash in android?

    制造一个crash   为了演示的目的,我在libsensors的open_sensors_device中故意制造了一个crash:   static int open_sensors_device( ...

  10. httpwatch 9.3怎么在ie 8上看不到

    首先,确认HttpWatch Basic加载项是否启动:打开IE,单击工具图标并选择管理加载项.确认HttpWatch Basic的状态是已启用,点击关闭.之后打开某个网页,在页面空白处右击选择Htt ...