このプラグインは、デバイスのオーディオ、イメージ、およびビデオ キャプチャ機能へのアクセスを提供します。
警告: イメージ、ビデオ、またはデバイスのカメラやマイクからの音声の収集と利用を重要なプライバシーの問題を発生させます。 アプリのプライバシー ポリシーは、アプリがそのようなセンサーを使用する方法と、記録されたデータは他の当事者と共有かどうかを議論すべきです。 さらに、カメラまたはマイクのアプリの使用がない場合明らかに、ユーザー インターフェイスで、前に、アプリケーションにアクセスするカメラまたはマイクを (デバイスのオペレーティング システムしない場合そう既に) - 時間のお知らせを提供する必要があります。 その通知は、上記の (例えば、 [ok]をおかげで選択肢を提示する) によってユーザーのアクセス許可を取得するだけでなく、同じ情報を提供する必要があります。 いくつかのアプリのマーケットプ レース - 時間の通知を提供して、カメラまたはマイクにアクセスする前にユーザーからアクセス許可を取得するアプリをする必要がありますに注意してください。 詳細については、プライバシーに関するガイドを参照してください。
このプラグインでは、グローバル navigator.device.capture
オブジェクトを定義します。
グローバル スコープではあるがそれがないまで deviceready
イベントの後です。
document.addEventListener("deviceready", onDeviceReady, false);
function onDeviceReady() {
console.log(navigator.device.capture);
}
cordova plugin add cordova-plugin-media-capture
supportedAudioModes: デバイスでサポートされている形式の録音。(ConfigurationData[])
supportedImageModes: 記録画像サイズとデバイスでサポートされている形式です。(ConfigurationData[])
supportedVideoModes: 記録のビデオ解像度とデバイスでサポートされている形式です。(ConfigurationData[])
オーディオ レコーダー アプリケーションを起動し、キャプチャしたオーディオ クリップ ファイルに関する情報を返します。
navigator.device.capture.captureAudio(
CaptureCB captureSuccess, CaptureErrorCB captureError, [CaptureAudioOptions options]
);
オーディオ録音デバイスの既定のオーディオ録音アプリケーションを使用してキャプチャする非同期操作を開始します。 操作を単一のセッションで複数の録音をキャプチャするデバイスのユーザーことができます。
キャプチャ操作は、アプリケーションでは、録音を終了するか、または録音 CaptureAudioOptions.limit
で指定された最大数に達したときに終了します。 limit
パラメーター値が指定されていない場合既定の 1 つ (1) とキャプチャ操作をユーザーが 1 つのオーディオ クリップを録音した後終了します。
キャプチャ操作が完了したら、キャプチャしたオーディオ クリップの各ファイルを記述する MediaFile
オブジェクトの配列を CaptureCallback
を実行します。 場合は、ユーザー操作を終了します、オーディオ クリップをキャプチャする前に、CaptureErrorCallback
を実行します CaptureError
オブジェクトと CaptureError.CAPTURE_NO_MEDIA_FILES
エラーコードをフィーチャーします。
// capture callback
var captureSuccess = function(mediaFiles) {
var i, path, len;
for (i = 0, len = mediaFiles.length; i < len; i += 1) {
path = mediaFiles[i].fullPath;
// do something interesting with the file
}
};
// capture error callback
var captureError = function(error) {
navigator.notification.alert('Error code: ' + error.code, null, 'Capture Error');
};
// start audio capture
navigator.device.capture.captureAudio(captureSuccess, captureError, {limit:2});
オーディオ キャプチャの構成オプションをカプセル化します。
制限: デバイス ユーザーは、単一のキャプチャ操作で記録することができますオーディオ クリップの最大数。値 1 (デフォルトは 1) 以上にする必要があります。
期間: オーディオのサウンド クリップの最大継続時間を秒単位で。
// limit capture operation to 3 media files, no longer than 10 seconds each
var options = { limit: 3, duration: 10 };
navigator.device.capture.captureAudio(captureSuccess, captureError, options);
duration
パラメーターはサポートされていません。長さの記録プログラムで限定することはできません。duration
パラメーターはサポートされていません。長さの記録プログラムで限定することはできません。duration
パラメーターはサポートされていません。長さの記録プログラムで限定することはできません。limit
パラメーターはサポートされていません、各呼び出しに対して、1 つだけ記録を作成できます。limit
パラメーターはサポートされていません、各呼び出しに対して、1 つだけ記録を作成できます。カメラ アプリケーションを起動し、キャプチャしたイメージ ファイルに関する情報を返します。
navigator.device.capture.captureImage(
CaptureCB captureSuccess, CaptureErrorCB captureError, [CaptureImageOptions options]
);
デバイスのカメラ アプリケーションを使用して画像をキャプチャする非同期操作を開始します。操作では、単一のセッションで 1 つ以上のイメージをキャプチャすることができます。
キャプチャ終了操作時ユーザー カメラ アプリケーションを閉じるまたはのいずれかの CaptureAudioOptions.limit
によって指定された録音の最大数に達した。 limit
値が指定されていない場合、デフォルトは 1 つ (1) キャプチャ操作が終了した後、ユーザーは単一のイメージをキャプチャします。
キャプチャ操作が完了したら、キャプチャしたイメージの各ファイルを記述する MediaFile
オブジェクトの配列を CaptureCB
コールバックを呼び出します。 ユーザーがイメージをキャプチャする前に操作を終了する場合 CaptureError.CAPTURE_NO_MEDIA_FILES
のエラー コードを備え CaptureError
オブジェクトと CaptureErrorCB
コールバックを実行します。
Zune を介してお使いのデバイスが接続されているネイティブ カメラ アプリケーションを呼び出すと、動作しませんし、エラー コールバックを実行します。
// capture callback
var captureSuccess = function(mediaFiles) {
var i, path, len;
for (i = 0, len = mediaFiles.length; i < len; i += 1) {
path = mediaFiles[i].fullPath;
// do something interesting with the file
}
};
// capture error callback
var captureError = function(error) {
navigator.notification.alert('Error code: ' + error.code, null, 'Capture Error');
};
// start image capture
navigator.device.capture.captureImage(captureSuccess, captureError, {limit:2});
イメージ キャプチャの構成オプションをカプセル化します。
// limit capture operation to 3 images
var options = { limit: 3 };
navigator.device.capture.captureImage(captureSuccess, captureError, options);
ビデオ レコーダー アプリケーションを起動し、キャプチャしたビデオ クリップ ファイルに関する情報を返します。
navigator.device.capture.captureVideo(
CaptureCB captureSuccess, CaptureErrorCB captureError, [CaptureVideoOptions options]
);
デバイスのビデオ録画アプリケーションを使用してビデオ記録をキャプチャする非同期操作を開始します。操作は、単一のセッションで 1 つ以上の録音をキャプチャすることができます。
キャプチャ操作はユーザーがビデオ録画アプリケーションを終了または CaptureVideoOptions.limit
で指定された録音の最大数に達したときに終了します。 limit
パラメーター値が指定されていない場合それデフォルト値は 1 (1) と、ユーザーは 1 つのビデオ クリップを記録した後にキャプチャ操作が終了しました。
キャプチャ操作が完了したら、CaptureCB
コールバック実行に使用する各ビデオ クリップのキャプチャ ファイルを記述する MediaFile
オブジェクトの配列。 ユーザーがビデオ クリップをキャプチャする前に操作を終了する場合 CaptureError.CAPTURE_NO_MEDIA_FILES
のエラー コードを備え CaptureError
オブジェクトと CaptureErrorCB
コールバックを実行します。
// capture callback
var captureSuccess = function(mediaFiles) {
var i, path, len;
for (i = 0, len = mediaFiles.length; i < len; i += 1) {
path = mediaFiles[i].fullPath;
// do something interesting with the file
}
};
// capture error callback
var captureError = function(error) {
navigator.notification.alert('Error code: ' + error.code, null, 'Capture Error');
};
// start video capture
navigator.device.capture.captureVideo(captureSuccess, captureError, {limit:2});
CaptureError.CAPTURE_NOT_SUPPORTED
、アプリケーションがデバイスにインストールされていない場合はエラー コード。ビデオ キャプチャの構成オプションをカプセル化します。
制限: デバイスのユーザーを単一のキャプチャ操作でキャプチャすることができますビデオ クリップの最大数。値 1 (デフォルトは 1) 以上にする必要があります。
期間: ビデオ クリップの最大継続時間を秒単位で。
// limit capture operation to 3 video clips
var options = { limit: 3 };
navigator.device.capture.captureVideo(captureSuccess, captureError, options);
成功したメディア キャプチャ操作時に呼び出されます。
function captureSuccess( MediaFile[] mediaFiles ) { ... };
この関数は成功したキャプチャ操作の完了後に実行します。 いずれかのメディア ファイルをキャプチャすると、この時点で、ユーザーが終了しているメディア ・ キャプチャ ・ アプリケーションまたはキャプチャ制限に達しています。
MediaFile
の各オブジェクトにはキャプチャしたメディア ファイルについて説明します。
// capture callback
function captureSuccess(mediaFiles) {
var i, path, len;
for (i = 0, len = mediaFiles.length; i < len; i += 1) {
path = mediaFiles[i].fullPath;
// do something interesting with the file
}
};
失敗したメディア キャプチャ操作からの結果のエラー コードをカプセル化します。
CaptureError.CAPTURE_INTERNAL_ERR
: カメラまたはマイクの画像やサウンドをキャプチャに失敗しました。
CaptureError.CAPTURE_APPLICATION_BUSY
: 現在カメラやオーディオのキャプチャのアプリケーション別のキャプチャ要求を提供します。
CaptureError.CAPTURE_INVALID_ARGUMENT
: 無効な API の使用 (例えば、の値 limit
が 1 未満です)。
CaptureError.CAPTURE_NO_MEDIA_FILES
: ユーザーが何かをキャプチャする前にカメラやオーディオのキャプチャ アプリケーションを終了します。
CaptureError.CAPTURE_NOT_SUPPORTED
: 要求されたキャプチャ操作はサポートされていません。
メディア キャプチャ操作中にエラーが発生した場合に呼び出されます。
function captureError( CaptureError error ) { ... };
この関数は、エラーが発生した場合を起動しようとすると、メディア操作のキャプチャを実行します。 障害シナリオを含めますキャプチャ アプリケーションがビジー状態、キャプチャ操作は既に起こって、または、操作をキャンセルする前にメディア ファイルが自動的にキャプチャされます。
この関数は適切なエラー code
を含む CaptureError
オブジェクトで実行します。.
// capture error callback
var captureError = function(error) {
navigator.notification.alert('Error code: ' + error.code, null, 'Capture Error');
};
デバイスがサポートするメディア キャプチャ パラメーターのセットをカプセル化します。
デバイスでサポートされているメディアのキャプチャのモードについて説明します。構成データには、MIME の種類、およびビデオやイメージ キャプチャのキャプチャ寸法が含まれます。
MIME の種類は RFC2046 に従う必要があります。例:
video/3gpp
video/quicktime
image/jpeg
audio/amr
audio/wav
タイプ: 小文字の文字列を ASCII でエンコードされたメディアの種類を表します。(,)
高さ: イメージまたはビデオのピクセルでの高さ。値は、サウンド クリップの場合は 0 です。(数)
幅: イメージまたはピクセルのビデオの幅。値は、サウンド クリップの場合は 0 です。(数)
// retrieve supported image modes
var imageModes = navigator.device.capture.supportedImageModes;
// Select mode that has the highest horizontal resolution
var width = 0;
var selectedmode;
for each (var mode in imageModes) {
if (mode.width > width) {
width = mode.width;
selectedmode = mode;
}
}
任意のプラットフォームでサポートされていません。すべての構成データの配列は空です。
取得についての書式情報メディア キャプチャ ファイル。
mediaFile.getFormatData(
MediaFileDataSuccessCB successCallback,
[MediaFileDataErrorCB errorCallback]
);
この関数は、非同期的にメディア ファイルの形式情報を取得しようとします。 成功した場合、MediaFileData
オブジェクトと MediaFileDataSuccessCB
コールバックを呼び出します。 失敗した場合、この関数は MediaFileDataErrorCB
コールバックを呼び出します。
API 情報にアクセスするメディア ファイル形式は限られて、それで、必ずしもすべて MediaFileData
プロパティがサポートされます。
既定値を持つすべての MediaFileData
オブジェクトを返すので、メディア ファイルについて API を提供しません。
API 情報にアクセスするメディア ファイル形式は限られて、それで、必ずしもすべて MediaFileData
プロパティがサポートされます。
API 情報にアクセスするメディア ファイル形式は限られて、それで、必ずしもすべて MediaFileData
プロパティがサポートされます。
メディア キャプチャ ファイルのプロパティをカプセル化します。
名前: パス情報なしのファイルの名前。(,)
fullPath: 名を含むファイルの完全パス。(,)
タイプ: ファイルの mime の種類 (,)
ファイルサイズ: 日付と時刻、ファイルが最後に変更されました。(日)
サイズ: バイトで、ファイルのサイズ。(数)
メディア ファイルの形式情報をカプセル化します。
コーデック: オーディオおよびビデオ コンテンツの実際のフォーマット。(,)
ビットレート: コンテンツの平均ビットレート。値が画像の場合は 0 です。(数)
高さ: イメージまたはビデオのピクセルでの高さ。値は、オーディオ クリップの場合は 0 です。(数)
幅: イメージまたはピクセルのビデオの幅。値は、オーディオ クリップの場合は 0 です。(数)
期間: 秒のビデオまたはサウンドのクリップの長さ。値が画像の場合は 0 です。(数)
API には、メディア ファイルの形式情報提供しません MediaFile.getFormatData
機能によって返される MediaFileData
オブジェクト次の既定値。
コーデック: ないサポートされておりを返しますnull
.
ビットレート: ないサポートされており、ゼロを返します。
高さ: ないサポートされており、ゼロを返します。
幅: ないサポートされており、ゼロを返します。
期間: ないサポートされており、ゼロを返します。
以下がサポート MediaFileData
プロパティ。
コーデック: いないサポートしを返しますnull
.
ビットレート: いないサポートし、ゼロを返します。
高さ: サポート: イメージ ファイルやビデオ ファイルのみです。
幅: サポート: イメージ ファイルやビデオ ファイルのみです。
期間: サポート: オーディオおよびビデオ ファイルのみ
以下がサポート MediaFileData
プロパティ。
コーデック: ないサポートされておりを返しますnull
.
ビットレート: ないサポートされており、ゼロを返します。
高さ: サポート: イメージ ファイルやビデオ ファイルのみです。
幅: サポート: イメージ ファイルやビデオ ファイルのみです。
期間: サポート: オーディオおよびビデオ ファイルのみです。
以下がサポート MediaFileData
プロパティ。
コーデック: ないサポートされておりを返しますnull
.
ビットレート: iOS4 オーディオのみのデバイスでサポートされています。画像や動画はゼロを返します。
高さ: サポート: イメージ ファイルやビデオ ファイルのみです。
幅: サポート: イメージ ファイルやビデオ ファイルのみです。
期間: サポート: オーディオおよびビデオ ファイルのみです。