本ページは 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 トップページ