C#数字图像处理之图像二值化(彩色变黑白)的方法
本文实例讲述了C#数字图像处理之图像二值化(彩色变黑白)的方法。分享给大家供大家参考。具体如下:
//定义图像二值化函数 privatestaticBitmapPBinary(Bitmapsrc,intv) { 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)(((byte)(0.2125*r+0.7154*g+0.0721*b)>=v) ?255:0); pIn+=3; pOut+=3; } pIn+=srcData.Stride-w*3; pOut+=srcData.Stride-w*3; } src.UnlockBits(srcData); dstBitmap.UnlockBits(dstData); returndstBitmap; } }
希望本文所述对大家的C#程序设计有所帮助。