经过大量的测试,人们得到了一个经验公式,来说明人的眼睛是如何识别亮度的:
Gray = Red * 0.3 + Green * 0.6 + Blue * 0.1
而右因为人的眼睛对于绿色的敏感度,就有了一个更加近似的公式:
Gray = Green
请大家再回想一下以前在用铅笔画眼睛看到的景色的时候,是如何做的呢?轮廓,对了,轮廓是什么呢?其实说白了就是灰度的一个跳变。因此我们只要设定一个阀值,把电脑上的图片中的像素的色彩转化为灰度,再把相邻的两个像素的灰度去比较,当灰度变化超过一定的量的时候,我们就判断它是轮廓。用铅笔把它描绘出来。
有了这个思路,我们就很容易把这个算法写出来了。
Public Sub Pencil(Optional ByVal Sensitivity As Long = 25)
Dim I As Long
Dim L As Long
Dim M As Long
Dim N As Long
Dim Col As Long
Dim ColNext As Long
'On Error GoTo ErrLine
If Not CanPut Then Exit Sub
Done = False
TimeFilter = timeGetTime
For I = 0 To OutPutWid - 1
M = I + 1
For L = 0 To OutPutHei - 1
N = L + 1
Col = ColOut(0, I, L) * 3 + ColOut(1, I, L) * 6 + ColOut(2, I, L)
Col = Col \ 10 '当前点的灰度哦。
ColNext = ColOut(0, M, N) * 3 + ColOut(1, M, N) * 6 + ColOut(2, M, N)
ColNext = -ColNext / 10 '下一点的灰度哦。
If Col + ColNext > Sensitivity Then '判断灰度变化是否超过设定的阀值
ColOut(0, I, L) = 0 'RGB(0,0,0)表示黑色
ColOut(1, I, L) = 0
ColOut(2, I, L) = 0
Else
ColOut(0, I, L) = 255 'RGB(255,255,255)表示白色
ColOut(1, I, L) = 255
ColOut(2, I, L) = 255
End If
Next
Next
Done = True
TimeFilter = timeGetTime - TimeFilter
Exit Sub
ErrLine:
MsgBox Err.Description
End Sub
【VB图像处理之铅笔画算法和木雕算法】相关文章:
Vb中控件的自动排列05-15
法院上半年工作总结05-15
at(the)least和not(in)the least用法区别 相似词语辨析(17)05-15
5月11日开始报名!2023年内蒙古鄂尔多斯市乌审旗秋季幼升小入学条件和流程公布05-15
辽宁省退役军人事务厅 财政厅 关于调整部分优抚对象等人员抚恤和生活补助标准的通知05-15
高一诗歌:在前奏和尾声之间_200字05-15
趵突泉公园之游05-15
计算机应用技术英语简历范文大全05-15
敲重点啦!2024年四川攀枝花中小学寒假时间和春季开学时间公布05-15
分式的乘方和乘方法则05-15
分式的乘方和乘方法则05-15
