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

2023-11-25

我特别需要加载保存为 blob 的 JPG 图像。 GDI+ 使得从文件中检索图像变得非常容易,但不能从数据库中检索图像......


看一眼图像::图像(IStream *, BOOL)。这需要一个指向实现 IStream 接口的 COM 对象的指针。您可以通过分配一些全局内存来获得其中之一全局分配然后打电话在HGlobal上创建流在返回的句柄上。它看起来像这样:

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;
}

但带有错误检查等(此处省略以使事情更清楚)

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

如何使用 GDI+ 和 C++ 从 SQL Server 数据库加载和保存图像? 的相关文章

随机推荐