图像处理-逻辑运算

个人博客:http://www.chenjianqu.com/

原文链接:http://www.chenjianqu.com/show-39.html

图像的逻辑运算:

1.   对图像求反

对于黑白图像来说,黑变白 百变黑,对于灰度图像来说,将255减去原像素值即为求反。

应用:

(1)     求取图像的阴影面积

(2)     求取图像的补图像

代码实现如下:

//非运算

Mat NotOperation(Mat& src)
{
    return LinearPointOperation(src, -1, 255);
}

1_20190109212010_818.png

 

2.  与运算

当两个图像对应的像素同时为真时,结果为真。

应用: 主要用于求两幅二值图像的相交部分。

代码实现:

Mat AndOperation(Mat& src1, Mat& src2)
{
    Mat dst(src1.rows, src1.cols, src1.type(), Scalar(0));
    if (src1.channels() == 1 && src2.channels() == 1) {
        for (int i = 0; i < src1.rows; i++) {
            uchar *src1Row = src1.ptr(i);
            uchar *src2Row = src2.ptr(i);
            uchar *dstRow = dst.ptr(i);
            for (int j = 0; j < src1.cols; j++)
            {
                if (src1Row[j] > 122 && src2Row[j] > 122)
                    dstRow[j] = 255;
                else
                    dstRow[j] = 0;
            }
        }
    }
    return dst;
}


2_20190109212056_149.png

 

3.   或运算

当两个图像对应的像素有一个为真时,结果为真。

应用:主要用于求两幅二值图像的合并。

代码实现如下:

Mat OrOperation(Mat& src1, Mat& src2)
{
    Mat dst(src1.rows, src1.cols, src1.type(), Scalar(0));
    if (src1.channels() == 1 && src2.channels() == 1) {
        for (int i = 0; i < src1.rows; i++) {
            uchar *src1Row = src1.ptr(i);
            uchar *src2Row = src2.ptr(i);
            uchar *dstRow = dst.ptr(i);
            for (int j = 0; j < src1.cols; j++)
            {
                if (src1Row[j] > 122 || src2Row[j] > 122)
                    dstRow[j] = 255;
                else
                    dstRow[j] = 0;
            }
        }
    }
    return dst;
}

3_20190109212119_386.png

 

 

4.    异或运算

当两个图像对应的像素相同时,结果为真;反之为假。

应用:

(1)     得到两幅图像中不想交的部分

(2)     绘制区别于背景的,可恢复的图像

代码实现:

Mat XorOperation(Mat& src1, Mat& src2)
{
    Mat dst(src1.rows, src1.cols, src1.type(), Scalar(0));
    if (src1.channels() == 1 && src2.channels() == 1) {
        for (int i = 0; i < src1.rows; i++) {
            uchar *src1Row = src1.ptr(i);
            uchar *src2Row = src2.ptr(i);
            uchar *dstRow = dst.ptr(i);
            for (int j = 0; j < src1.cols; j++)
            {
                if (src1Row[j] ==src2Row[j])
                    dstRow[j] = 0;
                else
                    dstRow[j] = 255;
            }
        }
    }
    return dst;
}

4_20190109212154_578.png

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值