1

Phonegap のカメラ プラグインでは、呼び出しごとに 1 つの画像のみを撮影できます。

http://docs.phonegap.com/en/2.2.0/cordova_media_capture_capture.md.html#Captureによると、iOS では limit パラメータはサポートされていません。呼び出しごとに 1 つのイメージが取得されます。

以下を可能にする方法。

  1. カメラを呼び出す
  2. 写真を 1 枚撮影し、バックグラウンドでカメラロールに保存します。カメラを閉じないでください。この手順を繰り返します。
  3. カメラがアクティブな間、下部に「画像を表示」ボタンのある半透明レイヤーが必要です。このボタンをクリックすると、カメラが閉じられ、カメラ ロールの画像が表示されます。

github で利用できるコード サンプルはありますか?

4

2 に答える 2

1

特定のサイトでは、この制限機能は ios では機能しないと言っているので、写真をクリックし続けることができるように戻るボタンを押すまで閉じられないカメラを実装する他の代替手段

于 2015-07-24T05:23:06.163 に答える
0

カメラ プラグインではなくキャプチャ プラグインを使用する場合は、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 プラグインも必ず必要になることに注意してください。

于 2013-09-26T18:28:51.990 に答える