科尔多瓦相机插件获得所选图像的真实路径

时间:2014-03-20 05:45:49

标签: android angularjs cordova

var options = {
    quality: 30, 
    destinationType: Camera.DestinationType.FILE_URI,
    sourceType: Camera.PictureSourceType.PHOTOLIBRARY,
};

navigator.camera.getPicture(
    function(imageURI) {
        window.resolveLocalFileSystemURL(imageURI, function(fileEntry) {
            console.log(fileEntry.toURI());
            scope.$apply(function() {    
                ctrl.$setViewValue(fileEntry.fullPath);
            });
        }, function(err){
            console.log(err);
        }); 
    },
    function(err) {
        console.log(err);
    }, options
);

imageURI返回' / media / external / images / media / 11。

我想获得真正的路径,但window.resolveLocalFileSystemURL仅返回' content:// media / external / images / media / 11'。

我试图获得类似' /mnt/sdcard/DCIM/camera/321321321.jpg'。

5 个答案:

答案 0 :(得分:5)

我刚刚找到了解决方案。代码更改应该在插件中完成,而不是在javascript文件中。

首先找到CameraLauncher.java

添加此功能。这是将转换' / media / external / images / media /'到realpath

public String getRealPathFromURI(Uri contentUri) {
    String res = null;
    String[] proj = { MediaStore.Images.Media.DATA };
    Cursor cursor = cordova.getActivity().getContentResolver().query(contentUri, proj, null, null, null);
    if(cursor.moveToFirst()){;
       int column_index = cursor.getColumnIndexOrThrow(MediaStore.Images.Media.DATA);
       res = cursor.getString(column_index);
    }
    cursor.close();
    return res;
}

然后找到这一行。这是在navigator.camera.getPicture(success())

上返回imageURI的那个
if (this.targetHeight == -1 && this.targetWidth == -1 &&
        (destType == FILE_URI || destType == NATIVE_URI) && !this.correctOrientation) {
    this.callbackContext.success(uri.toString());
}

将此行更改为

if (this.targetHeight == -1 && this.targetWidth == -1 &&
        (destType == FILE_URI || destType == NATIVE_URI) && !this.correctOrientation) {
    this.callbackContext.success(getRealPathFromURI(uri)); 
}

答案 1 :(得分:0)

您必须使用fileEntry.toURL()

答案 2 :(得分:0)

我也在努力解决这个问题。 您必须使用cordova-plugin-filepath。它将转换为真实路径。

    $cordovaCamera.getPicture(options).then(function(imageUrl) {
//FilePath will resolve the path
        window.FilePath.resolveNativePath(imageUrl, function (result) {
            imageURI = 'file://' + result;
            console.log(imageURI);
            resolve(imageURI);
        });
    });

使用此功能,您可以启用编辑(allowEdit:true),甚至可以保存在您的photolibrary上。 经过测试和工作!

答案 3 :(得分:0)

navigator.camera.getPicture(onSuccess, onFail, { quality: 50,destinationType:Camera.DestinationType.FILE_URI,mediaType:Camera.MediaType.ALLMEDIA,encodingType:Camera.EncodingType.JPEG,saveToPhotoAlbum:true,sourceType: Camera.PictureSourceType.PHOTOLIBRARY});
function onSuccess(imageData) {
    $("#img_id").attr("src",imageData);
    alert(imageData);
}

将输出显示为/storage/sdcard0/Pictures/IMG_9999433.jpg

答案 4 :(得分:-2)

你可以用这个

function getImageURI(imageURI) {

var gotFileEntry = function(fileEntry) {
    alert("got image file entry: " + fileEntry.fullPath);
    var gotFileSystem = function(fileSystem) {
// your code