



免费预览已结束,剩余1页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
如何在VB中获得图像的像素值要处理一个图像,首先要获得该图像的像素值,而VB本身提供的PICTURE控件虽然可以打开很多类型的图片,但是它提供的那个POINT方法读取像素实在是太慢。而使用GetPixel这个API的速度也快不到哪里去,因为PIONT方法本身就是对于GetPixel的一个包装。 在VB中要快速获取一幅在PICTURE中打开的图像比较快速的方法是使用DIB方法,当然还有DDB方法,不过使用DDB方法还需要考虑不同颜色深度的图像的分别处理,在程序的实现上要相对复杂,而使用DIB方法则不必,并且在处理速度上比DDB方法也慢的有限。过程一:获得一个在PICTURE控件中打开的图像的所有像素。Public Sub DibGet(ByVal IdSource As Long, XBegin As Long, ByVal YBegin As Long, ByVal XEnd As Long, ByVal YEnd As Long)Dim iBitmap As LongDim iDC As LongDim I As LongDim Dim W As LongDim H As LongOn Error GoTo ErrLineDone = FalseTimeGet = timeGetTimeInPutWid = XEnd - XBeginInPutHei = YEnd - YBeginW = InPutWid + 1H = InPutHei + 1I = (Bits 8) - 1ReDim ColVal(I, InPutWid, InPutHei)With bi24BitInfo.bmiHeader .biBitCount = Bits .biCompression = 0& .biPlanes = 1 .biSize = Len(bi24BitInfo.bmiHeader) .biWidth = W .biHeight = HEnd WithiBitmap = GetCurrentObject(IdSource, 7&)GetDIBits IdSource, iBitmap, 0&, H, ColVal(0, 0, 0), bi24BitInfo, 0&DeleteObject iBitmapDone = TrueTimeGet = timeGetTime - TimeGetExit SubErrLine:MsgBox 错误号: & Err.Number & : & Err.DescriptionEnd Sub在这个过程中所用到的只是一些参数的设定和API的调用,不涉及算法。过程二:图像输出的过程:Public Sub DIBPut(ByVal IdDestination As Long)Dim W As LongDim H As LongOn Error GoTo ErrLineDone = FalseTimePut = timeGetTimeW = OutPutWid + 1H = OutPutHei + 1With bi24BitInfo.bmiHeader .biWidth = W .biHeight = H LineBytes = (W * Bits + 31) And &HFFFFFFE0) 8 .biSizeImage = LineBytes * HEnd WithSetDIBitsToDevice IdDestination, 0, 0, W, H, 0, 0, 0, H, ColOut(0, 0, 0), bi24BitInfo.bmiHeader, 0 Done = TrueTimePut = timeGetTime - TimePutExit SubErrLine:MsgBox Err.DescriptionEnd Sub下面解释一下在过程中到的全局变量和数据结构,以及API的定义。API定义:删除一个DCPrivate Declare Function DeleteDC Lib gdi32 (ByVal hdc As Long) As Long删除一个对象Private Declare Function DeleteObject Lib gdi32 (ByVal hObject As Long) As Long选择当前对象Private Declare Function GetCurrentObject Lib gdi32 (ByVal hdc As Long, ByVal uObjectType As Long) As Long获取DIBPrivate Declare Function GetDIBits Lib gdi32 (ByVal aHDC As Long, ByVal hBitmap As Long, ByVal nStartScan As Long, ByVal nNumScans As Long, lpBits As Any, lpBI As BitMapInfo, ByVal wUsage As Long) As Long获取系统时间Private Declare Function timeGetTime Lib winmm.dll () As Long数据结构定义:Private Type BitMapInfoHeader 文件信息头BITMAPINFOHEADER biSize As Long biWidth As Long biHeight As Long biPlanes As Integer biBitCount As Integer biCompression As Long biSizeImage As Long biXPelsPerMeter As Long biYPelsPerMeter As Long biClrUsed As Long biClrImportant As LongEnd TypePrivate Type RGBQuad rgbBlue As Byte rgbGreen As Byte rgbRed As Byte rgbReserved As ByteEnd TypePrivate Type BitMapInfo bmiHeader As BitMapInfoHeader bmiColors As RGBQuadEnd Type这三个数据结构都是在DIB中不可缺少的。我们不必深究,只是按照顺序复制粘贴直接使用就是了。过程中用到的全局变量:Private Const Bits As Long = 32 颜色深度,这里把所有图像都按照32位来处理Public Done As Boolean用于标记一个过程是否结束Public TimeGet As Long用于记录输入过程处理所花费的时间Public TimePut As Long用于记录输出过程处理所花费的时间Dim ColVal() As Byte 用于存放从DIB输入的像素值Dim ColOut() As Byte 用于存放向DIB输出的像素值Dim InPutHei As Long 用于记录输入图像的高度Dim InPutWid As Long 用于记录输入图像的宽度Dim bi24BitInfo As BitMapInfo 定义BMP信息可以看出,我在输入和输出中使用了两个不同的动态数组ColVal()和ColOut()这么做是有道理的,因为我们不只是为了输入和输出图像,中间还要对像素进行处理。包括图像缩放、色彩调整、锐化、柔化等等处理,使用两个不同的数组来分别存放数据更有利于程序的实现。有些性急的朋友说不定已经把程序贴到工程里试用了,可是会发现根本不能输出图像。这是因为当你用DIBGET获得的图像还在ColVal() 中呢,需要把它们放到ColOut()这个数组中去,DIBPUT这个过程才能起作用。这里再给出一个用于数组整体移动数据的过程:Public Sub CopyData(ByVal W As Long, ByVal H As Long)Dim Length As LongDim I As LongDim L As LongI = Bits 8L = I - 1Length = (W + 1&) * (H + 1&) * IReDim ColOut(L, W, H)CopyMemory ColOut(0, 0, 0), ColVal(0, 0, 0), LengthEnd subAPI定义:Private Declare Sub CopyMemory Lib kernel32 Alias RtlMoveMemory (pDest As Any, pSrc As Any, ByVal ByteLen As Long)这时,我们就可以来试一下效果了:把你的显示器调到32位色。将前面的所有API和变量定义全部贴到一个新建的模块里新建一个窗体,加两个PICTURE控件:pictrue1 ,picture2 一个按钮command1在pictrue1中加载一个图片在command1中写如下代码:sub command1_click()With picture1 .Scale
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- GB/T 46168-2025建筑和土木工程密封胶可操作时间的测定
- 2025江西赣州市宁都县选调县内教师190人考前自测高频考点模拟试题及1套完整答案详解
- 2025年长春急救中心公开招聘编外聘用制工作人员(10人)考前自测高频考点模拟试题附答案详解(完整版)
- 安全培训教师年度述职课件
- 2025福建三明市清流县金星园建设发展有限公司招聘消防驾驶员2人模拟试卷附答案详解(考试直接用)
- 广汽安全驾驶培训课程课件
- 2025江苏徐州东创新能源科技有限公司招聘19人模拟试卷及1套参考答案详解
- 安全培训教室的特殊名字课件
- 安全培训教室单人面积课件
- 安全培训教学配乐课件
- 幼儿园红色小故事PPT:抗日小英雄王二小的故事
- 如何理解欧盟MDR临床评价要求
- 监理业务手册(范本)
- 2022年国家公务员考试申论真题及答案解析(地市级)
- 名师成长的路径与修炼(教师版)课件
- 案外人执行异议之诉课件
- T-CSCS 015-2021 钢结构深化设计制图标准-(高清版)
- 西方经济学导论全套课件
- “基础教育精品课”PPT课件模板
- 第8部分消防设施标识可视化
- 简约医院医疗工作汇报工作总结PPT模板
评论
0/150
提交评论