cordova-plugin-camera-dev/doc/zh/index.md

14 KiB
Raw Blame History

org.apache.cordova.camera

這個外掛程式提供了一個 API拍照從系統的圖像庫中選擇圖像。

cordova plugin add org.apache.cordova.camera

navigator.camera.getPicture

需要使用的相機,一張照片或從設備的圖像庫檢索一張照片。 圖像作為 base64 編碼傳遞成功回檔到 String ,或作為影像檔的 URI。 該方法本身返回 CameraPopoverHandle 可以用於重新置放檔選擇彈出的物件。

navigator.camera.getPicture( cameraSuccess, cameraError, cameraOptions );

說明

camera.getPicture函數將打開該設備的預設攝像頭應用程式,使使用者能夠對齊圖片。 預設情況下,會發生此行為時 Camera.sourceType 等於 Camera.PictureSourceType.CAMERA 。 一旦使用者快照照片、 攝像頭應用程式關閉,並恢復該應用程式。

如果 Camera.sourceTypeCamera.PictureSourceType.PHOTOLIBRARYCamera.PictureSourceType.SAVEDPHOTOALBUM ,然後允許使用者選擇一個現有圖像對話方塊的顯示。 camera.getPicture函數返回 CameraPopoverHandle 物件,可用於設備方向更改時重新置放圖像選擇對話方塊,例如。

傳回值發送到 cameraSuccess 回呼函數,根據指定的以下格式之一 cameraOptions

  • A String 包含的 base64 編碼的照片圖像。

  • A String 表示在本機存放區 (預設值) 上的影像檔位置。

你可以做任何你想與編碼的圖像或 URI例如

  • 呈現在圖像 <img> 標記,如下面的示例所示

  • 保存本地的資料 LocalStorage Lawnchair,等等.)

  • 將資料發佈到遠端伺服器

在較新的設備上的照片解析度是相當好。 從設備的庫選擇了照片不到較低的品質,壓縮螢幕使即使 quality 指定參數。 為了避免常見的記憶體問題,設置 Camera.destinationTypeFILE_URI 而不是DATA_URL.

支援的平臺

  • 亞馬遜火 OS
  • Android 系統
  • 黑莓 10
  • 火狐瀏覽器作業系統
  • iOS
  • Tizen
  • Windows Phone 7 和 8
  • Windows 8

亞馬遜火 OS 怪癖

亞馬遜火 OS 使用意向啟動捕獲圖像,在設備上的相機活動和與低記憶體手機,科爾多瓦活動可能被殺。 在此方案中,可能不會顯示圖像還原科爾多瓦活動時。

Android 的怪癖

Android 使用意向啟動捕獲圖像,在設備上的相機活動和與低記憶體手機,科爾多瓦活動可能被殺。 在此方案中,可能不會顯示圖像還原科爾多瓦活動時。

火狐瀏覽器作業系統的怪癖

目前使用Web 活動實現相機外掛程式.

iOS 的怪癖

包括 JavaScript alert() 中任一回檔的函數可能會導致問題。 換行內的警報 setTimeout() ,允許 iOS 圖像選取器或彈出要完全關閉之前警報將顯示:

setTimeout(function() {/ / 做你的事!}0) 

Windows Phone 7 的怪癖

調用本機攝像頭應用程式,同時通過 Zune 連接設備不工作,並觸發錯誤回檔。

Tizen 怪癖

Tizen 僅支援 destinationTypeCamera.DestinationType.FILE_URIsourceTypeCamera.PictureSourceType.PHOTOLIBRARY.

示例

拍一張照片,並檢索它為 base64 編碼的圖像:

navigator.camera.getPicture(onSuccess, onFail, { quality: 50,
    destinationType: Camera.DestinationType.DATA_URL
});

function onSuccess(imageData) {
    var image = document.getElementById('myImage');
    image.src = "data:image/jpeg;base64," + imageData;
}

function onFail(message) {
    alert('Failed because: ' + message);
}

拍一張照片和檢索圖像的檔位置:

navigator.camera.getPicture(onSuccess, onFail, { quality: 50,
    destinationType: Camera.DestinationType.FILE_URI });

function onSuccess(imageURI) {
    var image = document.getElementById('myImage');
    image.src = imageURI;
}

function onFail(message) {
    alert('Failed because: ' + message);
}

CameraOptions

要自訂相機設置的可選參數。

{品質: 75destinationType Camera.DestinationType.DATA_URLsourceType Camera.PictureSourceType.CAMERAallowEdit 為 trueencodingType Camera.EncodingType.JPEGtargetWidth 100targetHeight 100popoverOptions CameraPopoverOptionssaveToPhotoAlbum 虛假} 

選項

  • 品質 保存的圖像,表示為一系列的 0-100在 100 哪裡通常全解析度而不會丟失檔的壓縮品質。 預設值為 50。 (人數)(請注意相機的解析度有關的資訊是不可用)。

  • 選擇傳回值的格式。預設值是 FILE_URI。定義在 navigator.camera.DestinationType (人數)

    Camera.DestinationType = {DATA_URL 0/ / 返回圖像作為 base64 編碼字串 FILE_URI 1/ / 返回影像檔的 URI NATIVE_URI 2 / / 返回圖像本機 URI (例如,資產庫: / / 在 iOS 或內容上: / / 在 Android 上)} 
    
  • 設置圖片的來源。預設值是觀景窗。定義在 navigator.camera.PictureSourceType (人數)

    Camera.PictureSourceType = {PHOTOLIBRARY: 0相機 1SAVEDPHOTOALBUM: 2} 
    
  • allowEdit 允許簡單編輯的選擇面前的形象。(布林)

  • encodingType 選擇返回的影像檔的編碼。預設值為 JPEG。定義在 navigator.camera.EncodingType (人數)

    Camera.EncodingType = {JPEG: 0/ / 返回 JPEG 編碼的 PNG 圖像: 1 / / 返回 PNG 編碼的圖像} 
    
  • targetWidth 以圖元為單位的尺度圖像的寬度。必須與targetHeight一起使用。縱橫比保持不變。(人數)

  • targetHeight 以圖元為單位的尺度圖像的高度。必須與targetWidth一起使用。縱橫比保持不變。(人數)

  • 媒體類型 設置要從選擇媒體的類型。 時才起作用 PictureSourceTypePHOTOLIBRARYSAVEDPHOTOALBUM 。 定義在 nagivator.camera.MediaType (人數)

    Camera.MediaType = {圖片: 0/ / 允許只仍然圖片的選擇。 預設情況。 Will return format specified via DestinationType
        VIDEO: 1,      // allow selection of video only, WILL ALWAYS RETURN FILE_URI
        ALLMEDIA : 2   // allow selection from all media types
    };
    
  • correctOrientation 旋轉圖像,期間擷取裝置的方向的正確。(布林)

  • saveToPhotoAlbum 將圖像保存到相冊在設備上捕獲後。(布林)

  • popoverOptions 僅限 iOS 在 iPad 中指定彈出位置的選項。在中定義CameraPopoverOptions.

  • cameraDirection 選擇相機以使用 (前面或後面-面向)。預設值是背。定義在 navigator.camera.Direction (人數)

    Camera.Direction = {回: 0/ / 使用前面後面攝像頭: 1 / / 使用前置攝像頭} 
    

亞馬遜火 OSQuirks

  • 任何 cameraDirection 值回朝的照片中的結果。

  • 忽略 allowEdit 參數。

  • Camera.PictureSourceType.PHOTOLIBRARYCamera.PictureSourceType.SAVEDPHOTOALBUM 都顯示相同的相冊。

Android 的怪癖

  • 任何 cameraDirection 值回朝的照片中的結果。

  • 忽略 allowEdit 參數。

  • Camera.PictureSourceType.PHOTOLIBRARYCamera.PictureSourceType.SAVEDPHOTOALBUM 都顯示相同的相冊。

黑莓 10 怪癖

  • 忽略 quality 參數。

  • 忽略 sourceType 參數。

  • 忽略 allowEdit 參數。

  • Camera.MediaType不受支援。

  • 忽略 correctOrientation 參數。

  • 忽略 cameraDirection 參數。

火狐瀏覽器作業系統的怪癖

  • 忽略 quality 參數。

  • Camera.DestinationType將被忽略並且等於 1 (影像檔的 URI

  • 忽略 allowEdit 參數。

  • 忽略 PictureSourceType 參數 (使用者選擇它在對話方塊視窗中)

  • 忽略encodingType

  • 忽略 targetWidthtargetHeight

  • Camera.MediaType不受支援。

  • 忽略 correctOrientation 參數。

  • 忽略 cameraDirection 參數。

iOS 的怪癖

  • 設置 quality 低於 50避免在某些設備上的記憶體不足錯誤。

  • 當使用 destinationType.FILE_URI ,照片都保存在應用程式的臨時目錄。應用程式結束時,將刪除該應用程式的臨時目錄中的內容。

Tizen 怪癖

  • 不支援的選項

  • 始終返回一個檔的 URI

Windows Phone 7 和 8 怪癖

  • 忽略 allowEdit 參數。

  • 忽略 correctOrientation 參數。

  • 忽略 cameraDirection 參數。

  • 忽略 saveToPhotoAlbum 參數。 重要: 使用 wp7/8 科爾多瓦攝像頭 API 拍攝的所有圖像總是都複製到手機的相機膠捲。 根據使用者的設置,這可能也意味著圖像是自動上傳到他們另。 這有可能意味著的圖像,可以比你的應用程式的目的更多的觀眾。 如果此阻滯劑您的應用程式,您將需要實現 CameraCaptureTask 在 msdn 上記載: HTTP://msdn.microsoft.com/en-us/library/windowsphone/develop/hh394006.aspx你可能還評論或在問題追蹤器的向上投票的相關的問題

  • 忽略了 mediaType 屬性的 cameraOptions 作為 Windows Phone SDK 並不提供從 PHOTOLIBRARY 中選擇視頻的方法。

CameraError

onError 回呼函數的函數提供了一條錯誤訊息。

function(message) {
    // Show a helpful message
}

參數

  • 消息 消息提供的設備的本機代碼。(字串)

cameraSuccess

onSuccess 提供的圖像資料的回呼函數。

function(imageData) {
    // Do something with the image
}

參數

  • 把圖像資料 Base64 編碼的圖像資料,影像檔的 URI取決於 cameraOptions 生效。(字串)

示例

// Show image
//
function cameraCallback(imageData) {
    var image = document.getElementById('myImage');
    image.src = "data:image/jpeg;base64," + imageData;
}

CameraPopoverHandle

由創建的彈出對話方塊的控制碼navigator.camera.getPicture.

方法

  • setPosition: 設置彈出的位置。

支援的平臺

  • iOS

setPosition

設置彈出的位置。

參數

  • cameraPopoverOptions CameraPopoverOptions ,指定新的位置

示例

 var cameraPopoverHandle = navigator.camera.getPicture(onSuccess, onFail,
     { destinationType: Camera.DestinationType.FILE_URI,
       sourceType: Camera.PictureSourceType.PHOTOLIBRARY,
       popoverOptions: new CameraPopoverOptions(300, 300, 100, 100, Camera.PopoverArrowDirection.ARROW_ANY)
     });

 // Reposition the popover if the orientation changes.
 window.onorientationchange = function() {
     var cameraPopoverOptions = new CameraPopoverOptions(0, 0, 100, 100, Camera.PopoverArrowDirection.ARROW_ANY);
     cameraPopoverHandle.setPosition(cameraPopoverOptions);
 }

CameraPopoverOptions

iOS 僅指定彈出的錨元素的位置和箭頭方向,從 iPad 的庫或專輯選擇圖像時的參數。

{x: 0y 32寬度 320高度 480arrowDir Camera.PopoverArrowDirection.ARROW_ANY} 

CameraPopoverOptions

  • x 圖元的 x 座標上的錨定彈出螢幕元素。(人數)

  • y 到其錨定彈出螢幕元素的 y 圖元座標。(人數)

  • 寬度 寬度以圖元為單位),到其錨定彈出螢幕元素。(人數)

  • 高度 高度以圖元為單位),到其錨定彈出螢幕元素。(人數)

  • arrowDir 上彈出的箭頭應指向的方向。定義在 Camera.PopoverArrowDirection (人數)

        Camera.PopoverArrowDirection = {ARROW_UP: 1/ / 匹配 iOS UIPopoverArrowDirection 常量 ARROW_DOWN 2ARROW_LEFT 4ARROW_RIGHT 8ARROW_ANY 15} 
    

請注意彈出的大小可能會更改箭頭的方向和螢幕的方向調整。 請確保帳戶方向更改時指定的錨點的元素位置。

navigator.camera.cleanup

刪除中間由從臨時存儲相機所拍攝的照片。

navigator.camera.cleanup( cameraSuccess, cameraError );

說明

刪除中間打完電話後保留在臨時存儲的影像檔 camera.getPicture 。 適用時,才的價值 Camera.sourceType 等於 Camera.PictureSourceType.CAMERACamera.destinationType 等於Camera.DestinationType.FILE_URI.

支援的平臺

  • iOS

示例

navigator.camera.cleanup(onSuccess, onFail);

function onSuccess() {
    console.log("Camera cleanup success.")
}

function onFail(message) {
    alert('Failed because: ' + message);
}