2 qq 34614890 qq_34614890 于 2016.05.09 11:03 提问

图像加减运算,为什么输出结果不对

#include
#include
#include
#include

#include

using namespace std;

//图像加减运算
//unsigned char *lpSrc1:原图像1像素指针
//unsigned char *lpSrc2:原图像2像素指针
//unsigned char *lpDst:目标像素指针

int main()
{
IplImage * image1, *image2, *image3;
image1 = cvLoadImage("1.jpg", 0);
image2 = cvLoadImage("2.jpg", 0);
cvNamedWindow("image1", CV_WINDOW_AUTOSIZE);
cvNamedWindow("image2", CV_WINDOW_AUTOSIZE);
cvNamedWindow("image3", CV_WINDOW_AUTOSIZE);
cvSaveImage("1.jpg", image1, 0);
cvSaveImage("2.jpg", image2, 0);
cvShowImage("image1", image1);
cvShowImage("image2", image2);
image3 = cvCreateImage(cvGetSize(image1), image1->depth, 1);

unsigned char *lpSrc1;
unsigned char *lpSrc2;
unsigned char *lpDst;

int i, j;

for ( i = 0; i < image1->height;i++) 

    for ( j = 0; j< image1->width;j++)
    {
        lpSrc1 = (unsigned char *)image1->imageData + i*image1->widthStep + j;


        for (i = 0; i < image2->height;i++)

            for (j = 0; j < image2->width;j++)
            {
                lpSrc2 = (unsigned char *)image2->imageData + i*image2->widthStep + j;


                lpDst = (unsigned char *)image3->imageData + i*image3->widthStep + j;


                if ((*lpSrc1 + *lpSrc2) > 255)
                    *lpDst = 255;
                else
                    *lpDst = (*lpSrc1 + *lpSrc2);

            }
    }




cvShowImage("image3", image3);
cvWaitKey(0);
return 0;

}

2个回答

qq_34614890
qq_34614890   2016.05.09 11:08

图像加减运算,为什么输出结果不对

sinat_34928892
sinat_34928892   2016.05.09 11:16

请问你下面的图是怎么弄的啊,我发问题,图片总是看不清

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!
其他相关推荐
NYOJ 111 分数加减法
描述编写一个C程序,实现两个分数的加减法输入输入包含多行数据 每行数据是一个字符串,格式是”a/boc/d”。 其中a, b, c, d是一个0-9的整数。o是运算符”+”或者”-“。 数据以EOF结束 输入数据保证合法输出对于输入数据的每一行输出两个分数的运算结果。 注意结果应符合书写习惯,没有多余的符号、分子、分母,并且化简至最简分数样例输入1/8+3/8 1/4-1/2 1
C语言代码,求高手解答,为什么没有错误,但是结果不对
#include #include char *cmonth(int month) { char str_month[]={ "Illegal Month" "January" "February" "March" "April" "May" "June" "July" "August" "September" "October" "November"
为什么 y<0 时,输出结果不对?
#include double mhs(double x,int y) { if (y==1) return x; else if(y>1) return x * mhs(x,y-1); else if(y<0) return 1.0/x*mhs(x,(-y)-1); } void main() { in
代码的结果输出不对
import java.util.*; public class L4_5  {     public static void main(String[] args)      {         HashMap ee=new HashMap();         Sp sp1=new Sp("001","香肠",20);         Sp sp2=new Sp("002","果
printf格式输出结果不正确
测试程序: #include int main(void) { printf("%f\n", 0); printf("%f\n", (float)123); printf("%f\n", 123.0); return 0; } VC6中反汇编一下,看看: 7: printf("%f\n", 123); 00401028 push 7Bh //
数据结构一元多项式的计算
并较完善的一元多项式计算代码,能够实现一元多项式的加减运算!并且正确输出结果!
cuda 反傅里叶变换结果不对的问题
cufftExecC2C(plan, (cufftComplex *)in_vx_d, (cufftComplex *)out_vx_d, CUFFT_INVERSE);  cufft做逆傅里叶变换后需要将结果除以点数(NX*NY).
ROS_OpenCV_socket传送图像_结果不对
//Includes all the headers necessary to use the most common public pieces of the ROS system. #include //Use image_transport for publishing and subscribing to images in ROS #include //Use cv_bridge t
java float double类型做小数点加减运算不准确
比如: 21.1-17 不是等于4.1 解决办法================== http://blog.javaxxz.com/?p=763 一提到Java里面的商业计算,我们都知道不能用float和double,因为他们无法 进行精确计算。但是Java的设计者给编程人员提供了一个很有用的类BigDecimal,他可以完善float和dou
结果规格化—规格化浮点数的加减运算
一.对运算结果进行规格化处理(1)先判断结果是不是规格化,如不是执行下面几步(2)补码尾数的最高位和尾数符号相反,如(3)结果溢出(01,10)则需要左规,否则右规二.例题分析例题1:x = 2^11*0.100101, y = 2^-10*(-0.011110) [x]浮 = 11101,0.100101,[y]浮 = 11110,-0.011110Ex-Ey = 11101+00010=111...