カメラ プラグインではなくキャプチャ プラグインを使用する場合は、1 回のセッションで撮影する写真に設定する制限を指定できます。リファレンスについては、phonegap 3.0 キャプチャ プラグインのドキュメントを参照してください。これは2.2でも同じように機能すると思います。
キャプチャ セッションを呼び出す方法のコードを次に示します。
<script type="text/javascript" charset="utf-8">
// Called when capture operation is finished
//
function captureSuccess(mediaFiles) {
var i, len;
for (i = 0, len = mediaFiles.length; i < len; i += 1) {
uploadFile(mediaFiles[i]);
}
}
// Called if something bad happens.
//
function captureError(error) {
var msg = 'An error occurred during capture: ' + error.code;
navigator.notification.alert(msg, null, 'Uh oh!');
}
// A button will call this function
//
function captureImage() {
// Launch device camera application,
// allowing user to capture up to 2 images
navigator.device.capture.captureImage(captureSuccess, captureError, {limit: 2});
}
// Upload files to server
function uploadFile(mediaFile) {
var ft = new FileTransfer(),
path = mediaFile.fullPath,
name = mediaFile.name;
ft.upload(path,
"http://my.domain.com/upload.php",
function(result) {
console.log('Upload success: ' + result.responseCode);
console.log(result.bytesSent + ' bytes sent');
},
function(error) {
console.log('Error uploading file ' + path + ': ' + error.code);
},
{ fileName: name });
}
</script>
これにより、キャプチャされた画像の画像ファイル名と場所が得られます。これらをカメラロールに保存する方法については、後でわかり次第、回答を編集してみます。注...これは、captureVideo 関数を使用する場合、ビデオでも機能します。また、これらの画像をサーバーに投稿できる uploadFile 関数も含まれています。その関数内では、画像ファイルへのフルパスと画像ファイル名を参照する方法を示しています。これは、これらをカメラ ロールに追加する際に役立ちます。fileTransfer オブジェクトには File プラグインが必要な場合がありますが、FileTransfer プラグインも必ず必要になることに注意してください。