2016-03-29 10 views
2

Aynı resim ve aynı boyutta tuvalim var, ancak çıktı farklı. Aynı çıktıyı istiyorum, nasıl yapmalıyım?canvas2d toDataURL() Farklı tarayıcıda farklı çıktı

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; 
+1

Eğer varsayılan bırakmak yerine biçimini ve sıkıştırma belirtebilirsiniz. Aynı görüntüyü belirli bir formatta şifrelemenin birçok yolu olduğu için, size bile mükemmel eşleşme çıktıları vermeyebilir. – dandavis

+0

Olası çoğaltılabilir [Tuvale getImageData yöntemi makine/tarayıcı bağımlı mı?] (Http://stackoverflow.com/q/26615580/1529630) – Oriol

+0

@Oriol, açıkça ilgili olsa da, OP olduğundan beri bir dupe olduğunu sanmıyorum Aynı çıktıyı elde etmenin bir yolunu soruyorum. (Ben zaten cevabını kestirmişim, o yüzden artık yapamam ...) – Kaiido

cevap

3

bir FileReader ve yöntemi readAsDataURL() kullanın.

Harici dosyalar için, yine de çapraz kaynaklı isteklerle sınırlandırılırken XMLHttpRequest Object ve xhr.responseType = "blob" özelliğine teşekkür ederiz.

Her tarayıcıda denemedim, ancak bu tuvalden daha hassas olmalı.

Tuval üzerine çizilen resim, çizilmeden önce kodu çözülür, daha sonra toDataURL çağrıldığında yeniden kodlanır. Bu işlem her tarayıcıya ve hatta her makineye bağlıdır (0O381'e göre canvas fingerprinting ve this post'a bakın).

Açıkçası, bu süreç orijinal dosyanın içeriğini değiştirir (gerçekte bunun bir daha hiçbir ilgisi yoktur.) Bu cevap olabileceğini düşündüm


Düzenleme,

Bu tekniği test etmek için iyi bir yer, işte burada tarayıcınızın benimkine karşı dönüşümünü test edecek bir pasaj.

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', 'https://dl.dropboxusercontent.com/s/4e90e48s5vtmfbd/aaa.png'); 
 
xhr.send(); 
 

 
var imageDataURL = '';

+0

Teşekkür ederim! İstediğim şey buydu :) – Zan