OpenCVを使ったプログラムで各種入力パラメータをいじるのに便利そうなGUIライブラリを見つけた。
このcvuiは、ヘッダーファイルcvui.hのみの軽量なライブラリで、クロスプラットフォーム(Windows, OSX, Linux)にビルドできる。そして依存するライブラリはOpenCV(バージョン2.xまたは3.x)のみ!
MITライセンスなので、ライセンスと著作権を表示すれば商用利用も可能。
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関数内に記述する行に似たテイストに感じる。
関連記事
Pylearn2:ディープラーニングに対応したPythonの...
DCGAN (Deep Convolutional GAN)...
WordPressのテーマを自作する
RSSフィードを読込んで表示するWordpressプラグイン...
Unityの薄い本
Open Shading Language (OSL)
RefineNet (Multi-Path Refineme...
Paul Debevec
書籍『ROSプログラミング』
Iterator
機械学習について最近知った情報
UnityでLight Shaftを表現する
フィーリングに基づくタマムシの質感表現
WordPressのサーバ引っ越し方法を考える
TeleSculptor:空撮動画からPhotogramme...
TorchStudio:PyTorchのための統合開発環境と...
OpenCV 3.1のsfmモジュールを試す
Gource:バージョン管理の履歴を可視化するツール
GeoGebra:無料で使える数学アプリ
法線マップを用意してCanvas上でShadingするサンプ...
iOSデバイスのためのフィジカル・コンピューティングツールキ...
ZBrushのZScript入門
機械学習手法『Random Forest』
R-CNN (Regions with CNN featur...
NumSharp:C#で使えるNumPyライクな数値計算ライ...
Pythonのソースコードに特化した検索エンジン『Nulle...
Math.NET Numerics:Unityで使える数値計...
Kubric:機械学習用アノテーション付き動画生成パイプライ...
Live CV:インタラクティブにComputer Visi...
ブログのデザイン変えました
Amazon EC2ログイン用の秘密鍵を無くした場合の対処方...
顔画像処理技術の過去の研究
C++ 標準テンプレートライブラリ (STL)
Google Chromecast
顔検出・認識のAPI・ライブラリ・ソフトウェアのリスト
画像認識による位置情報取得 - Semi-Direct Mo...
OANDAのfxTrade API
iPadをハンディ3Dスキャナにするガジェット『iSense...
hloc:SuperGlueで精度を向上させたSfM・Vis...
Faster R-CNN:ディープラーニングによる一般物体検...
立体視を試してみた
Mayaのレンダリング アトリビュート



コメント
[…] OpenCVのための軽量GUIライブラリ『cvui』 […]