加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

如何使用GDI和C从SQL Server数据库加载和保存图像?

发布时间:2020-12-16 07:24:40 所属栏目:百科 来源:网络整理
导读:我需要专门加载保存为blob的JPG图像. GDI使得从文件中检索图像变得非常容易,而不是从数据库中检索图像…… 解决方法 看看 Image::Image(IStream *,BOOL).这需要一个指向实现IStream接口的COM对象的指针.您可以通过使用 GlobalAlloc分配一些全局内存然后在返
我需要专门加载保存为blob的JPG图像. GDI使得从文件中检索图像变得非常容易,而不是从数据库中检索图像……

解决方法

看看 Image::Image(IStream *,BOOL).这需要一个指向实现IStream接口的COM对象的指针.您可以通过使用 GlobalAlloc分配一些全局内存然后在返回的句柄上调用 CreateStreamOnHGlobal来获取其中一个.它看起来像这样:

shared_ptr<Image> CreateImage(BYTE *blob,size_t blobSize)
{
    HGLOBAL hMem = ::GlobalAlloc(GMEM_MOVEABLE,blobSize);
    BYTE *pImage = (BYTE*)::GlobalLock(hMem);

    for (size_t iBlob = 0; iBlob < blobSize; ++iBlob)
        pImage[iBlob] = blob[iBlob];

    ::GlobalUnlock(hMem);

    CComPtr<IStream> spStream;
    HRESULT hr = ::CreateStreamOnHGlobal(hMem,TRUE,&spStream);

    shared_ptr<Image> image = new Image(spStream);  
    return image;
}

但是有错误检查等(这里省略了让事情更清楚)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读