本ページは i-PRO株式会社 の有志メンバーにより記載されたものです。
本ページの情報は ライセンス に記載の条件で提供されます。
本ページでは、i-PRO カメラとLinux OS の PCを RTSP(H.264/H.265) で接続して映像を画面へ表示するプログラムを c++ で作成します。
Python の記事は こちら を参照ください。
i-PRO カメラと接続するための RTSP 表記仕様は こちら を参照ください。
Linux の c++ と OpenCV を使って、PC と i-PRO カメラを RTSP(H.264/H.265) で接続して映像表示してみます。
開発環境 : | GNU build-essensial CMake |
9.4.0 12.8 3.16.3 |
ライブラリ : | OpenCV | 4.6.0 |
OS : | ubuntu | 20.04 LTS |
以下のコマンドを実施して環境を準備します。
sudo apt update -y && sudo apt upgrade -y sudo apt install build-essential libopencv-dev cmake -y sudo apt update -y && sudo apt upgrade -y
サンプルプログラムのソースコードを以下に示します。
[プログラムソース "opencv_rtsp.cpp"]
/* ====================================================================================== [Abstract] Try connecting to an i-PRO camera with RTSP. RTSP で i-PRO カメラと接続してみる [Details] Let's try first. まずはやってみる [Library install] sudo apt update -y && sudo apt upgrade -y sudo apt install build-essential libopencv-dev cmake -y sudo apt update -y && sudo apt upgrade -y ====================================================================================== */ #include <iostream> #include <opencv2/opencv.hpp> #include <opencv2/core/utility.hpp> const std::string user_id = "user_id"; // Change to match your camera setting const std::string user_pw = "user_pw"; // Change to match your camera setting const std::string host = "192.168.0.10"; // Change to match your camera setting const std::string winname = "VIDEO"; // Window title const std::string url = "rtsp://" + user_id + ":" + user_pw + "@" + host + "/MediaInput/stream_1"; int main(int argc, const char* argv[]) { cv::VideoCapture cap(url); cv::Mat frame; char ret; while (true) { cap >> frame; if (frame.empty()) { break; } // Please modify the value to fit your PC screen size. resize(frame, frame, cv::Size(), 0.5, 0.5); // Setting by magnification. // Display video. cv::imshow(winname, frame); ret = (char)cv::waitKey(1); // necessary to display the video by cv::imshow(). // Press the "q" key to finish. if (ret == 'q') { break; } } cap.release(); cv::destroyAllWindows(); return EXIT_SUCCESS; }
ビルドにおいて環境依存を極力するなくするため、以下の手順でビルドします。
ソースコード(opencv_rtsp.cpp)と同じディレクトリに以下のように中身が書かれたCMakeLists.txtを配置してください。
CMake の知識がある方は、内容をカスタマイズしてお使いください。
["CMakeLists.txt"]
# 変数SOURCE_CORDEを宣言し、ソースコードのファイル名の拡張子無くした値を入れる。 # cmake -D SOURCE_CODE=(ソース名)で上書き可 set(SOURCE_CODE opencv_rtsp CACHE NAME "Target object name") # CMakeの最低バージョンを記述 cmake_minimum_required(VERSION 2.8) # ソリューション名を指定 project( ${SOURCE_CODE} ) # OpenCVのパッケージを探す find_package( OpenCV REQUIRED ) #ヘッダファイルのパスを指定 include_directories( ${OpenCV_INCLUDE_DIRS} ) # 実行ファイル名とソース指定(ここではソースと同じ名前の実行ファイルを作ります) add_executable( ${SOURCE_CODE} ${SOURCE_CODE}.cpp ) #リンク先のライブラリを指定 target_link_libraries( ${SOURCE_CODE} ${OpenCV_LIBS} )
ビルド環境を作成してアプリケーションを構築するため、以下のコマンドを実施します。
mkdir build && cd build cmake .. make
これにより、buildディレクトリに[opencv_rtsp]という実行ファイルができましたので、以下のようにコマンドを実施すればアプリケーションが実施されます
./opencv_rtsp
ソースコードの変更をする場合は、すでにビルド環境ができていますので、buildディレクトリで以下のようにすれば更新が可能です。
ライブラリを追加する場合は CMakeLists.txtの追記を行い、build ディレクトリを削除してcmakeをやり直してください。
make clean make
本ページで紹介のソースコードは、下記 github より取得できます。
下記 github のソースコードと本ページの内容は差異がある場合があります。
i-pro-corp/cpp-examples: c++ sample programs for i-PRO camera. (github.com)
本ページの情報は、特記無い限り下記ライセンスで提供されます。
2023/3/22 | - | 新規作成, | 蓬田 康雄 |
i-PRO - Programming Items トップページ