cvui:OpenCVのための軽量GUIライブラリ

OpenCVを使ったプログラムで各種入力パラメータをいじるのに便利そうなGUIライブラリを見つけた。
このcvuiは、ヘッダーファイルcvui.hのみの軽量なライブラリで、クロスプラットフォーム(Windows, OSX, Linux)にビルドできる。そして依存するライブラリはOpenCV(バージョン2.xまたは3.x)のみ!
MITライセンスなので、ライセンスと著作権を表示すれば商用利用も可能。

cvui

cvui

cvuiは、OpenCVの描画機能をベースとした(とても)シンプルなUIライブラリです。
imguiなど、他のUIライブラリでOpenCVアプリを開発する場合、OpenGLなどのバックエンドグラフィックス機能も別途有効にする必要がありますが、cvuiではそんな必要がありません。
cvuiはOpenCVの描画機能のみで全ての描画処理を行います。(別途OpenGLやQtはいりません)

アプリケーション開発というほど大げさじゃなく、ちょっとモジュールレベルで動作を試したいけど、cv::highguiだけでは微妙にやりづらい時って結構あるから便利そう。

ソースコードはGitHubにある↓
https://github.com/Dovyski/cvui


スポンサーリンク


というのは毎度お馴染みこのブログで知った情報ですが↓
https://www.learnopencv.com/cvui-gui-lib-built-on-top-of-opencv-drawing-primitives/


スポンサーリンク

cvuiの特長

  • 軽量・シンプルで使いやすいインターフェイス
  • 追加の依存ライブラリは必要ない(OpenCVのみに依存)
  • OpenCVの描画機能のみをベースとしている(OpenGLやQtなどは必要ない)
  • 馴染みやすくC言語ライクなAPI(クラスやオブジェクト、etc)
  • 各コンポーネントの位置を気にせず(rows/columnsを指定して)手軽に描画可能
  • MITライセンス

C言語ライクなのが良いことなのか意見が分かれそうだけど、習得コストが低いってことなんですかね。
imguiの使い方を勉強しようかと思ってたところだったけど、動作環境を構築して試すまでの手間を考えると、まずはcvuiの方が楽そうな感じ。

使い方のサンプルコードを見た感じだと、

cv::namedWindow(WINDOW_NAME);
cvui::init(WINDOW_NAME);

でウィンドウを定義し、cvui名前空間の関数を使ってcv::MatにGUI要素をどんどん突っ込んでいき、そのcv::Matを定義したウィンドウにcv::imshowで表示するだけだ。
何かUnityのOnGUI関数内に記述する行に似たテイストに感じる。


スポンサーリンク

関連記事

Iterator

ポリゴンジオメトリ処理ライブラリ『pmp-library (Polygon Mesh Process...

html5のcanvasの可能性

OpenCVで顔のランドマークを検出する『Facemark API』

ポリゴン用各種イテレータと関数セット

OpenCV 3.3.0-RCでsfmモジュールをビルド

BlenderでPhotogrammetryできるアドオン

書籍『OpenCV 3 プログラミングブック』を購入

Cartographer:オープンソースのSLAMライブラリ

3Dモデルを立体視で確認できるVRアプリを作っている

Unityで強化学習できる『Unity ML-Agents』

UnityでTweenアニメーションを実装できる3種類の無料Asset

OpenCV 3.1のsfmモジュールのビルド再び

UnityのTransformクラスについて調べてみた

GoogleのDeep Learning論文

OpenCVでPhotoshopのプラグイン開発

Facebookの顔認証技術『DeepFace』

viser:Pythonで使える3D可視化ライブラリ

画像認識による位置情報取得 - Semi-Direct Monocular Visual Odome...

OpenCVで顔のモーフィングを実装する

書籍『イラストで学ぶ ディープラーニング』

Python拡張モジュールのWindows用インストーラー配布サイト

OpenCVで動画の手ぶれ補正

Pythonの自然言語処理ライブラリ『NLTK(Natural Language Toolkit)』

池袋パルコで3Dのバーチャルフィッティング『ウェアラブル クロージング バイ アーバンリサーチ』

Open3D:3Dデータ処理ライブラリ

NeRF (Neural Radiance Fields):深層学習による新規視点合成

Manim:Pythonで使える数学アニメーションライブラリ

UnityからROSを利用できる『ROS#』

Google XML Sitemap Generatorプラグインを3.4.1へダウングレード

HD画質の無駄遣い その2

Faster R-CNN:ディープラーニングによる一般物体検出手法

HD画質の無駄遣い

ブラウザ操作自動化ツール『Selenium』を試す

OpenCVのfindEssentialMat関数を使ったサンプルを読んでみる

プログラムによる景観の自動生成

顔検出・認識のAPI・ライブラリ・ソフトウェアのリスト

konashiのサンプルコードを動かしてみた

Unityの薄い本

libigl:軽量なジオメトリ処理ライブラリ

R-CNN (Regions with CNN features):ディープラーニングによる一般物体...

pythonもかじってみようかと

コメント

  1. […] OpenCVのための軽量GUIライブラリ『cvui』 […]