vb.net 教程 5-16 图像处理之ImageAttributes 类2 颜色矩阵4

版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。
在《vb.net 教程 5-14 图像处理之内存处理基础6 》一节,我们曾对比了一维数组、二维数组、指针处理、像素处理这几种方法处理图像的速度。

本节也将色彩矩阵加入进行对比,同样使用灰度均值法处理并计算耗时,前述四种图像处理方法速度的计算参看《vb.net 教程 5-14 图像处理之内存处理基础5》

灰度均值法的计算为:

Rnew=Gnew=Bnew=(Rold+Gold+Bold)/3

拟采用的矩阵为:

主要代码如下:

    Private Sub Button15_Click(sender As Object, e As EventArgs) Handles Button15.Click
        Dim imageAttributes As New ImageAttributes()
 
        Dim timeStart, timeEnd As DateTime
        Dim timeDiff As TimeSpan
 
        timeStart = Now()
 
        '灰度均值
        Dim imgMatrixElement()() As Single = {
          New Single() {0.33, 0.33, 0.33, 0, 0},
          New Single() {0.33, 0.33, 0.33, 0, 0},
          New Single() {0.33, 0.33, 0.33, 0, 0},
          New Single() {0, 0, 0, 1, 0},
          New Single() {0, 0, 0, 0, 0}
        }
 
        Dim imgMatrix As New ColorMatrix(imgMatrixElement)
        imageAttributes.SetColorMatrix(imgMatrix, ColorMatrixFlag.Default, ColorAdjustType.Bitmap)
 
 
        Dim destImg As New Bitmap(sourceImg.Width, sourceImg.Height)
        Dim g As Graphics = Graphics.FromImage(destImg)
        g.DrawImage(sourceImg, New Rectangle(0, 0, sourceImg.Width, sourceImg.Height), 0, 0, sourceImg.Width, sourceImg.Height,
                    GraphicsUnit.Pixel, imageAttributes)
 
        picDest.Image = destImg
        timeEnd = Now
        timeDiff = timeEnd - timeStart
        Console.WriteLine(timeDiff.TotalMilliseconds)
    End Sub
 

请大家见谅的是,之前测试用时的那个小点的图片被我无意中处理成了更小的图片,找原图也找不到,这里只做那张大图片的测试:

5次运行平均耗时:412.4948,参考之前的耗时:

说明颜色矩阵在处理速度上还是有优势,当然处理颜色的灵活度上比其他方法差点,要实际问题实际分析,看情况选用。

由于.net平台下C#和vb.NET很相似,本文也可以为C#爱好者提供参考。

学习更多vb.net知识,请参看 vb.net教程 目录

————————————————
版权声明:本文为CSDN博主「VB.Net」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值