2

我想将从我的手机拍摄的图像更新到 Parse,我们正在努力使用这个简单的功能,因为我们无法使用 Phonegap 将 ImageUri 转换为真实文件(以便将其上传到我们的 Parse 服务器),我们正在使用 Ripple模仿手机行为。

我们尝试了这段代码:

var reader = new FileReader();


reader.onloadend = function(evt) {

console.log("read success");
console.log(evt.target.result);
evt.target.result;
};
reader.readAsText(user.myPicture);

但我得到这个错误:TypeError: Object #<Console> has no method 'warning'

似乎 phonegap 的 FileReader 不喜欢我从 navigator.camera.getPicture() 获得的那种 URI

$scope.getPicture = function(){

            navigator.camera.getPicture(onSuccess, onFail,
                //Options => http://docs.phonegap.com/en/2.6.0/cordova_camera_camera.md.html#Camera
                { quality: 50,
                    destinationType:Camera.DestinationType.FILE_URI,
                    encodingType: Camera.EncodingType.JPEG,
                    sourceType : Camera.PictureSourceType.PHOTOLIBRARY ,//CAMERA,
                    targetWidth: 100,
                    targetHeight: 100
                });
            function onSuccess(imageURI) {
                var image = document.getElementById('preview');
                image.src = imageURI;
                $scope.myPicture = image.src;

//                $scope.$apply(function() {
//                    ctrl.$setViewValue(image.src);
//                });
            }

            function onFail(message) {
                alert('Failed because: ' + message);
                ctrl.$setValidity('Failed because: ' + message, false);
            }

        };

有没有其他方法可以在不使用 JQuery $.get() 的情况下获取文件?

这里有一个类似的帖子有同样的问题

4

2 回答 2

3

我想你会欣赏我为你链接的问题得到的相同答案。

与这篇文章中的信息。. 非常感谢雷蒙德卡姆登!

function gotPic(data) {

window.resolveLocalFileSystemURI(data, function(entry) {

var reader = new FileReader();

reader.onloadend = function(evt) {
    var byteArray = new Uint8Array(evt.target.result);
    var output = new Array( byteArray.length );
    var i = 0;
    var n = output.length;
    while( i < n ) {
        output[i] = byteArray[i];
        i++;
    }                
    var parseFile = new Parse.File("mypic.jpg", output);

    parseFile.save().then(function(ob) {
            navigator.notification.alert("Got it!", null);
            console.log(JSON.stringify(ob));
        }, function(error) {
            console.log("Error");
            console.log(error);
        });

}

reader.onerror = function(evt) {
      console.log('read error');
      console.log(JSON.stringify(evt));
  }

entry.file(function(s) {
    reader.readAsArrayBuffer(s);
}, function(e) {
    console.log('ee');
});

});
}
于 2013-07-11T14:33:30.957 回答
0

我不确定是否理解。你想保存图片,或者只是显示它,还是别的什么?

  • 为了保存图片,有人写了一个插件。你可以在这里找到它:base64ToPNG

  • 要显示图片:

    image.src = "数据:图像/jpeg;base64," + imageURI

于 2013-05-15T15:22:23.593 回答