C#图像灰度级拉伸的方法
更新时间:2015年04月24日 09:58:40 作者:沧海一粟……
这篇文章主要介绍了C#图像灰度级拉伸的方法,涉及C#灰度操作的相关技巧,需要的朋友可以参考下
本文实例讲述了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#程序设计有所帮助。
相关文章
C#实现Excel表数据导入Sql Server数据库中的方法
这篇文章主要介绍了C#实现Excel表数据导入Sql Server数据库中的方法,结合实例形式详细分析了C#读取Excel表数据及导入Sql Server数据库的具体操作步骤与相关操作技巧,需要的朋友可以参考下2017-05-05C# HttpClient 如何使用 Consul 发现服务
这篇文章主要介绍了C# HttpClient 如何使用 Consul 发现服务,帮助大家更好的理解和使用c#,感兴趣的朋友可以了解下2021-02-02
最新评论