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

时间:2008-10-10 16:22:34

标签: c++ sql sql-server image gdi+

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

2 个答案:

答案 0 :(得分:2)

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

但是有错误检查等(这里省略了更清楚的东西)

答案 1 :(得分:0)

首先将您的博客提取为字节数组,然后使用以下内容:

public static Image CreateImage(byte[] pict)
{
   System.Drawing.Image img = null;
   using (System.IO.MemoryStream stream = new System.IO.MemoryStream(pict)) {
    img = System.Drawing.Image.FromStream(stream);
   }
   return img;
}