C#数字图象处理之图像灰度化方法
本文实例讲述了C#数字图象处理之图像灰度化方法。分享给大家供大家参考。具体如下:
//定义图像灰度化函数 privatestaticBitmapPGray(Bitmapsrc) { intw=src.Width; inth=src.Height; //构建与原图像大小一样的模版图像 BitmapdstBitmap=newBitmap(src.Width,src.Height,System.Drawing.Imaging.PixelFormat.Format24bppRgb); //将原图像存入内存 System.Drawing.Imaging.BitmapDatasrcData=src.LockBits(newRectangle(0,0,w,h),System.Drawing.Imaging.ImageLockMode.ReadOnly,System.Drawing.Imaging.PixelFormat.Format24bppRgb); System.Drawing.Imaging.BitmapDatadstData=dstBitmap.LockBits(newRectangle(0,0,w,h),System.Drawing.Imaging.ImageLockMode.WriteOnly,System.Drawing.Imaging.PixelFormat.Format24bppRgb); unsafe { byte*pIn=(byte*)srcData.Scan0.ToPointer(); byte*pOut=(byte*)dstData.Scan0.ToPointer(); byte*p; intstride=srcData.Stride; intr,g,b; for(inty=0;y<h;y++) { for(intx=0;x<w;x++) { p=pIn; r=p[2]; g=p[1]; b=p[0]; //调用图像灰度化公式 pOut[0]=pOut[1]=pOut[2]=(byte)(b*0.114+g*0.587+r*0.299); pIn+=3; pOut+=3; } pIn+=srcData.Stride-w*3; pOut+=srcData.Stride-w*3; } src.UnlockBits(srcData); dstBitmap.UnlockBits(dstData); returndstBitmap; } }
希望本文所述对大家的C#程序设计有所帮助。