欢迎来到代码驿站!

.NET代码

当前位置:首页 > 软件编程 > .NET代码

C#图像灰度级拉伸的方法

时间:2021-07-05 09:20:15|栏目:.NET代码|点击:

本文实例讲述了C#图像灰度级拉伸的方法。分享给大家供大家参考。具体如下:

//定义图像灰度拉伸函数
private static Bitmap GrayLP (Bitmap a)
{
  Rectangle rect = new Rectangle(0, 0, a.Width, a.Height);
  System.Drawing.Imaging.BitmapData srcData = a.LockBits(rect, System.Drawing.Imaging.ImageLockMode.ReadWrite, a.PixelFormat);
  IntPtr ptr = srcData.Scan0;
  int bytes = 0;
  if (a.PixelFormat == System.Drawing.Imaging.PixelFormat.Format8bppIndexed)
  { bytes = a.Width * a.Height; }
  else { bytes = a.Width * a.Height * 3; }
  byte[] grayValues = new byte[bytes];
  System.Runtime.InteropServices.Marshal.Copy(ptr, grayValues, 0, bytes);
  byte n = 255, m = 0;
  double p;
  //计算最大和最小灰度级
  for (int i = 0; i < bytes; i++)
  {
   //计算最小灰度级
   if (n > grayValues[i])
   {
     n = grayValues[i];
   }        
   //计算最大灰度级
   if (m < grayValues[i])
   {
     m = grayValues[i];
   }
  }
  //得到斜率
  p = 255.0 / (m - n);
  //灰度拉伸
  for (int i = 0; i < bytes; i++)
  {
   grayValues[i] = (byte)(p * (grayValues[i] - n) + 0.5);
  }
  System.Runtime.InteropServices.Marshal.Copy(grayValues, 0, ptr, bytes);
  a.UnlockBits(srcData);
  return a;
}

希望本文所述对大家的C#程序设计有所帮助。

上一篇:winform实现可拖动的自定义Label控件

栏    目:.NET代码

下一篇:asp.net 自制的单选、多选列表实现代码

本文标题:C#图像灰度级拉伸的方法

本文地址:http://www.codeinn.net/misctech/152830.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有