canvas2d toDataURL () salida diferente en un navegador diferente

Tengo la misma imagen y el mismo tamaño de canvas, pero el resultado es diferente. Quiero el mismo resultado, ¿cómo debería hacerlo?

var canvas = document.createElement('canvas'), ctx = canvas.getContext('2d'), img = new Image; img.crossOrigin = 'Anonymous'; img.onload = function(){ canvas.height = img.height; canvas.width = img.width; ctx.drawImage(img, 0, 0); var dataURL = canvas.toDataURL(); setBreakpoint(dataURL); callback.call(this, dataURL); canvas = null; }; img.src = url; 

Use un FileReader y su método readAsDataURL() .

Para archivos externos, aún puede usarlo gracias a XMLHttpRequest Object y su xhr.responseType = "blob" , mientras que está limitado por solicitudes de origen cruzado.

No probé en todos los navegadores, pero esto debería ser más preciso que el canvas.

La imagen dibujada en el canvas se decodifica antes de dibujarse, y luego se vuelve a codificar cuando se llama a toDataURL . este proceso depende de cada navegador, e incluso de cada máquina (mire la huella dactilar del canvas y esta publicación de @Oriol).

Obviamente, este proceso modificará el contenido de su archivo original (en realidad ya no tiene nada que ver con él).


Editar ,

Pensé que esta respuesta podría ser un buen lugar para probar esta técnica, así que aquí hay un fragmento, que pondrá a prueba la conversión de tu navegador frente a la mía.

 var xhr = new XMLHttpRequest(); xhr.responseType = 'blob'; xhr.onload = function() { var f = new FileReader(); f.onload = function() { if (this.result === imageDataURL) { console.log('same conversion'); } else { console.log('please post a comment to let me know that it\'s also browser/machine dependant'); } }; f.readAsDataURL(this.response); }; xhr.open('GET', 'http://sofes.miximages.com/javascript/=UTF-8''aaa.png'); xhr.send(); var imageDataURL = '';