手机
当前位置:查字典教程网 >编程开发 >C#教程 >C#图像灰度级拉伸的方法
C#图像灰度级拉伸的方法
摘要:本文实例讲述了C#图像灰度级拉伸的方法。分享给大家供大家参考。具体如下://定义图像灰度拉伸函数privatestaticBitmapGra...

本文实例讲述了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#图像灰度级拉伸的方法】相关文章:

C#操作目录与文件的方法步骤

.NET(C#):Emit创建异常处理的方法

c#中分割字符串的几种方法

解决C#全屏幕截图的实现方法

c# 托盘双击不触发单击事件的实现方法

c# asp .net 动态创建sql数据库表的方法

c#简单读取文本的实例方法

深入C# 内存管理以及优化的方法详解

C#中读写INI文件的方法例子

C#图片压缩的实现方法

精品推荐
分类导航