开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 11557|回复: 20
收起左侧

[易语言] VB源码转易语言源码

[复制链接]
结帖率:0% (0/1)
发表于 2012-12-6 09:12:07 | 显示全部楼层 |阅读模式   山东省青岛市
10精币
请各位高手帮忙把附件中的VB源码转换成易语言源码,谢谢了

自动色阶.zip

329.25 KB, 下载次数: 70

仿pS自动色阶


回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值

结帖率:94% (46/49)

签到天数: 1 天

发表于 2012-12-6 11:17:56 | 显示全部楼层   重庆市重庆市
介个。。。。等别人。帮你顶下
回复

使用道具 举报

结帖率:76% (13/17)
发表于 2012-12-6 12:06:43 | 显示全部楼层   陕西省西安市
把源码直接复制出来吧、懒得下载了
回复

使用道具 举报

结帖率:0% (0/4)
发表于 2012-12-7 21:51:33 | 显示全部楼层   安徽省蚌埠市
把源码直接复制出来吧、懒得下载了,对VB不太了解
回复

使用道具 举报

结帖率:0% (0/1)
 楼主| 发表于 2012-12-12 07:47:45 | 显示全部楼层   山东省青岛市
顶一下,别沉下去
回复

使用道具 举报

结帖率:0% (0/1)
 楼主| 发表于 2012-12-19 22:57:01 | 显示全部楼层   山东省青岛市
模块源码:
Option Explicit



Public Type BITMAPFILEHEADER
    bfType      As Integer
    bfSize      As Long
    bfReserved1 As Integer
    bfReserved2 As Integer
    bfOffBits  As Long
End Type

Public Type Bitmap
  bmType As Long
  bmWidth As Long
  bmHeight As Long
  bmWidthBytes As Long
  bmPlanes As Integer
  bmBitsPixel As Integer
  bmBits As Long
End Type

Public Type BITMAPINFOHEADER       '40 bytes
   biSize As Long                   'BITMAPINFOHEADER结构的大小
   biWidth As Long
   biHeight As Long
   biPlanes As Integer              '设备的为平面数,现在都是1
   biBitCount As Integer            '图像的颜色位图
   biCompression As Long            '压缩方式
   biSizeImage As Long              '实际的位图数据所占字节
   biXPelsPerMeter As Long          '目标设备的水平分辨率
   biYPelsPerMeter As Long          '目标设备的垂直分辨率
   biClrUsed As Long                '使用的颜色数
   biClrImportant As Long           '重要的颜色数。如果该项为0,表示所有颜色都是重要的
End Type
  
Public Type RGBQUAD                '只有bibitcount为1,2,4时才有调色板
   Blue As Byte                     '蓝色分量
   Green As Byte                    '绿色分量
   Red As Byte                      '红色分量
   Reserved As Byte                 '保留值
End Type

Public Type BITMAPINFO
  bmiHeader As BITMAPINFOHEADER
  bmiColors As RGBQUAD
End Type



Public Const BI_RGB = 0&
Public Const DIB_RGB_COLORS = 0&
Public Const IMAGE_BITMAP = 0&

Public 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
Public Declare Function GetGDIObject Lib "gdi32.dll" Alias "GetObjectA" (ByVal hObject As Long, ByVal nCount As Long, ByRef lpObject As Any) As Long
Public Declare Function SetDIBits Lib "gdi32" (ByVal Hdc 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
Public Declare Function GetTickCount Lib "kernel32" () As Long
Public Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" (lpDst As Any, lpSrc As Any, ByVal ByteLength As Long)
Public Declare Function VarPtrArray Lib "msvbvm60.dll" Alias "VarPtr" (ByRef Ptr() As Any) As Long



'得到图像数据
Public Function GetPicData(Pic As PictureBox, PicData() As RGBQUAD) As Boolean               '读取位图数据
   
    Dim Bmp As Bitmap, BmpInfo As BITMAPINFO

    GetGDIObject Pic.Picture.Handle, Len(Bmp), Bmp         '取得对指定对象进行说明的一个结构,
                                                        'hobject为位图,刷子等的句柄,
                                                        'count欲取回的字节数。通常是由lpObject定义的那个结构的长度
   
    With BmpInfo.bmiHeader
        .biSize = Len(BmpInfo.bmiHeader)
        .biWidth = Bmp.bmWidth
        .biHeight = -Bmp.bmHeight                       'BMP位图默认的扫描方式是从下到上,
                                                        '这与GDI的坐标系统相反,为方便,这里
                                                        '改为-值,则取得数据就是以左上角为起点
        .biPlanes = 1
        .biBitCount = 32                                '32位位图,默认情况下Windows不会处理最高8位
                                                        '可以将它作为自己的Alpha通道,取为32位位图,
                                                        '虽然多占用了点内存,但是避免了扫描行宽度问题,代码易于理解
        .biCompression = BI_RGB                         '无压缩
        .biSizeImage = Bmp.bmWidth * Bmp.bmHeight * 4
    End With
   
    ReDim PicData(0 To Bmp.bmWidth - 1, 0 To Bmp.bmHeight - 1) As RGBQUAD
   
    GetDIBits Pic.Hdc, Pic.Image, 0, Bmp.bmHeight, PicData(0, 0), BmpInfo, DIB_RGB_COLORS

End Function


'根据数组显示图像
Public Sub SetPicData(Pic As PictureBox, PicData() As RGBQUAD)          '显示位图
   
    Dim Bmp As Bitmap, BmpInfo As BITMAPINFO

    GetGDIObject Pic.Picture.Handle, Len(Bmp), Bmp           '取得对指定对象进行说明的一个结构,hobject为位图,刷子等的句柄,count欲取回的字节数。通常是由lpObject定义的那个结构的长度
   
     
    With BmpInfo.bmiHeader
        .biSize = Len(BmpInfo.bmiHeader)
        .biWidth = Bmp.bmWidth
        .biHeight = -Bmp.bmHeight                       'BMP位图默认的扫描方式是从下到上,
                                                        '这与GDI的坐标系统相反,为方便,这里
                                                        '改为-值,则取得数据就是以左上角为起点
        .biPlanes = 1
        .biBitCount = 32                                '32位位图,默认情况下Windows不会处理最高8位
                                                        '可以将它作为自己的Alpha通道,取为32位位图,
                                                        '虽然多占用了点内存,但是避免了扫描行宽度问题,代码易于理解
        .biCompression = BI_RGB                         '无压缩
        .biSizeImage = Bmp.bmWidth * Bmp.bmHeight * 4
    End With
   
   
    SetDIBits Pic.Hdc, Pic.Image, 0, Bmp.bmHeight, PicData(0, 0), BmpInfo, DIB_RGB_COLORS
  
    Pic.Refresh
End Sub
回复

使用道具 举报

结帖率:0% (0/1)
 楼主| 发表于 2012-12-20 08:04:47 | 显示全部楼层   山东省青岛市
顶起来,别沉下去
回复

使用道具 举报

发表于 2012-12-25 16:00:21 | 显示全部楼层   广东省广州市
{:soso__14347937040236606360_1:}能多出点吗 等下班我看看
回复

使用道具 举报

发表于 2012-12-26 22:37:24 | 显示全部楼层   河北省保定市
http://www.3600gz.cn/thread-13622178-1-1.html    我写的VB转E语言的工具  开源的  看看去吧
回复

使用道具 举报

结帖率:0% (0/1)
 楼主| 发表于 2013-1-2 09:24:16 | 显示全部楼层   山东省青岛市
顶一下,请高手帮帮我吧
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

关闭

精易论坛 - 有你更精彩上一条 /2 下一条

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报QQ: 793400750,邮箱:wp@125.la
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备2025452707号) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表