c# OpenCvSharp 判断图片的是否黑白

本文介绍了如何使用C#结合OpenCvSharp库来判断一张图片是否为黑白或灰度。最初的方法只能区分黑白和彩色,通过检查像素是否存在0和255的色素。后续代码进行了优化,确保在所有三个通道中颜色要么全为0要么全为255,以准确识别8色图像。
摘要由CSDN通过智能技术生成
public static bool CheckIsBlackWrite(Mat srcMat)
        {
            int height = srcMat.Rows / 4; //行 取了1/4是优化速度 一般判断这些就够了
            int width = srcMat.Cols / 4;  //列  ... ...     宽度

            for (int row = 0; row < height; row++)
            {
                for (int col = 0; col < width; col++)
                {
                    byte p = srcMat.At<byte>(row, col); //获对应矩阵坐标的取像素
                    if (p != byte.Parse((255).ToString()) && p != byte.Parse((0).ToString()))
                    {
                        return false;
                    }
                }
            }
            return true;
        }

有判断色道的方法 只能判断出灰度/黑白和彩色两种 所以用此方法判断黑白和灰度图片

黑白图只有0 和255色素 所以这样来判断

后续:完善了代码 之前有那种8色图 无法用以上方法判断出来 下面是改进方法 

三个通道的必须全为0或者全为255

public static bool CheckIsGray(Mat srcMat)
        {
            int height = srcMat.Rows / 4; //行 获取图片的行叠加起来就是高度
            int width = srcMat.Cols / 4;  //列  ... ...     宽度

            for (int row = 0; row < height; row++)
            {
                for (int col = 0; col < width; col++)
                {
                    Vec3b p = srcMat.At<Vec3b>(row, col); //获对应矩阵坐标的取像素
                    if (((int)p[0] != 255 && (int)p[0] != 0) ||
                        ((int)p[1] != 255 && (int)p[1] != 0) ||
                        ((int)p[2] != 255 && (int)p[2] != 0) ||
                        p[0] != p[1] || p[1] != p[2] || p[0] != p[2])
                    {
                        Console.WriteLine(p[0] + "  " + p[1] + " " + p[2]);
                        return true;
                    }
                }
            }
            return false;
        }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值