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

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

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

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

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



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5662375.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存