opencv处理透明图片

opencv处理透明图片

本文由 @lonelyrains出品,转载请注明出处。
文章链接: http://blog.csdn.net/lonelyrains/article/details/50389034

opencv处理透明图片,主要是考虑图片的叠加。

//主函数操作
...
Mat dest,srcAlpha;

// imread后一个参数为-1表示读取带有alpha通道的图片
srcAlpha = imread("C:\\Users\\Administrator\\Desktop\\1.png",-1);
dest= imread("C:\\Users\\Administrator\\Desktop\\1.png");

// 表示从dest的第(50,100)设置对srcAlpha的叠加
mapToMat(srcAlpha, dest, 50, 100);
...

void mapToMat(const cv::Mat &srcAlpha, cv::Mat &dest, int x, int y)
{
    int nc = 3;
    int alpha = 0;

    for (int j = 0; j < srcAlpha.rows; j++)
    {
        for (int i = 0; i < srcAlpha.cols*3; i += 3)
        {
            // 目的图片为三通道,所以是三通道的遍历、四通道的源图
            // i/3*4表示第i/3个像素的位置 
            // i/3*4 + 3表示本像素的alpha通道的值
            alpha = srcAlpha.ptr<uchar>(j)[i / 3*4 + 3];
            //alpha = 255-alpha;
            if(alpha != 0) //4通道图像的alpha判断
            {
                for (int k = 0; k < 3; k++)
                {
                    // if (src1.ptr<uchar>(j)[i / nc*nc + k] != 0)
                    if( (j+y < dest.rows) && (j+y>=0) &&
                        ((i+x*3) / 3*3 + k < dest.cols*3) && ((i+x*3) / 3*3 + k >= 0) &&
                        (i/nc*4 + k < srcAlpha.cols*4) && (i/nc*4 + k >=0) )
                    {
                        dest.ptr<uchar>(j+y)[(i+x*nc) / nc*nc + k] = srcAlpha.ptr<uchar>(j)[(i) / nc*4 + k];
                    }
                }
            }
        }
    }
}

处理前
这里写图片描述

处理后这里写图片描述

本代码段所在的完整工程见另一篇博客 大家一起过圣诞

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值