Привет, можно ли конвертировать Blob / Base64 в формат fileURI, используя javascript / angularjs и ionic1. - PullRequest
0 голосов
/ 18 декабря 2018

Я пытаюсь захватить изображения с помощью cordovaCamera и imagePicker, затем удалить данные EXIF ​​и создать копию изображения, которое я получаю после удаления метаданных.

В следующем коде я получаю файл изображения в формате Blob, который я передаю в resolLocalFileSystemURL, но не могу продолжить, так как resolLocalFileSystemURL не принимает данные BLOB или Base64, поэтому можно преобразовать Blob / Base64 в формат fileURI.Или есть какая-нибудь альтернатива для решения этой проблемы.

В html: <input id="erd" type="file"/>

В controllers.js:

var input = document.querySelector('#erd');
input.addEventListener('change', load);
function load(){
    var fr = new FileReader();
    fr.onload = process;
    fr.readAsArrayBuffer(this.files[0]);
    console.log(" onload "+URL.createObjectURL(this.files[0]));
}

function process(){
var dv = new DataView(this.result);
var offset = 0, recess = 0;
var pieces = [];
var i = 0;
if (dv.getUint16(offset) == 0xffd8){
    offset += 2;
    var app1 = dv.getUint16(offset);
    offset += 2;
    while (offset < dv.byteLength){
        if (app1 == 0xffe1){

            pieces[i] = {recess:recess,offset:offset-2};
            recess = offset + dv.getUint16(offset);
            i++;
        }
        else if (app1 == 0xffda){
            break;
        }
        offset += dv.getUint16(offset);
        var app1 = dv.getUint16(offset);
        offset += 2;
    }
    if (pieces.length > 0){
        var newPieces = [];
        pieces.forEach(function(v){
            newPieces.push(this.result.slice(v.recess, v.offset));
        }, this);
        newPieces.push(this.result.slice(recess));
        var br = new Blob(newPieces, {type: 'image/jpeg'});
        console.log(" pieces.length "+URL.createObjectURL(br));
        $scope.strimg=URL.createObjectURL(br).toString();
        //var file = new File(URL.createObjectURL(br), "uploaded_file.jpg", { type: "image/jpeg", lastModified: Date.now() });

        var myFile = blobToFile(br, "my-image.jpg"); 
        console.log('myFile'+JSON.stringify(myFile));
        $scope.strimg = myFile;
        createFileEntry($scope.strimg);
        }
    }
}
        function blobToFile(theBlob,fileName){ 
        console.log('theBlob'+theBlob+fileName);
        var b = theBlob; 
        b.lastModifiedDate = new Date(); 
        b.name = fileName; //Cast to a File() type 
        return theBlob; 
        }



    function createFileEntry(fileURI) {
        window.resolveLocalFileSystemURL(fileURI, copyFile, fail);
    }

    // 5
    function copyFile(fileEntry) {
    console.log(" copyFile "+fileEntry);
        var name = fileEntry.fullPath.substr(fileEntry.fullPath.lastIndexOf('/') + 1);
        var newName = name;

        $scope.filepathnew="file:///storage/emulated/0/Android/data/com.offermanagement.system/files/";

        window.resolveLocalFileSystemURL($scope.filepathnew, function(fileSystem2) {
                                        fileEntry.copyTo(
                                        fileSystem2,
                                        newName,
                                        onCopySuccess,
                                        fail
                                    );
                            },
                            fail);
    }

    function onCopySuccess(entry) {
        $scope.$apply(function () {
            $rootScope.profilepic=entry.nativeURL;
            $rootScope.images.push(entry.nativeURL);
            $rootScope.items.push({src:entry.nativeURL,sub:'' });

        });
    }

    function fail(error) {
        console.log("fail: " + error.code);
    }

Я получаю следующую ошибку дляприведенный выше код «Uncaught TypeError: Неверный тип для параметра« uri »resolLocalFileSystemURI: Ожидаемая строка, но получен Blob.»

...