当前位置: 首页 > news >正文

直接显示二进制图片

Option Explicit
Private Type GUID
Data1 As Long
Data2 As Integer
Data3 As Integer
Data4(7) As Byte
End Type
Private Declare Function CreateStreamOnHGlobal Lib “ole32.dll” (ByRef hGlobal As Any, ByVal fDeleteOnResume As Long, ByRef ppstr As Any) As Long
Private Declare Function OleLoadPicture Lib “olepro32.dll” (ByVal lpStream As IUnknown, ByVal lSize As Long, ByVal fRunMode As Long, ByRef riid As GUID, ByRef lplpObj As Any) As Long
Private Declare Function CLSIDFromString Lib “ole32.dll” (ByVal lpsz As Long, ByRef pclsid As GUID) As Long

’ HKEY_CLASSES_ROOT/Interface/{7BF80980-BF32-101A-8BBB-00AA00300CAB} = IPicture
Private Const SIPICTURE As String = “{7BF80980-BF32-101A-8BBB-00AA00300CAB}”
Private Mstream As Object '二进制转换对象
Private Const adTypeBinary = 1 '二进制模式
Dim B() As Byte

Private Sub Form_Load()
Set Mstream = CreateObject(“ADODB.Stream”)
With Mstream
.Open '打开"ADODB.Stream"对象
.Type = adTypeBinary '二进制模式
.LoadFromFile App.Path & “\1.jpg” '图片路径
End With
B = Mstream.Read '将转好的二进制图片赋予BYTE值
Mstream.Close '关闭Mstream对象
End Sub

’ 将字节数组转换为IPicture
Public Function PictureFromRes(ByRef B() As Byte) As IPicture
On Error GoTo Errorhandler
Dim istrm As IUnknown
Dim tGUID As GUID
If Not CreateStreamOnHGlobal(B(LBound(B)), False, istrm) Then
CLSIDFromString StrPtr(SIPICTURE), tGUID
OleLoadPicture istrm, UBound(B) - LBound(B) + 1, False, tGUID, PictureFromRes
End If
Set istrm = Nothing
Exit Function
Errorhandler:
MsgBox “无法转换为IPicture!”
End Function

Private Sub Command1_Click()
Set Me.Picture = PictureFromRes(B)
End Sub

http://www.lryc.cn/news/343166.html

相关文章:

  • 微软exchange邮箱发送
  • AI绘画Stable Diffusion SDXL 超赞!高质量万能大模型,写实人像、时尚设计、建筑设计、电影制作—筑梦工业XLV4.0
  • 数字人捕捉、建模与合成
  • Yarn:下一代JavaScript包管理器的安装与实战指南
  • JVM进程缓存 Caffeine
  • c++ 线程交叉场景试验
  • Cell:如何升华你的单细胞数据——PCF空间单细胞蛋白组联合scRNA-seq解析骨髓微环境
  • vue强制刷新组件
  • 分享5款对工作学习有帮助的效率软件
  • redis秒杀(PHP版本)
  • 图形用户界面(GUI)在AI去衣技术中的作用与重要性
  • 如何阅读:一个已被证实的低投入高回报的学习方法的笔记
  • pycharm 安装“通义灵码“并测试
  • React 之 useMemo Hook (九)
  • 短视频矩阵系统源码saas开发--可视化剪辑、矩阵托管、多功能合一开发
  • 百度大模型文心一言api 请求错误码 一览表
  • Unity调用智谱API(简单操作 文本实时翻译)
  • Android 开机启动扫描SD卡apk流程源码分析
  • 如何恢复回收站中被删除的文件?3个恢复策略,实测有用!
  • Unity---版本控制软件
  • 基于大模型的idea提炼:围绕论文和引用提炼idea之ResearchAgent
  • 前端深度扩展
  • 雷军-2022.8小米创业思考-6-互联网七字诀之专注:有所为,有所不为;克制贪婪,少就是多;一次解决一个最迫切的需求
  • 【禅道客户案例】北大软件携手禅道,开启产品化之路新征程
  • 解释泛型(Generics)在Java中的用途
  • 给网站网页PHP页面设置密码访问代码
  • 124.反转链表(力扣)
  • 【数据库原理及应用】期末复习汇总高校期末真题试卷06
  • Offline:IQL
  • 图像涂哪就动哪!Gen-2新功能“神笔马良”爆火,网友:急急急