登录社区:用户名: 密码: 忘记密码 网页功能:加入收藏 设为首页 网站搜索  

文档

下载

图书

论坛

安全

源码

硬件

游戏
首页 | 信息 | 空间 | VB | VC | Delphi | Java | Flash | 补丁 | 控件 | 安全 | 黑客 | 电子书 | 笔记本 | 手机 | MP3 | 杀毒 | QQ群 | 产品库 | 分类信息 | 编程网站
  立华软件园 - Visual Basic 专区 - 技术文档 - 窗体界面 技术文章 | VB源代码 | 电子图书 | VB网站 | 相关下载 | 在线论坛 | QQ群组 | 搜索   
 VB技术文档
  · 窗体界面
  · 系统控制
  · VB.Net
  · 多媒体
  · 网络编程
  · API函数
  · 游戏编程
  · 数据报表
  · 其他文档
 VB源代码
  · 窗体界面
  · 文件目录
  · 多媒体
  · 网络编程
  · 系统API
  · 数据报表
  · 游戏编程
  · VBA办公
  · 其他代码
 VB论坛
  · Visual Basic 讨论区
  · VB.Net 讨论区
  · VB数据库开发讨论区
  · VB系统API讨论区
 其他VB资源
  · VB下载资源
  · VB电子图书
  · VB QQ群组讨论区
  · VB 其他网站资源




彩色BMP档转成灰度
发表日期:2002-12-08作者:[] 出处:  

将RGB想成3D之X,Y,Z轴,则BMP的RGB为(r,g,b)与座标(Y,Y,Y)距离最小时的Y即为灰度值

Y = 0.29900 * R + 0.58700 * G + 0.11400 * B

  整数化

Y = ( 9798*R + 19235*G + 3735*B) / 32768

RGB(Y, Y, Y)就可以了

需一个内有彩色图的PictureBox, CommandBox

Option Explicit

Private Declare Function GetPixel Lib "gdi32" _

   (ByVal hdc As Long, ByVal x As Long, ByVal Y As Long) As Long

Private Declare Function SetPixelV Lib "gdi32" _

   (ByVal hdc As Long, ByVal x As Long, _

   ByVal Y As Long, ByVal crColor As Long) As Long

Private tmpPic As Picture

Private Sub Form_Load()

Picture1.ScaleMode = 3 '设为Pixel

Picture1.AutoRedraw = True '设定所有Pixel的改变不立即在pictureBox上显示

Set tmpPic = Picture1.Picture

End Sub

Private Sub Command1_click()

Dim width5 As Long, heigh5 As Long, rgb5 As Long

Dim hdc5 As Long, i As Long, j As Long

Dim bBlue As Long, bRed As Long, bGreen As Long

Dim Y As Long

width5 = Picture1.ScaleWidth

heigh5 = Picture1.ScaleHeight

hdc5 = Picture1.hdc

For i = 1 To width5

  For j = 1 To heigh5

    rgb5 = GetPixel(hdc5, i, j)

    bBlue = Blue(rgb5)

    bRed = Red(rgb5)

    bGreen = Green(rgb5)

    Y = (9798 * bRed + 19235 * bGreen + 3735 * bBlue) \ 32768

    rgb5 = RGB(Y, Y, Y)

    SetPixelV hdc5, i, j, rgb5

  Next j

Next i

Set Picture1.Picture = Picture1.Image '此时才真正显示Picture

End Sub

Private Function Red(ByVal mlColor As Long) As Long

Red = mlColor And &HFF

End Function

Private Function Green(ByVal mlColor As Long) As Long

Green = (mlColor \ &H100) And &HFF

End Function

Private Function Blue(ByVal mlColor As Long) As Long

Blue = (mlColor \ &H10000) And &HFF

End Function

我来说两句】 【发送给朋友】 【加入收藏】 【返加顶部】 【打印本页】 【关闭窗口
中搜索 彩色BMP档转成灰度

 ■ [欢迎对本文发表评论]
用  户:  匿名发出:
您要为您所发的言论的后果负责,故请各位遵纪守法并注意语言文明。

关于我们 / 合作推广 / 给我留言 / 版权举报 / 意见建议 / 广告投放 / 友情链接  
Copyright ©2001-2006 Lihuasoft.net webmaster(at)lihuasoft.net
网站编程QQ群   京ICP备05001064号 页面生成时间:0.002