當(dāng)前位置:首頁 > 芯聞號 > 充電吧
[導(dǎo)讀]初次接觸OpenCV在用OpenCV做一些東西之前,要先配置一下開發(fā)環(huán)境,由于我的常使用的是Qt ,就以Qt作為例子。這是我的pro配置:#------------------------------


初次接觸OpenCV


在用OpenCV做一些東西之前,要先配置一下開發(fā)環(huán)境,由于我的常使用的是Qt ,就以Qt作為例子。


這是我的pro配置:



#-------------------------------------------------
#
#?Project?created?by?QtCreator?2016-04-09T11:40:17
#
#-------------------------------------------------

QT???????+=?core

QT???????-=?gui

TARGET?=?Example4
CONFIG???+=?console
CONFIG???-=?app_bundle

TEMPLATE?=?app

INCLUDEPATH?+=?-L?D:OpenSourceopencvbuildinclude?
???????????????-L?D:OpenSourceopencvbuildincludeopencv?
???????????????-L?D:OpenSourceopencvbuildincludeopencv2
LIBS?+=?D:OpenSourceopencvbuildx86vc12libopencv_core2410.lib
LIBS?+=?D:OpenSourceopencvbuildx86vc12libopencv_highgui2410.lib
LIBS?+=?D:OpenSourceopencvbuildx86vc12libopencv_imgproc2410.lib
LIBS?+=?D:OpenSourceopencvbuildx86vc12libopencv_photo2410.lib

SOURCES?+=?main.cpp




INCLUDEPATH 中是必要的頭文件包含,使用的是整體文件夾包含,LIBS是需要的LIB,使用的具體路徑。


下面程序演示了對圖片的一些簡單處理,包括放大,縮小,平滑,和邊緣檢測并輸出一個單通道的圖像


#include#include?"iostream"
#include?"cxcore.h"
#include?"cv.h"
#include?"highgui.h"

//對圖片進行縮操作
IplImage*?doPyrDown(IplImage*?in,?int?filter?=?IPL_GAUSSIAN_5x5)
{
????IplImage*?out?=?cvCreateImage(cvSize(in->width/2,in->height/2),
??????????????????????????????????in->depth,
??????????????????????????????????in->nChannels);
????cvPyrDown(in,out);
????return?out;
}
//對圖片進行放操作
IplImage*?doPyrUp(IplImage*?in,?int?filter?=?IPL_GAUSSIAN_5x5)
{
????IplImage*?out?=?cvCreateImage(cvSize(in->width?*?2,in->height?*?2),
??????????????????????????????????in->depth,
??????????????????????????????????in->nChannels);
????cvPyrUp(in,out);
????return?out;
}
//進行邊緣檢測輸出一個單通道圖像(灰色)
IplImage*?doCanny(IplImage*?in,double?lowThresh,double?highThresh,double?aperture)
{
????if(in->nChannels?!=?1)
????????return?0;

????IplImage*?out?=?cvCreateImage(cvGetSize(in),IPL_DEPTH_8U,1);

????cvCanny(in,out,lowThresh,highThresh,aperture);
????return?out;
}

int?main(int?argc,?char**?argv)
{
????QCoreApplication?a(argc,?argv);

????//Create?four?windows?to?show?our?input?image?and?output?iamge
????cvNamedWindow("Example4_in",CV_WINDOW_AUTOSIZE);
????cvNamedWindow("Example4_out1",CV_WINDOW_AUTOSIZE);
????cvNamedWindow("Example4_out2",CV_WINDOW_AUTOSIZE);
????cvNamedWindow("Example4_out3",CV_WINDOW_AUTOSIZE);
????cvNamedWindow("Example4_out4",CV_WINDOW_AUTOSIZE);

????//show?the?input?image
????IplImage*?inImage?=?cvLoadImage("C:/Users/Administrator/Documents/Example4/debug/test.png");
????cvShowImage("Example4_in",inImage);

????//do?the?pyrdown?and?show?the?image
????IplImage*?outImage1?=?doPyrDown(inImage);
????cvShowImage("Example4_out1",outImage1);

????//do?the?pyrup?and?show?the?image
????IplImage*?outImage2?=?doPyrUp(inImage);
????cvShowImage("Example4_out2",outImage2);

????//do?the?smoothing?and?show?the?smoothed?image
????IplImage*?outImage3?=?cvCreateImage(cvGetSize(inImage),IPL_DEPTH_8U,3);
????cvSmooth(inImage,outImage3,CV_GAUSSIAN,3,3);
????cvShowImage("Example4_out3",outImage3);

????//do?the?canny
????IplImage*?outImage4?=?doCanny(inImage,10,100,3);
????cvShowImage("Example4_out4",outImage4);

????//Be?tidy
????cvWaitKey(0);
????cvReleaseImage(&outImage1);
????cvReleaseImage(&outImage2);
????cvReleaseImage(&outImage3);
????cvReleaseImage(&outImage4);
????cvDestroyWindow("Example4_in");
????cvDestroyWindow("Example4_out1");
????cvDestroyWindow("Example4_out2");
????cvDestroyWindow("Example4_out3");
????cvDestroyWindow("Example4_out4");

????return?a.exec();
}



下面程序演示了對于視頻的打開,并復(fù)制



#include#include?"iostream"
//OpenCV
#include"cxcore.h"
#include?"cv.h"
#include?"highgui.h"

/****************************************************************

??首先打開一個視頻文件,讀取文件內(nèi)容,將每一幀圖像轉(zhuǎn)化為對數(shù)
??極坐標(biāo)格式(就像你的眼睛真正能看到的),最后將轉(zhuǎn)化后的圖像
??序列寫入新的視頻文件中

*****************************************************************/

int?main(int?argc,?char?*argv[])
{
????QCoreApplication?a(argc,?argv);

????CvCapture*?capture?=?0;
????capture?=?cvCreateFileCapture(argv[1]);//input?video
????if(!capture)
????{
????????return?-1;
????}

????IplImage*?bgr_frame?=?cvQueryFrame(capture);//init?the?video?read
????double?fps?=?cvGetCaptureProperty(capture,
??????????????????????????????????????CV_CAP_PROP_FPS);
????CvSize?size?=?cvSize(
????????????????(int)cvGetCaptureProperty(capture,CV_CAP_PROP_FRAME_WIDTH),
????????????????(int)cvGetCaptureProperty(capture,CV_CAP_PROP_FRAME_HEIGHT));
????CvVideoWriter*?writer?=?cvCreateVideoWriter(argv[2],
????????????????????????????????????????????????CV_FOURCC('M','J','P','G'),
????????????????????????????????????????????????fps,
????????????????????????????????????????????????size);
?????IplImage*?logpolar_frame?=?cvCreateImage(
?????????????????size,
?????????????????IPL_DEPTH_8U,
?????????????????3);
/*******************************************************************?
?????void?cvLogPolar(?const?CvArr*?src,?
??????????????????????CvArr*?dst,?
??????????????????????CvPoint2D32f?center,?
??????????????????????double?M,?
??????????????????????int?flags=CV_INTER_LINEAR+CV_WARP_FILL_OUTLIERS?);
src?輸入圖像。?dst?輸出圖像。?center?變換的中心,輸出圖像在這里最精確。?M?幅度的尺度參數(shù),見下面公式。?flags?插值方法和以下選擇標(biāo)志的結(jié)合
CV_WARP_FILL_OUTLIERS?-填充輸出圖像所有像素,如果這些點有和外點對應(yīng)的,則置零。
CV_WARP_INVERSE_MAP?-?表示矩陣由輸出圖像到輸入圖像的逆變換,并且因此可以直接用于像素插值。否則,函數(shù)從map_matrix中尋找逆變換。
fillval?用于填充外點的值。

此函數(shù)模仿人類視網(wǎng)膜中央凹視力,并且對于目標(biāo)跟蹤等可用于快速尺度和旋轉(zhuǎn)變換不變模板匹配。
************************************************************************/
??????????????????????
?????while(?bgr_frame?!=?NULL)
?????{
?????????cvLogPolar(bgr_frame,logpolar_frame,
????????????????????cvPoint2D32f(bgr_frame->width/2,
????????????????????????????????bgr_frame->height/2),
????????????????????40,
????????????????????CV_INTER_LINEAR+CV_WARP_FILL_OUTLIERS);
?????????cvWriteFrame(writer,logpolar_frame);
?????}
?????cvReleaseVideoWriter(&writer);
?????cvReleaseImage(&logpolar_frame);
?????cvReleaseCapture(&capture);

????return?a.exec();
}



在工程構(gòu)建之后,要想運行成功,必須把DLL拷貝到debug中去。



本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉