小编典典

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

sql

我需要专门加载另存为斑点的JPG图像。GDI +使从文件而不是从数据库检索图像非常容易…


阅读 143

收藏
2021-04-07

共1个答案

小编典典

看一下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;
}

但是带有错误检查等功能(这里为了使事情更清楚而省略了)

2021-04-07