zoukankan      html  css  js  c++  java
  • opencv中的cvAddWeighted函数

     自己最近需要跑一个利用opencv的程序,看到程序中有一个cvAddWeighted函数,不是很理解,所以到网上找了一些材料,整理了它的用法: 

    vAddWeighted( const CvArr* src1, double alpha,  
                  const CvArr* src2, double beta,  
                  double gamma, CvArr* dst );  
    src1  
    第一个原数组.  
    alpha  
    第一个数组元素的权值  
    src2  
    第二个原数组  
    beta  
    第二个数组元素的权值  
    dst  
    输出数组  
    gamma  
    添加的常数项。  
    函数 cvAddWeighted 计算两数组的加权值的和:  
    dst(I)=src1(I)*alpha+src2(I)*beta+gamma  
    所有的数组必须有相同的类型相同的大小(或ROI大小)

    下面的例子生成原始图片的缩略图,并把缩略图以不同的alpha混合参数和源图片混合。

    #include <cv.h>
    #include <highgui.h>
    #define PART 4
    int main()
    {
    IplImage *src1, *src2;
    CvFont font;
    float alpha_value;
    char alpha_str[10];
    char wnd_title[100];
    //载入图像到src1并生成其缩略图src2
    src1 = cvLoadImage("poppy.jpg"1);
    src2 = cvCreateImage(cvSize(src1->width / PART, src1->height / PART),
    src1->depth, src1->nChannels);
    cvResize(src1, src2);
    //初始化字体,为以后的绘制文字做准备
    cvInitFont(&font, CV_FONT_HERSHEY_SIMPLEX, 0.50.5);
    for (int x = 0; x < PART; x+=1){
    for (int y = 0; y < PART; y+=1){
    //计算alpha值
    alpha_value = (float)(x + y * PART) / (PART * PART -1);
    sprintf(alpha_str, "%.3f", alpha_value);
    //设定RIO并进行该区域的Alpha blending
    cvSetImageROI(src1, cvRect(x * (src1->width / PART), y * (src1->height / PART),
    src1->width / PART, src1->height / PART));
    cvAddWeighted(src2, alpha_value, src1, 1 - alpha_value, 0, src1);
    //绘制图框和文字
    cvRectangle(src1, cvPoint(00),
    cvPoint(src1->width / PART, src1->height / PART),
    cvScalar(064238), 1);
    cvPutText(src1, alpha_str, cvPoint(1020), &font, cvScalar(000));
    cvResetImageROI(src1);
    }
    }
    //显示混合结果
    strcpy(wnd_title, "Alpha_blending by Afu 2010/7/26");
    cvNamedWindow(wnd_title);
    cvShowImage(wnd_title, src1);
    cvWaitKey();
    return 0;
    }
  • 相关阅读:
    文件操作
    匿名函数
    函数
    运算符
    (模板)扩展kmp算法(luoguP5410)
    poj2406(求字符串的周期,kmp算法next数组的应用)
    poj1961(kmp算法next数组应用)
    hdoj1711(kmp算法)
    (模板)poj3461(kmp模板题)
    fzu1704(高斯消元法解异或方程组+高精度输出)
  • 原文地址:https://www.cnblogs.com/xkfz007/p/2216156.html
Copyright © 2011-2022 走看看