您好,登錄后才能下訂單哦!
本篇文章為大家展示了如何進行TX1使用OpenCV3.1實時采集視頻圖像的分析,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
嵌入式平臺(Target): Jeston TX1
OpenCV: OpenCV3.1
攝像頭: USB 800W攝像頭
Jetpack3.0安裝的OpenCV是OpenCV2.4.13,OpenCV2.4.13對于USB攝像頭支持不好。NVIDIA以后更新的Jetpack會解決對USB攝像頭支持不好的問題,在官方解決之前,一個臨時的解決方案就是自己編譯OpenCV3.1。
URL : http://www.opencv.org/releases.html
點擊Sources下載源碼:
# Some general development librariessudo apt-get install -y build-essential make cmake cmake-curses-gui g++# libav video input/output development librariessudo apt-get install -y libavformat-dev libavutil-dev libswscale-dev# Video4Linux camera development librariessudo apt-get install -y libv4l-dev# Eigen3 math development librariessudo apt-get install -y libeigen3-dev# OpenGL development libraries (to allow creating graphical windows)sudo apt-get install -y libglew1.6-dev# GTK development libraries (to allow creating graphical windows)sudo apt-get install -y libgtk2.0-dev
cd ~ mkdir src cd src unzip ~/Downloads/opencv-3.1.0.zip cd opencv-3.1.0mkdir build cd build cmake -DWITH_CUDA=ON -DCUDA_ARCH_BIN="5.3" -DCUDA_ARCH_PTX="" -DBUILD_TESTS=OFF -DBUILD_PERF_TESTS=OFF -DCUDA_FAST_MATH=ON -DCMAKE_INSTALL_PREFIX=/home/ubuntu/opencv-3.1.0 ..make -j4 install
cd ~/src/opencv-3.1.0/samples/gpu g++ -o hog -I /home/ubuntu/opencv-3.1.0/include -O2 -g -Wall hog.cpp -L /home/ubuntu/opencv-3.1.0/lib -lopencv_core -lopencv_imgproc -l opencv_flann -l opencv_imgcodecs -lopencv_videoio -lopencv_highgui -lopencv_ml -lopencv_video -lopencv_objdetect -lopencv_photo -lopencv_features2d -lopencv_calib3d -lopencv_stitching -lopencv_videostab -lopencv_shape -lopencv_cudaobjdetect -lopencv_cudawarping -lopencv_cudaimgprocexport LD_LIBRARY_PATH=/home/ubuntu/opencv-3.1.0/lib:$LD_LIBRARY_PATH./hog --camera 0
export LD_LIBRARY_PATH=/home/ubuntu/opencv-3.1.0/lib:$LD_LIBRARY_PATH:添加LIBARARY,這個只是臨時添加,永久添加可以放到~/.bashrc中,并使用source ~/.bashrc“激活”設置的環境變量;
./hog –camera 0:最后一個參數0,代表使用/dev/video0設備,如果TX1插上板載的CSI攝像頭,又插上USB攝像頭,這個0,應該改為1。可以通過ls /dev/ | grep video*,查看有那些video設備。
#include <stdio.h> #include <opencv2/opencv.hpp> using namespace cv; using namespace std; int main(int argc, char** argv) { VideoCapture cap("nvcamerasrc ! video/x-raw(memory:NVMM), width=(int)1280, height=(int)720,format=(string)I420, framerate=(fraction)24/1 ! nvvidconv flip-method=2 ! video/x-raw, format=(string)BGRx ! videoconvert ! video/x-raw, format=(string)BGR ! appsink"); if (!cap.isOpened()) { cout << "Failed to open camera." << endl; return -1; } for(;;) { Mat frame; cap >> frame; imshow("original", frame); //waitKey(1); if(waitKey(30) >= 0) break; } return 0; }
PS : 陽光原因,圖像有些泛白,見諒
在make的時候,我們可能遇到如下error:
解決辦法:需要修改一處源碼,在graphcuts.cpp中將
#if !defined (HAVE_CUDA) || defined (CUDA_DISABLER)
改為:
#if !defined (HAVE_CUDA) || defined (CUDA_DISABLER) || (CUDART_VERSION >= 8000)
如下圖所示:
上述內容就是如何進行TX1使用OpenCV3.1實時采集視頻圖像的分析,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。