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

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

概述我需要专门加载保存为blob的JPG图像. GDI使得从文件中检索图像变得非常容易,而不是从数据库中检索图像…… 看看 Image::Image(IStream *, BOOL).这需要一个指向实现IStream接口的COM对象的指针.您可以通过使用 GlobalAlloc分配一些全局内存然后在返回的句柄上调用 CreateStreamOnHGlobal来获取其中一个.它看起来像这样: share 我需要专门加载保存为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;}

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

总结

以上是内存溢出为你收集整理的如何使用GDI和C从SQL Server数据库加载和保存图像?全部内容,希望文章能够帮你解决如何使用GDI和C从SQL Server数据库加载和保存图像?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

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

原文地址:https://54852.com/langs/1229383.html

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

发表评论

登录后才能评论

评论列表(0条)

    保存