多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > php開源 > 綜合技術 > opencv模擬景深效果

opencv模擬景深效果

來源:程序員人生   發布時間:2015-04-02 08:49:26 閱讀次數:3798次

簡介

  在htc的相機利用中發現了1個叫景深的拍照場景,然后練習著用opencv來摹擬實現。


hcl景深場景效果

Opencv wt 18 1.jpg


本例實現效果

Opencv wt 18 2.jpg


實現進程

  要實現本例,需要用到兩方面知識:1、圖象的高斯模糊。 2.在圖象中去出感興趣的圓形區域。


高斯模糊

  用的是opencv函數:cvSmooth。該函數參數具體使用,看opencv官網的api介紹吧:http://docs.opencv.org/modules/refman.html
#include <opencv2/core/core.hpp>                                                                                                   
#include <opencv2/highgui/highgui.hpp>
#include <math.h>
#include <string.h>
#include <opencv/cv.h>
#include <stdio.h>
 
using namespace cv;
 
int width, height;
char pic_name[20];
Mat mat1;
 
void mySmooth(Mat mat1, Mat mat2, int flag, int width, int height){
    IplImage pI1 = mat1;    
    IplImage pI2 = mat2;
 
    cvSmooth(&pI1, &pI2, flag, width, height);
}
 
int main(int argc,char *argv[]){
    memcpy(pic_name,argv[1], sizeof(argv[1]));
    mat1 = imread(pic_name, 1);
 
    imshow("1", mat1);
    mySmooth(mat1, mat1,CV_GAUSSIAN, 23, 23);                                                                                      
    imshow("2", mat1);
    cv::waitKey(0);
    return 0;
}
  顯示效果以下: Opencv wt 18 3.jpg


圓形興趣區域

  在opencv的ROI中,最常使用的在圖片中截取出感興趣區域方式以下:
cv::Mat imageROI;
imageROI = img(cv::Rect(40,40,40,40));
  該代碼表示,在圖象img的坐標(40,40)位置,取出1個width:40,height:40的矩形復制到imageROI中。 但是如果我們想復制取出的區域為圓形的話,就不能用這個辦法。需要使用以下方式:
/**************取出圓形感興趣區域**********/
    mat1 = imread(pic_name, 1);                                                                                                    
    src = mat1;
    res = cvCreateImage(cvGetSize(&src), 8, 3);
    roi = cvCreateImage(cvGetSize(&src), 8, 1);
 
    cvZero(roi);
    cvZero(res);
    cvCircle(roi,cvPoint(50, 50), 30,CV_RGB(255, 255, 255),⑴, 8, 0);
    cvAnd(&src, &src, res, roi);    
    /******************************************/
  首先新建兩個和原圖象src相同大小的Mat:res、roi,然后將res和roi內容都清空,接著在roi中坐標(50,50)為圓形,30為半徑畫1個圓。 接著調用cvAnd函數中,將roi作為掩碼輸入,就在res中復制得到了src對應在roi畫圓區域的圖象內容。   具體的效果演示以下: Opencv wt 18 4.jpg


本例代碼

  本例使用的代碼主要就是如上知識,另外還有鼠標拖動來控制圖象景深圓圈的大小和開始位置。 具體代碼以下:
#include <opencv2/core/core.hpp>                                                                                                   
#include <opencv2/highgui/highgui.hpp>
#include <math.h>
#include <string.h>
#include <opencv/cv.h>
#include <stdio.h>
 
using namespace cv;
 
int width, height;
int pic_info[3];
char pic_name[20];
Mat mat1;
IplImage src, *res, *roi;
 
void mySmooth(Mat mat1, Mat mat2, int flag, int width, int height){
	IplImage pI1 = mat1;	
	IplImage pI2 = mat2;
 
	cvSmooth(&pI1, &pI2, flag, width, height);
}
 
void mypic_merge(IplImage* src, IplImage* res, IplImage* dst){
	CvScalar s;
	int height = src->height;
	int width = src->width;
	int i, j;
 
	for(i=0;i<height;i++){
		for(j=0;j<width;j++){
			s = cvGet2D(res, i, j);
			if((s.val[0] == 0) && (s.val[1] == 0) && (s.val[2] == 0)){
				s = cvGet2D(src, i, j);	
			}
			cvSet2D(dst,i,j,s);
		}
	}
}
 
void on_mouse( int event, int x, int y, int flags, void* ustc)  
{
 
	if(event == CV_EVENT_LBUTTONDOWN){
		pic_info[0] = x;   /*width1*/
		pic_info[1] = y;   /*height1*/
		pic_info[2] = 0;   /*width2*/
		mat1=cv::imread(pic_name,1);  
		cv::imshow("1",mat1);
	}
	if(flags == CV_EVENT_FLAG_LBUTTON){
		x = abs(x - pic_info[0]);
		y = abs(y - pic_info[1]);
		pic_info[2] = (int)sqrt((x*x + y*y));
		mat1=cv::imread(pic_name,1);
		src = mat1;
 
		res = cvCreateImage(cvGetSize(&src), 8, 3);
		roi = cvCreateImage(cvGetSize(&src), 8, 1);
 
/**************取出圓形感興趣區域**********/
		cvZero(roi);
		cvZero(res);
		cvCircle(roi,cvPoint(pic_info[0], pic_info[1]), pic_info[2],CV_RGB(255, 255, 255),⑴, 8, 0);
		cvAnd(&src, &src, res, roi);    
/******************************************/
		mySmooth(mat1, mat1,CV_GAUSSIAN, 23, 23);
		mypic_merge(&src, res, res);
 
		cvNamedWindow("2", 1);
		cvShowImage("2", res);
	}
	printf("circle:%d
", pic_info[2]);
} 
 
int main(int argc,char *argv[]){
	memcpy(pic_name,argv[1], sizeof(argv[1]));
	mat1 = imread(pic_name, 1);
	width = mat1.rows;
	height = mat1.cols;
 
	imshow("1", mat1);
	cvSetMouseCallback("1", on_mouse, NULL);
	cv::waitKey(0);
	return 0;
}
  如上,就可以實現在圖象窗口"1"中,通過鼠標點擊和拖拽,控制景深圓圈變化。
生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 香蕉在线精品视频在线观看2 | 亚洲国产精品一区二区三区在线观看 | 久久亚洲国产成人影院 | 性生生活三级视频在线观看 | 欧美一区二区三区视频在线 | 在线亚洲国产精品区 | 亚洲国产最新 | 久久久精品成人免费看 | 欧美精品一区二区三区四区 | 毛色毛片免费观看 | 午夜视频网站 | 欧美性受xxxx黑人xxxx | 午夜宅男在线视频 | 欧美一区二区三区在线观看免费 | 日本一二三四区免费视频 | 亚洲精品永久www忘忧草 | 伊人久久中文大香线蕉综合 | 欧美八区 | 亚色官网| 欧美18videosex性欧美tube1080 | 免费国产福利 | 操人视频在线观看 | 免费日本网站 | 欧美人与牲动交xxxxbbbb | 欧美日韩一区二区三区免费 | 亚洲精品综合一区二区三区 | 国产日本高清 | 午夜视频在线免费 | free性日韩 | xxxxxx国产对白 | 亚洲人成高清 | 亚洲精品国产成人一区二区 | 毛片一级在线 | 黑人巨大三根一起进hd | 一级毛片毛片毛片毛毛片 | 最近中文字幕高清中文字幕网1 | 久久国产免费 | 亚洲精品美女视频 | 久久久成人网 | oo0xxxx性欧美野外 | 四虎一区二区三区精品 |