自從進(jìn)入3.X時(shí)代以后,OpenCV將代碼庫分成了兩部分,分別是穩(wěn)定的核心功能庫和試驗(yàn)性質(zhì)的contrib庫。
并且從3.1以后,編譯好的版本中就沒有現(xiàn)成的x86平臺的庫了,想用就必須自己從源碼編譯。
之前都是直接下載編譯好的版本。為了體驗(yàn)完整版本的OpenCV,也為了跟進(jìn)后續(xù)的版本更新,只好硬著頭皮來學(xué)一下怎么從源碼安裝OpenCV了。
1. 環(huán)境及準(zhǔn)備
- Windows 10
- VisualStudio 2013
- CMake 3.5
- OpenCV核心庫源碼
- OpenCV contrib庫源碼
2. 編譯及安裝
2.1 編譯
打開CMake GUI工具。
Where is the source code:
選擇D:/opencv
或其他的解壓目錄。Where to build the binaries:
選擇D:/opencv/build
或?qū)?yīng)的目錄。點(diǎn)擊
Congigure
按鈕,CMake會自己進(jìn)行配置。在彈出的對話框中選擇Visual Studio 12 2013
。
編譯過程中CMake會下載幾個(gè)文件,但是由于網(wǎng)絡(luò)問題,很難下載成功。
可以先從我的網(wǎng)盤分享(提取碼xrkm)中下載這幾個(gè)文件,然后放在對應(yīng)的opencv\3rdparty
文件夾下,然后進(jìn)行Congigure
操作。
初步配置完成后,在OPENCV_EXTREA_MODULES_PATH
選項(xiàng)中選擇D:/opencv_contrib/modules
,再次點(diǎn)擊Congigure
進(jìn)行配置。
如果配置完成沒有問題,則點(diǎn)擊Generate
進(jìn)行生成。
2.2 安裝
進(jìn)入D:/opencv/build
文件夾,打開新生成的OpenCV.sln
,分別在Debug和Release模式下Rebuild整個(gè)solution,然后在CMakeTargets工程中的INSTALL上右鍵選擇Project Only
->Build Only INSTALL
。
在D:/opencv/build/install
文件夾下面就會生成編譯好的opencv文件。
3. 系統(tǒng)配置
在VS的Property Manager
中找到Microsift.Cpp.Win32.user
配置文件,修改其中的設(shè)置,就不用每次新建一個(gè)項(xiàng)目就要改包含目錄和庫目錄等了。
為Include Directories
添加:
- D:\opencv\build\install\include
- D:\opencv\build\install\include\opencv
- D:\opencv\build\install\include\opencv2
為Library Directories
添加:
- D:\opencv\build\install\x86\vc12\lib
為Additional Dependencies
添加:
- D:\opencv\build\install\x86\vc12\lib*.lib
4. 測試
OpenCV官方文檔中關(guān)于contrib modules有一系列教程,其中有一個(gè)是關(guān)于Tracker模塊的,用來做目標(biāo)跟蹤。以此為例來測試contrib modules的調(diào)用。
為了方便運(yùn)行,對源碼做了稍許改動:
#include "stdafx.h"
#include "core/core.hpp"
#include "highgui/highgui.hpp"
#include "opencv2/tracking.hpp"
using namespace cv;
using namespace std;
int _tmain(int argc, _TCHAR* argv[])
{
Rect2d roi;
Mat frame;
Ptr<Tracker> tracker = Tracker::create("KCF");
VideoCapture cap("video.avi");
int fps = cap.get(CAP_PROP_FPS);
VideoWriter writer("r.avi", CV_FOURCC('D', 'I', 'V', 'X'), fps, Size(704, 576));
cap >> frame;
roi = Rect2d(335, 160, 75, 75);
tracker->init(frame, roi);
for (;;)
{
cap >> frame;
tracker->update(frame, roi);
rectangle(frame, roi, Scalar(255, 0, 0), 2, 1);
writer << frame;
imshow("tracker", frame);
if (waitKey(1) == 27)
{
cap.release();
writer.release();
break;
}
}
return 0;
}
最終的運(yùn)行效果如下,不管目標(biāo)跟蹤的效果如何,至少程序是可以運(yùn)行的了。