質問するログイン新規登録

回答編集履歴

5

refine

2016/11/15 02:57

投稿

yohhoy
yohhoy

スコア6191

answer CHANGED
@@ -24,7 +24,7 @@
24
24
 
25
25
  >「"普通のDSF"としてレジストリに登録するだけ」とありますが、レジストリに登録すれば関数を使えるのでそれを使ってプログラムを組んだ方が良いという意味でしょうか?
26
26
 
27
- いいえ。Direct ShowはCOM(Component Object Model)技術を利用して作られており、COMではクラスやインターフェイスをWindowsレジストリに予め登録しておく必要があります。言い換えると、DSF(DirectShowフィルタ)をレジストリに登録しておかないと、プログラムから部品として使うことができません。
27
+ いいえ。Direct ShowはCOM(Component Object Model)技術を利用して作られており、COMではクラスやインターフェイスをWindowsレジストリに予め登録しておく必要があります。言い換えると、DSF(DirectShowフィルタ)をレジストリに登録しておかないと、プログラムから部品として使うことができません。DirectShowを利用しなければ、レジストリ云々は気にしなくて良くなります。
28
28
 
29
29
  > Win32APIを用いたデスクトップキャプチャの方をお勧めするとありますが、GetDesktopWindow関数を用いたキャプチャを行うということでしょうか?Win32apiを用いたデスクトップキャプチャというのがどういうことなのか気になります。
30
30
 
@@ -32,4 +32,6 @@
32
32
 
33
33
  > まだ調べている最中ですが、元のモニターの動画とのタイムラグがあると困るので、動画を滑らかにタイムラグがなくキャプチャすることは可能なのかが気がかりです。
34
34
 
35
- Direct Showはマルチメディア処理フレームワークの一種です。PushSourceFiltersSampleを用いてDirectShow経由でOpenCVにキャプチャ映像を取り込む方式でもよいのですが、DirectShowという一般化されたフレームワークを経由する分、確実に処理オーバーヘッドが存在します。同じ処理を行うならば、そのようなフレームワークを経由しない方が処理負荷がずっと小さくなります。
35
+ Direct Showはマルチメディア処理フレームワークの一種です。PushSourceFiltersSampleを用いてDirectShow経由でOpenCVにキャプチャ映像を取り込む方式でもよいのですが、DirectShowという一般化されたフレームワークを経由する分、確実に処理オーバーヘッドが存在します。同じ処理を行うならば、そのようなフレームワークを経由しない方が処理負荷がずっと小さくなります。
36
+
37
+ 「デスクトップキャプチャをOpenCVで解析したい」という目的に対して、実装も大変で処理オーバーヘッドが増えるDirectShowを無理に使うのは得策ではないという意見です。

4

update

2016/11/15 02:57

投稿

yohhoy
yohhoy

スコア6191

answer CHANGED
@@ -17,4 +17,19 @@
17
17
 
18
18
  上記にごちゃごちゃ書きましたが、「デスクトップキャプチャをOpenCVで解析したい」という目的であれば、DSF経由ではなくWin32APIを使ってデスクトップキャプチャを行い、得られたビットマップデータを`cv::Mat`に変換して扱う方式をお勧めします。
19
19
 
20
- Windows OS環境依存という点ではDSF利用もネイティブAPIも変わりませんし、何より正しく動作するDSFを作るのは結構難しいです。(技術的難易度よりも信頼できる資料があまりにも少ないのです。Microsoft提供のサンプルコードやドキュメントにも結構嘘があり、実際に他モジュールと組み合わせて動かすと障害が出たりします。)
20
+ Windows OS環境依存という点ではDSF利用もネイティブAPIも変わりませんし、何より正しく動作するDSFを作るのは結構難しいです。(技術的難易度よりも信頼できる資料があまりにも少ないのです。Microsoft提供のサンプルコードやドキュメントにも結構嘘があり、実際に他モジュールと組み合わせて動かすと障害が出たりします。)
21
+
22
+ ---
23
+ (コメントに対する回答追記)
24
+
25
+ >「"普通のDSF"としてレジストリに登録するだけ」とありますが、レジストリに登録すれば関数を使えるのでそれを使ってプログラムを組んだ方が良いという意味でしょうか?
26
+
27
+ いいえ。Direct ShowはCOM(Component Object Model)技術を利用して作られており、COMではクラスやインターフェイスをWindowsレジストリに予め登録しておく必要があります。言い換えると、DSF(DirectShowフィルタ)をレジストリに登録しておかないと、プログラムから部品として使うことができません。
28
+
29
+ > Win32APIを用いたデスクトップキャプチャの方をお勧めするとありますが、GetDesktopWindow関数を用いたキャプチャを行うということでしょうか?Win32apiを用いたデスクトップキャプチャというのがどういうことなのか気になります。
30
+
31
+ 仰る通り、GetDesktopWindow関数を利用したデスクトップキャプチャを意図していました。同関数はWin32API(もしくは単にWindows API)の一種です。
32
+
33
+ > まだ調べている最中ですが、元のモニターの動画とのタイムラグがあると困るので、動画を滑らかにタイムラグがなくキャプチャすることは可能なのかが気がかりです。
34
+
35
+ Direct Showはマルチメディア処理フレームワークの一種です。PushSourceFiltersSampleを用いてDirectShow経由でOpenCVにキャプチャ映像を取り込む方式でもよいのですが、DirectShowという一般化されたフレームワークを経由する分、確実に処理オーバーヘッドが存在します。同じ処理を行うならば、そのようなフレームワークを経由しない方が処理負荷がずっと小さくなります。

3

update

2016/11/15 02:52

投稿

yohhoy
yohhoy

スコア6191

answer CHANGED
@@ -9,4 +9,12 @@
9
9
 
10
10
  一方、[OpenCVのDSFサポート実装](https://github.com/opencv/opencv/blob/3.1.0/modules/videoio/src/cap_dshow.cpp#L1329-L1414)では[ビデオキャプチャデバイス`CLSID_VideoInputDeviceCategory`](https://msdn.microsoft.com/ja-jp/library/cc370645.aspx)の列挙を行います。この関数で列挙されるようにレジストリ登録する必要があります。
11
11
 
12
- DSF登録については [カテゴリを指定してフィルタを登録する](http://blog.firefly-vj.net/2008/07/01/directshow-filter-regist-specified-category.html) を参考にください。
12
+ DSF登録については [カテゴリを指定してフィルタを登録する](http://blog.firefly-vj.net/2008/07/01/directshow-filter-regist-specified-category.html) を参考にください。
13
+
14
+ ---
15
+
16
+ > デスクトップの映像をキャプチャしてOpenCVで解析することを目的としています。
17
+
18
+ 上記にごちゃごちゃ書きましたが、「デスクトップキャプチャをOpenCVで解析したい」という目的であれば、DSF経由ではなくWin32APIを使ってデスクトップキャプチャを行い、得られたビットマップデータを`cv::Mat`に変換して扱う方式をお勧めします。
19
+
20
+ Windows OS環境依存という点ではDSF利用もネイティブAPIも変わりませんし、何より正しく動作するDSFを作るのは結構難しいです。(技術的難易度よりも信頼できる資料があまりにも少ないのです。Microsoft提供のサンプルコードやドキュメントにも結構嘘があり、実際に他モジュールと組み合わせて動かすと障害が出たりします。)

2

append link

2016/11/14 06:57

投稿

yohhoy
yohhoy

スコア6191

answer CHANGED
@@ -7,4 +7,6 @@
7
7
 
8
8
  Windows SDK付属サンプル [Push Source Filters Sample](https://msdn.microsoft.com/ja-jp/library/windows/desktop/dd377481.aspx) でしょうか?同DSF(DirectShow Filter)の`DllRegisterServer`関数を見ると、単に`AMovieDllRegisterServer2`に処理委譲しているだけですね。この関数は"普通のDSF"としてレジストリに登録するだけです。
9
9
 
10
- 一方、[OpenCVのDSFサポート実装](https://github.com/opencv/opencv/blob/3.1.0/modules/videoio/src/cap_dshow.cpp#L1329-L1414)では[ビデオキャプチャデバイス`CLSID_VideoInputDeviceCategory`](https://msdn.microsoft.com/ja-jp/library/cc370645.aspx)の列挙を行います。この関数で列挙されるようにレジストリ登録する必要があります。
10
+ 一方、[OpenCVのDSFサポート実装](https://github.com/opencv/opencv/blob/3.1.0/modules/videoio/src/cap_dshow.cpp#L1329-L1414)では[ビデオキャプチャデバイス`CLSID_VideoInputDeviceCategory`](https://msdn.microsoft.com/ja-jp/library/cc370645.aspx)の列挙を行います。この関数で列挙されるようにレジストリ登録する必要があります。
11
+
12
+ DSF登録については [カテゴリを指定してフィルタを登録する](http://blog.firefly-vj.net/2008/07/01/directshow-filter-regist-specified-category.html) を参考にください。

1

update

2016/11/14 06:31

投稿

yohhoy
yohhoy

スコア6191

answer CHANGED
@@ -1,3 +1,10 @@
1
1
  一般に、OpenCVライブラリはC/C++ヘッダファイル+ライブラリ(バイナリ)形式で提供されます。内部実装コードまで参照したい場合は、OpenCVソースコード一式を取得してください。
2
2
 
3
- VideoCaptureクラス内部実装は [modules/videoio/src/cap.cpp](https://github.com/opencv/opencv/blob/3.1.0/modules/videoio/src/cap.cpp#L565-L568) にあります(OpenCV 3.1の場合)。DirectShowの場合、実際の処理はさらに [modules/videoio/src/cap_dshow.cpp](https://github.com/opencv/opencv/blob/3.1.0/modules/videoio/src/cap_dshow.cpp#L3141-L3151) に委譲されます。
3
+ VideoCaptureクラス内部実装は [modules/videoio/src/cap.cpp](https://github.com/opencv/opencv/blob/3.1.0/modules/videoio/src/cap.cpp#L565-L568) にあります(OpenCV 3.1の場合)。DirectShowの場合、実際の処理はさらに [modules/videoio/src/cap_dshow.cpp](https://github.com/opencv/opencv/blob/3.1.0/modules/videoio/src/cap_dshow.cpp#L3141-L3151) に委譲されます。
4
+
5
+ ---
6
+ > WindowsSDKのサンプルソースなので、自前と言うことになると思います。
7
+
8
+ Windows SDK付属サンプル [Push Source Filters Sample](https://msdn.microsoft.com/ja-jp/library/windows/desktop/dd377481.aspx) でしょうか?同DSF(DirectShow Filter)の`DllRegisterServer`関数を見ると、単に`AMovieDllRegisterServer2`に処理委譲しているだけですね。この関数は"普通のDSF"としてレジストリに登録するだけです。
9
+
10
+ 一方、[OpenCVのDSFサポート実装](https://github.com/opencv/opencv/blob/3.1.0/modules/videoio/src/cap_dshow.cpp#L1329-L1414)では[ビデオキャプチャデバイス`CLSID_VideoInputDeviceCategory`](https://msdn.microsoft.com/ja-jp/library/cc370645.aspx)の列挙を行います。この関数で列挙されるようにレジストリ登録する必要があります。