当前位置:   article > 正文

17.3.1.5 二值化(黑白)

17.3.1.5 二值化(黑白)

版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。

二值化的算法主要有以下两种:

1、彩色图像灰度化后,根据灰度和阈值来确定颜色是黑色还是白色。通常情况下使用的阈值是128。

2、第一种算法选择128作为阈值,在实际使用中显示效果并不是很好,可以采用更常见的求阈值的方法,例如大律法等。

【例 17.38二值化算法一。

  1. //黑白1
  2. private void btn2Color1_Click(object sender, EventArgs e)
  3. {
  4. Color pSourceColor;
  5. Color pDestColor;
  6. Bitmap destImg = new Bitmap(sourceImg.Width, sourceImg.Height);
  7. int R, G, B;
  8. int AvgColor;
  9. for (int i = 0; i < sourceImg.Width; i++)
  10. {
  11. for (int j = 0; j < sourceImg.Height; j++)
  12. {
  13. pSourceColor = sourceImg.GetPixel(i, j);
  14. R = pSourceColor.R;
  15. G = pSourceColor.G;
  16. B = pSourceColor.B;
  17. AvgColor = (R + G + B) / 3;
  18. if (AvgColor >= 128)
  19. AvgColor = 255;
  20. else
  21. AvgColor = 0;
  22. pDestColor = Color.FromArgb(AvgColor, AvgColor, AvgColor);
  23. destImg.SetPixel(i, j, pDestColor);
  24. }
  25. }
  26. picDest.Image = destImg;
  27. }

运行结果如下图所示:

图17-42 二值化处理一

【例 17.39二值化算法二。

  1. //黑白2
  2. private void btn2Color2_Click(object sender, EventArgs e)
  3. {
  4. Color pSourceColor;
  5. Color pDestColor;
  6. Bitmap destImg = new Bitmap(sourceImg.Width, sourceImg.Height);
  7. int R, G, B;
  8. int[] HistGram = new int[256];
  9. for (int i = 0; i < sourceImg.Width; i++)
  10. {
  11. for (int j = 0; j < sourceImg.Height; j++)
  12. {
  13. pSourceColor = sourceImg.GetPixel(i, j);
  14. HistGram[pSourceColor.R] += 1;
  15. }
  16. }
  17. int threshold;
  18. int allSum = 0;
  19. int allCount=0;
  20. for(int k = 0;k<= 255;k++)
  21. {
  22. allCount += HistGram[k];
  23. allSum += k * HistGram[k];
  24. }
  25. threshold = allSum / allCount;
  26. for (int i = 0; i < sourceImg.Width; i++)
  27. {
  28. for (int j = 0; j < sourceImg.Height; j++)
  29. {
  30. pSourceColor = sourceImg.GetPixel(i, j);
  31. R = pSourceColor.R;
  32. if (R >= threshold)
  33. R = 255;
  34. else
  35. R = 0;
  36. pDestColor = Color.FromArgb(R, R, R);
  37. destImg.SetPixel(i, j, pDestColor);
  38. }
  39. }
  40. picDest.Image = destImg;
  41. }

运行结果如下图所示:

图17-43 二值化处理二

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

学习更多C#知识,请参看 C# 教程 目录

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/笔触狂放9/article/detail/101153
推荐阅读
相关标签
  

闽ICP备14008679号