betterhalf 2016-05-05 10:06 采纳率: 15.4%
浏览 1237
已采纳

如何实现图像减操作

#include
#include
#include

using namespace std;
void main(unsigned char *src1, unsigned char *src2, unsigned char *dst, int width, int height)
{

IplImage *image1, *image2, *image3;
image1 = cvLoadImage("1.jpg", 0);//以灰度图像的形式读入图片 
image2 = cvLoadImage("2.jpg", 0);
cvNamedWindow("image", CV_WINDOW_AUTOSIZE);
cvNamedWindow("image2", CV_WINDOW_AUTOSIZE);
cvNamedWindow("image3", CV_WINDOW_AUTOSIZE);
cvShowImage("image", image3);
cvWaitKey(0);
int i, j;
unsigned char *p1, *p2, *p3;
p1 = src1;
p2 = src2;
p3 = dst;
for (j = 0; j< height; j++)
{
    for (i = 0; i< width; i++, p1++, p2++, p3++)
    {
        (*p3) = abs((*p1) - (*p2));
    }
}

}

  • 写回答

2条回答 默认 最新

  • 浪里来浪里去 2016-05-05 14:03
    关注

    1、使用opencv内置函数获取像素点灰度做差法。
    bool imageSubtract(IplImage* src,IplImage* dst)
    {
    int row = 0;//行
    int col = 0;//列
    CvScalar s;

    if (!src || !dst)
    {
        return 0;
    }
    if ((src->height != dst->height) && (src->width != dst->width))
    {
        return 0;
    }
    
    for (row = 0;row <src->height;row++)
    {   
        for (col = 0;col<src->width;col++)
        {
            s.val[0] = fabs(cvGet2D(src,row,col).val[0]-cvGet2D(dst,row,col).val[0]); 
            cvSet2D(dst,row,col,s);//相差结果存于dst
        }
    }
    return 1;
    

    }
    2、使用指针获取像素灰度做差法
    bool imageSubtract(IplImage* src,IplImage* dst)
    {
    int row = 0;//行
    int col = 0;//列
    uchar* pSrcData = NULL;
    uchar* pDstData = NULL;
    int stepSrc = 0;
    int stepDst = 0;

    if (!src || !dst)
    {
        return 0;
    }
    if ((src->height != dst->height) && (src->width != dst->width))
    {
        return 0;
    }
    
    pSrcData = (uchar *)src->imageData;
    stepSrc = src->widthStep/sizeof(uchar);
    
    pDstData = (uchar *)src->imageData;
    stepDst = dst->widthStep/sizeof(uchar);
    
    for (row = 0;row <src->height;row++)
    {   
        for (col = 0;col<src->width;col++)
        {
            pDstData[row*stepDst+col] = abs(pSrcData[row*stepSrc+col] - pDstData[row*stepDst+col]);
        }
    }
    return 1;
    

    }

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥200 uniapp长期运行卡死问题解决
  • ¥15 latex怎么处理论文引理引用参考文献
  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?
  • ¥15 乘性高斯噪声在深度学习网络中的应用