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関数内に記述する行に似たテイストに感じる。

関連記事

ArUco:OpenCVベースのコンパクトなARライブラリ

MB-Lab:Blenderの人体モデリングアドオン

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

Mask R-CNN:ディープラーニングによる一般物体検出・Instance Segmentatio...

C++始めようと思うんだ

PyTorch3D:3Dコンピュータービジョンライブラリ

科学技術計算向けスクリプト言語『Julia』

今年もSSII

Python.NET:Pythonと.NETを連携させるパッケージ

Pix2Pix:CGANによる画像変換

Theia:オープンソースのStructure from Motionライブラリ

ニューラルネットワークで画像分類

Raspberry PiのGPIOを操作するPythonライブラリ『RPi.GPIO』の使い方

SSII2014 チュートリアル講演会の資料

WordPress on Windows Azure

MFnMeshクラスのsplit関数

iPadをハンディ3Dスキャナにするガジェット『iSense 3D Scanner』

OpenCVのバージョン3が正式リリースされたぞ

IronPythonを使ってUnity上でPythonのコードを実行する

AndroidもopenGLも初心者さ (でもJavaは知ってるよ)

MRenderUtil::raytrace

OpenCVの顔検出過程を可視化した動画

Raspberry Pi 2のGPIOピン配置

UnityのGameObjectの向きをScriptで制御する

Unityで学ぶC#

3Dスキャンに基づくプロシージャルフェイシャルアニメーション

Webサイトのワイヤーフレームが作成できるオンラインツール

GoogleのDeep Learning論文

フォトンの放射から格納までを可視化した動画

WordPressプラグインによるサイトマップの自動生成

SONY製のニューラルネットワークライブラリ『NNabla』

Googleが画像解析旅行ガイドアプリのJetpac社を買収

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

顔画像処理技術の過去の研究

Mayaのシェーディングノードの区分

続・ディープラーニングの資料

SONYの自律型エンタテインメントロボット『aibo』

Autodesk Mementoでゴジラを3次元復元する

Quartus II

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

Pythonのソースコードに特化した検索エンジン『Nullege』

iOSデバイスと接続して連携するガジェットの開発方法

コメント

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