C#圖像灰度級拉伸的方法
更新時間:2015年04月24日 09:58:40 作者:滄海一粟……
這篇文章主要介紹了C#圖像灰度級拉伸的方法,涉及C#灰度操作的相關(guān)技巧,需要的朋友可以參考下
本文實例講述了C#圖像灰度級拉伸的方法。分享給大家供大家參考。具體如下:
//定義圖像灰度拉伸函數(shù)
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#程序設(shè)計有所幫助。
相關(guān)文章
C#數(shù)據(jù)結(jié)構(gòu)之堆棧(Stack)實例詳解
這篇文章主要介紹了C#數(shù)據(jù)結(jié)構(gòu)之堆棧(Stack),結(jié)合實例形式較為詳細(xì)的分析了堆棧的原理與C#實現(xiàn)堆棧功能的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-11-11
C#基于HttpWebRequest實現(xiàn)發(fā)送HTTP請求的方法分析
這篇文章主要介紹了C#基于HttpWebRequest實現(xiàn)發(fā)送HTTP請求的方法,結(jié)合實例形式分析了C#使用HttpWebRequest類與System.IO類實現(xiàn)發(fā)送HTTP請求相關(guān)操作技巧與注意事項,需要的朋友可以參考下2019-02-02
C#?利用Autofac批量接口注入依賴的問題小結(jié)
這篇文章主要介紹了C#?利用Autofac批量接口注入依賴的問題,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-12-12

