Win8MetroC#数字图像处理--2.1图像灰度化

简介: 原文:Win8MetroC#数字图像处理--2.1图像灰度化   [函数说明] 图像灰度化函数GrayProcess(WriteableBitmap src) [算法说明]   图像灰度化就是去掉彩色图像的彩色信息。
原文: Win8MetroC#数字图像处理--2.1图像灰度化

 

[函数说明]

图像灰度化函数GrayProcess(WriteableBitmap src)

[算法说明]

  图像灰度化就是去掉彩色图像的彩色信息。对于一张图像,其中的每一个像素都

存在B,G,R三个颜色分量(这里不考虑透明度分量),这三个分量在C#中是按照BG

R的顺序进行存储的,这三个分量的值分别取在0-255范围之内,对于不同取值,

相应的也就产生了不同的颜色信息。如果以X,Y,Z轴分别取代R,G,B分量构建三维坐

标系,则颜色分布如图2.1所示。

公式2-(1)是根据我们人眼对颜色感知的特点以及人眼对色彩分辨的范围计算得到

的一个比较适于人眼感官的公式。

    这里我们采用公式2-(1),对每个像素运用该公式,得到的值即为像素的灰度值。

[函数代码]

/// <summary>
        /// Gray process.
        /// </summary>
        /// <param name="src">Source image.</param>
        /// <returns></returns>
        public static WriteableBitmap GrayProcess(WriteableBitmap src) ////1 灰度化处理
        {
              if(src!=null )
              {
                int w = src.PixelWidth;
                int h = src.PixelHeight;
                WriteableBitmap grayImage = new WriteableBitmap(w, h);
                byte[] temp = src.PixelBuffer.ToArray();
                for (int i = 0; i < temp.Length; i += 4)
                {
                    byte tempByte = (byte)((int)(temp[i] * 0.114 + temp[i + 1] * 0.587 + temp[i + 2] * 0.299));
                    temp[i] = tempByte;
                    temp[i + 1] = tempByte;
                    temp[i + 2] = tempByte;
                }
                Stream sTemp = grayImage.PixelBuffer.AsStream();
                sTemp.Seek(0, SeekOrigin.Begin);
                sTemp.Write(temp, 0, w * 4 * h);
                return grayImage;
            }
            else
            {
                return null;
            }         
        }

[图像效果]

 

目录
相关文章
|
算法 C# 计算机视觉
Win8Metro(C#)数字图像处理--2.31灰度拉伸算法
原文:Win8Metro(C#)数字图像处理--2.31灰度拉伸算法  [函数名称] 灰度拉伸函数GrayStretchProcess(WriteableBitmap src) [算法说明]   直方图灰度拉伸也叫做对比度拉伸,是一种特殊的线性点运算,使用的是分段线性变换函数,它的主要思想是提高图像灰度级的动态范围;它的作用是扩展图像的直方图,使其充满整个灰度等级的范围内,从而改善输出图像。
1569 0
|
C# 计算机视觉 Windows
Win8 Metro(C#)数字图像处理--2.58双峰法图像二值化
原文:Win8 Metro(C#)数字图像处理--2.58双峰法图像二值化  [函数名称]   双峰法图像二值化 WriteableBitmap  PeakshistogramThSegment(Writea...
1143 0
|
存储 C# 计算机视觉
Win8 Metro(C#)数字图像处理--2.56简单统计法图像二值化
原文:Win8 Metro(C#)数字图像处理--2.56简单统计法图像二值化  [函数名称]   简单统计法图像二值化 WriteableBitmap StatisticalThSegment(Writea...
1107 0
|
C# 计算机视觉 缓存
Win8 Metro(C#)数字图像处理--2.55OSTU法图像二值化
原文:Win8 Metro(C#)数字图像处理--2.55OSTU法图像二值化  [函数名称]   Ostu法图像二值化      WriteableBitmap OstuThSegment(Writeabl...
930 0
|
算法 C# 计算机视觉
Win8 Metro(C#)数字图像处理--2.59 P分位法图像二值化
原文:Win8 Metro(C#)数字图像处理--2.59 P分位法图像二值化  [函数名称]   P分位法图像二值化 [算法说明]   所谓P分位法图像分割,就是在知道图像中目标所占的比率Ratio时,循环不同的灰度值对图像进行 分割,并计算对应的目标所占的比率,如果该比率与Ratio的差值足够小,那么该阈值就是所求的最 佳分割阈值。
974 0
|
C# 计算机视觉
Win8Metro(C#)数字图像处理--2.19图像水平镜像
原文:Win8Metro(C#)数字图像处理--2.19图像水平镜像  [函数名称] 图像水平镜像函数MirrorXProcess(WriteableBitmap src) [函数代码]        ///        /// Horizontal mirror process.
911 0
|
算法 C# 计算机视觉
Win8 Metro(C#)数字图像处理--2.35图像肤色检测算法
原文:Win8 Metro(C#)数字图像处理--2.35图像肤色检测算法  [函数名称] 肤色检测函数SkinDetectProcess(WriteableBitmap src) [算法说明]   这个算法是一篇学术论文算法的实现,论文名字为“基于韧脸检测和颜色分析的红眼自动消除”(作者金秋明,王朔中),主要是采集并统计肤色像素,得到肤色像素在RGB颜色空间中的分布范围,以此作为像素是否为肤色像素的判断标准及约束条件。
1265 0
|
算法 C# 计算机视觉
Win8 Metro(C#)数字图像处理--2.45图像雾化效果算法
原文:Win8 Metro(C#)数字图像处理--2.45图像雾化效果算法 [函数名称]   图像雾化         AtomizationProcess(WriteableBitmap src,int v) ...
1156 0
|
C# 计算机视觉
Win8Metro(C#)数字图像处理--2.17图像木刻效果
原文:Win8Metro(C#)数字图像处理--2.17图像木刻效果  [函数名称] 图像木刻效果函数WoodCutProcess(WriteableBitmap src) [函数代码]        ///        /// Wood cut process.
1292 0
|
C# 计算机视觉
Win8Metro(C#)数字图像处理--2.15图像霓虹效果
原文:Win8Metro(C#)数字图像处理--2.15图像霓虹效果  [函数名称] 图像霓虹效果函数NeonProcess(WriteableBitmap src) 上述公式进行开方即可。
914 0