1. Option Explicit
  2.  
  3. Private Const UnitPixel As Long =
  4. Private Const EncoderQuality As String = "{1D5BE4B5-FA4A-452D-9CDD-5DB35105E7EB}"
  5.  
  6. Private Type GdiplusStartupInput
  7. GdiplusVersion As Long
  8. DebugEventCallback As Long
  9. SuppressBackgroundThread As Long
  10. SuppressExternalCodecs As Long
  11. End Type
  12.  
  13. Private Enum EncoderParameterValueType
  14. EncoderParameterValueTypeByte =
  15. EncoderParameterValueTypeASCII =
  16. EncoderParameterValueTypeShort =
  17. EncoderParameterValueTypeLong =
  18. EncoderParameterValueTypeRational =
  19. EncoderParameterValueTypeLongRange =
  20. EncoderParameterValueTypeUndefined =
  21. EncoderParameterValueTypeRationalRange =
  22. End Enum
  23.  
  24. Private Type EncoderParameter
  25. GUID( To ) As Long
  26. NumberOfValues As Long
  27. Type As EncoderParameterValueType
  28. Value As Long
  29. End Type
  30.  
  31. Private Type EncoderParameters
  32. Count As Long
  33. Parameter As EncoderParameter
  34. End Type
  35.  
  36. Private Type ImageCodecInfo
  37. ClassID( To ) As Long
  38. FormatID( To ) As Long
  39. CodecName As Long
  40. DllName As Long
  41. FormatDescription As Long
  42. FilenameExtension As Long
  43. MimeType As Long
  44. Flags As Long
  45. Version As Long
  46. SigCount As Long
  47. SigSize As Long
  48. SigPattern As Long
  49. SigMask As Long
  50. End Type
  51.  
  52. Private Declare Function GdiplusStartup Lib "gdiplus" (Token As Long, inputbuf As GdiplusStartupInput, Optional ByVal outputbuf As Long = ) As Long
  53. Private Declare Sub GdiplusShutdown Lib "gdiplus" (ByVal Token As Long)
  54. Private Declare Function GdipSaveImageToFile Lib "gdiplus" (ByVal hImage As Long, ByVal sFilename As Long, clsidEncoder As Any, encoderParams As Any) As Long
  55. Private Declare Function GdipDisposeImage Lib "gdiplus" (ByVal Image As Long) As Long
  56. Private Declare Function GdipCreateBitmapFromHBITMAP Lib "gdiplus" (ByVal hbm As Long, ByVal hPal As Long, Bitmap As Long) As Long
  57. Private Declare Function GdipGetImageEncodersSize Lib "gdiplus" (numEncoders As Long, Size As Long) As Long
  58. Private Declare Function GdipGetImageEncoders Lib "gdiplus" (ByVal numEncoders As Long, ByVal Size As Long, Encoders As Any) As Long
  59.  
  60. Private Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" (Destination As Any, Source As Any, ByVal Length As Long)
  61. Private Declare Function lstrlenW Lib "kernel32" (ByVal psString As Any) As Long
  62. Private Declare Function CLSIDFromString Lib "ole32" (ByVal lpszProgID As Long, pCLSID As Any) As Long
  63. Private Declare Function GdipBitmapSetResolution Lib "gdiplus" (ByVal Bitmap As Long, ByVal xdpi As Single, ByVal ydpi As Single) As Long
  64.  
  65. Public Enum ImageFileFormat
  66. Bmp =
  67. Jpg =
  68. Png =
  69. Gif =
  70. End Enum
  71.  
  72. Public Function SaveStdPicToFile(Stdpic As StdPicture, ByVal FileName As String, _
  73. Optional ByVal FileFormat As ImageFileFormat = Jpg, _
  74. Optional ByVal JpgQuality As Long = , _
  75. Optional Resolution As Single) As Boolean
  76.  
  77. Dim CLSID() As Long
  78. Dim Bitmap As Long
  79. Dim Token As Long
  80. Dim Gsp As GdiplusStartupInput
  81.  
  82. Gsp.GdiplusVersion = 'GDI+ 1.0版本
  83. GdiplusStartup Token, Gsp '初始化GDI+
  84. GdipCreateBitmapFromHBITMAP Stdpic.Handle, Stdpic.hPal, Bitmap
  85. If Bitmap <> Then '说明我们成功的将StdPic对象转换为GDI+的Bitmap对象了
  86. GdipBitmapSetResolution Bitmap, Resolution, Resolution
  87. Select Case FileFormat
  88. Case ImageFileFormat.Bmp
  89. If Not GetEncoderClsID("Image/bmp", CLSID) = - Then
  90. SaveStdPicToFile = (GdipSaveImageToFile(Bitmap, StrPtr(FileName), CLSID(), ByVal ) = )
  91. End If
  92. Case ImageFileFormat.Jpg 'JPG格式可以设置保存的质量
  93. Dim aEncParams() As Byte
  94. Dim uEncParams As EncoderParameters
  95. If GetEncoderClsID("Image/jpeg", CLSID) <> - Then
  96. uEncParams.Count = ' 设置自定义的编码参数,这里为1个参数
  97. If JpgQuality < Then
  98. JpgQuality =
  99. ElseIf JpgQuality > Then
  100. JpgQuality =
  101. End If
  102. ReDim aEncParams( To Len(uEncParams))
  103. With uEncParams.Parameter
  104. .NumberOfValues =
  105. .Type = EncoderParameterValueTypeLong ' 设置参数值的数据类型为长整型
  106. Call CLSIDFromString(StrPtr(EncoderQuality), .GUID()) ' 设置参数唯一标志的GUID,这里为编码品质
  107. .Value = VarPtr(JpgQuality) ' 设置参数的值:品质等级,最高为100,图像文件大小与品质成正比
  108. End With
  109. CopyMemory aEncParams(), uEncParams, Len(uEncParams)
  110. SaveStdPicToFile = (GdipSaveImageToFile(Bitmap, StrPtr(FileName), CLSID(), aEncParams()) = )
  111. End If
  112. Case ImageFileFormat.Png
  113. If Not GetEncoderClsID("Image/png", CLSID) = - Then
  114. SaveStdPicToFile = (GdipSaveImageToFile(Bitmap, StrPtr(FileName), CLSID(), ByVal ) = )
  115. End If
  116. Case ImageFileFormat.Gif
  117. If Not GetEncoderClsID("Image/gif", CLSID) = - Then '如果原始的图像是24位,则这个函数会调用系统的调色板来将图像转换为8位,转换的效果会不尽人意,但也有可能系统不自动转换,保存失败
  118. SaveStdPicToFile = (GdipSaveImageToFile(Bitmap, StrPtr(FileName), CLSID(), ByVal ) = )
  119. End If
  120. End Select
  121. End If
  122. GdipDisposeImage Bitmap '注意释放资源
  123. GdiplusShutdown Token '关闭GDI+。
  124. End Function
  125.  
  126. Private Function GetEncoderClsID(strMimeType As String, ClassID() As Long) As Long
  127. Dim Num As Long
  128. Dim Size As Long
  129. Dim I As Long
  130. Dim Info() As ImageCodecInfo
  131. Dim Buffer() As Byte
  132. GetEncoderClsID = -
  133. GdipGetImageEncodersSize Num, Size '得到解码器数组的大小
  134. If Size <> Then
  135. ReDim Info( To Num) As ImageCodecInfo '给数组动态分配内存
  136. ReDim Buffer( To Size) As Byte
  137. GdipGetImageEncoders Num, Size, Buffer() '得到数组和字符数据
  138. CopyMemory Info(), Buffer(), (Len(Info()) * Num) '复制类头
  139. For I = To Num '循环检测所有解码
  140. If (StrComp(PtrToStrW(Info(I).MimeType), strMimeType, vbTextCompare) = ) Then '必须把指针转换成可用的字符
  141. CopyMemory ClassID(), Info(I).ClassID(), '保存类的ID
  142. GetEncoderClsID = I '返回成功的索引值
  143. Exit For
  144. End If
  145. Next
  146. End If
  147. End Function
  148.  
  149. Private Function PtrToStrW(ByVal lpsz As Long) As String
  150. Dim Out As String
  151. Dim Length As Long
  152. Length = lstrlenW(lpsz)
  153. If Length > Then
  154. Out = StrConv(String$(Length, vbNullChar), vbUnicode)
  155. CopyMemory ByVal Out, ByVal lpsz, Length *
  156. PtrToStrW = StrConv(Out, vbFromUnicode)
  157. End If
  158. End Function

GDI+_SavePic的更多相关文章

  1. 超全面的.NET GDI+图形图像编程教程

    本篇主题内容是.NET GDI+图形图像编程系列的教程,不要被这个滚动条吓到,为了查找方便,我没有分开写,上面加了目录了,而且很多都是源码和图片~ (*^_^*) 本人也为了学习深刻,另一方面也是为了 ...

  2. (转载)GDI+双缓冲

    双缓冲在GDI+里可以有效的提高描画效率.改善显示的质量. 下面的代码是一个最简单的双缓冲的模板.可以根据需要,做简单的修改即可. Bitmap CacheImage( [Width], [Heigh ...

  3. (转载)解决GDI闪烁

    一般的windows 复杂的界面需要使用多层窗口而且要用贴图来美化,所以不可避免在窗口移动或者改变大小的时候出现闪烁. 先来谈谈闪烁产生的原因 原因一:如果熟悉显卡原理的话,调用GDI函数向屏幕输出的 ...

  4. 通过GDI+绘制 验证码

    只为了记录下自己的学习历程,方便日后查看 现在开始言归正传,以下为其完整代码附上 using System; using System.Collections.Generic; using Syste ...

  5. 【VC++技术杂谈007】使用GDI+进行图片格式转换

    本文主要介绍如何使用GDI+对图片进行格式转换,可以转换的图片格式为bmp.jpg.png. 1.加载GDI+库 GDI+是GDI图形库的一个增强版本,提供了一系列Visual C++ API.为了使 ...

  6. C# GDI绘制矩形框,鼠标左键拖动可移动矩形框,滚轮放大缩小矩形框

    最近工作需要,要做一个矩形框,并且 用鼠标左键拖动矩形框移动其位置.网上查了一些感觉他们做的挺复杂的.我自己研究一天,做了一个比较简单的,发表出来供大家参考一下.如觉得简单,可路过,谢谢.哈哈. 先大 ...

  7. 【Windows编程】系列第五篇:GDI图形绘制

    上两篇我们学习了文本字符输出以及Unicode编写程序,知道如何用常见Win32输出文本字符串,这一篇我们来学习Windows编程中另一个非常重要的部分GDI图形绘图.Windows的GDI函数包含数 ...

  8. GDI+ 笔记

    1.GDI+模板 #include<windows.h> #include<GdiPlus.h> #include <time.h> #include <ma ...

  9. C# GDI+发生一般性错误(A generic error occurred in GDI+))

    解决思路: 1. 因为 .net GDI+ 是对底层 的封装. 所以可以尝试用 Marshal.GetLastWin32Error();函数获得底层错误代码. try{ image.Save(file ...

随机推荐

  1. 自动化测试-19.selenium定位之通过JS修改html写入日期数据以及从文本读取数据实战

    # -*- coding: utf-8 -*- from selenium import webdriver from selenium.webdriver.support.select import ...

  2. Day 2: ASP.NET and python trying

    ASP.NET and Python/Javascript Many jQuery plugins that are designed and shared for free on the inter ...

  3. jquery绑定回车事件

    //回车事件绑定 $(".left-content").keyup(function(event){ var theEvent = event || window.event; v ...

  4. Hello2 分析

    一.打开GreetingServlet.java文件以查看它 hello2应用程序是一个web模块,hello2应用程序的行为几乎与hello1应用程序相同,但是它是使用Java Servlet技术实 ...

  5. ios-上传图片到后台

    做第一个项目时,有个版块的个人信息的编辑涉及到头像修改,老大说项目里有通用的代码,让我自己去找.总算找到,搞了许久才弄好,看来理解能力还需要提高啊!! #pragma mark- 修改头像上传后保存 ...

  6. POI导出Execl文件,使JAVA虚拟机OOM

    由于在项目中使用POI导出execl,导致JAVA虚拟机OOM,采用以下方式解决问题: 原先方式: g_wb = new XSSFWorkbook(sourceFile.getInputStream( ...

  7. 18.3 #define DM9000_DBG(fmt,args...) printf(fmt, ##args)代表什么

    标准C支持可变参数的函数,意味着函数的参数是不固定的,例如printf()函数的原型为:int printf( const char *format [, argument]... ) 而在GNU C ...

  8. 百度网盘提交提取密码:根据cookies获取loginId 的js

    java下载百度网盘中资料,发现网上都只有关于公开分享的实现,没有关于私有分享的实现,抓包发现有一个关键参数:logid url:https://pan.baidu.com/share/verify? ...

  9. redux & react-redux

    在vue中,可以使用vuex进行数据管理,在react中,可以使用redux进行数据管理.redux主要由Store.Reducer和Action组成: Store:状态载体,访问状态.提交状态.监听 ...

  10. vm虚拟机 模板机进行克隆导致centos 7.2 无法加载网卡

    问题描述:vm虚拟机 模板机进行克隆导致centos 7.2 无法加载网卡. 1.ifconfig 查看网卡状态 lo: flags=<UP,LOOPBACK,RUNNING> mtu i ...