opencv中的cvAddWeighted函數

來源:互聯網
上載者:User

 自己最近需要跑一個利用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.5, 0.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(0, 0),
cvPoint(src1->width / PART, src1->height / PART),
cvScalar(0, 64, 238), 1);
cvPutText(src1, alpha_str, cvPoint(10, 20), &font, cvScalar(0, 0, 0));
cvResetImageROI(src1);
}
}
//顯示混合結果
strcpy(wnd_title, "Alpha_blending by Afu 2010/7/26");
cvNamedWindow(wnd_title);
cvShowImage(wnd_title, src1);
cvWaitKey();
return 0;
}

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.