Conversion d'URI de données en données d'image

/** * Converts data URI in 'image/png' format to an image data object * @param dataURL Base64 encoded string * @returns {ImageData/undefined} */ convertDataURLToImageData: function (dataURL) { if (dataURL !== undefined && dataURL !== null) { var canvas, context, image, imageData; canvas = document.createElement('canvas'); canvas.width = 470; canvas.height = 470; context = canvas.getContext('2d'); image = new Image(); image.addEventListener('load', function(){ context.drawImage(image, 0, 0, canvas.width, canvas.height); imageData = context.getImageData(0, 0, canvas.width, canvas.height); //how do i return this? }, false); image.src = dataURL; return imageData; } } 

Compte tenu de l'extrait ci-dessus, si je souhaite obtenir un ensemble de données d'image à partir d'une URL de données, je l'ai dessiné sur un canevas, comment puis-je retourner les données d'image?

Le problème est que votre fonction est asynchrone, car vous attendez l'événement de load .

Ensuite, vous pouvez utiliser des promesses:

 function convertURIToImageData(URI) { return new Promise(function(resolve, reject) { if (URI == null) return reject(); var canvas = document.createElement('canvas'), context = canvas.getContext('2d'), image = new Image(); image.addEventListener('load', function() { canvas.width = image.width; canvas.height = image.height; context.drawImage(image, 0, 0, canvas.width, canvas.height); resolve(context.getImageData(0, 0, canvas.width, canvas.height)); }, false); image.src = URI; }); } var URI = ""; convertURIToImageData(URI).then(function(imageData) { // Here you can use imageData console.log(imageData); }); 
 var img = new Image; img.src = strDataURI; 

Essayez cet espoir, vous comprendrez …