2016-11-15 12 views
0

私は多くを検索し、何も正しく見つからなかった。キャンバス画像からbase64を取得するにはどうすればよいですか?

は、ここに私のコードです:

context.drawImage(img, 0, -realDif, width, width*def); 
var base64 = canvas.toDataURL("image/jpeg"); 

一部の人々は私に言ったし、私は実際にそれを変換する方法を見つけるカントとしてtoDataUrlは私にイマイチベース64を返す文字列。誰かが手掛かりを持っていますか?

これは私だけでフォームを送信いけない場合はここで完全なコード

var canvas = document.getElementById('myCanvas'); 
    var context = canvas.getContext('2d'); 
    var URL = window.URL || window.webkitURL, 
    imageUrl, 
    img; 

    if (URL) { 
     imageUrl = URL.createObjectURL(file); 
     img = document.createElement("img"); 
     img.src = imageUrl; 
     img.onload = function() { 
      URL.revokeObjectURL(imageUrl);   
      var def = (img.height/img.width); 
      if(def < 1.25){ 
       dif = (heigh/def) - width; 
       realDif = dif/2; 
       context.drawImage(img, -realDif, 0, heigh/def, heigh); 
      } else { 
       dif = (width*def) - heigh; 
       realDif = dif/2; 
       context.drawImage(img, 0, -realDif, width, width*def); 
      } 
     } 
    } 
    var inpHidden = document.getElementById("img64"); 
    inpHidden.value = canvas.toDataURL("image/jpeg"); 
    document.getElementById("avatarForm").submit(); 

だ私は取得していますし、uはオンラインデコーダで確認することができますよう、それは

string(2415) "" 

を働いていないものです私はキャンバスが前のページで正しく描画されているのを見ることができます...間違っている可能性があります

+0

@Kaiido、いつかおかげで、誰かを助けます。あなたはそれがないと思いますか?それをコンソールにログオンすると、 'data:image/png; base64、...'と表示されます。 'base64 'の後のすべてがbase64でエンコードされた画像です。 –

+0

[HTML5 Canvas(readAsBinaryString)からのバイナリ(base64)データの取得](http://stackoverflow.com/questions/15685698/getting-binary-base64-data-from-html5-canvas-readasbinarystring) –

+0

Ditto @ Iwrestledabearonce。 'canvas.toDataURL'は実際にbase64でエンコードされたイメージ文字列を生成します。 ;-) – markE

答えて

0

まあ私はちょうどonlad関数の中にcanvas.toDataURL("image/jpeg");を入れて、それは今働いています

if (URL) { 
     imageUrl = URL.createObjectURL(file); 
     img.src = imageUrl; 
     img.onload = function() { 
      //URL.revokeObjectURL(imageUrl);   
      var def = (img.height/img.width); 
      if(def < 1.25){ 
       dif = (heigh/def) - width; 
       realDif = dif/2; 
       context.drawImage(img, -realDif, 0, heigh/def, heigh); 
      } else { 
       dif = (width*def) - heigh; 
       realDif = dif/2; 
       context.drawImage(img, 0, -realDif, width, width*def); 
      } 
      var inpHidden = document.getElementById("img64"); 
      inpHidden.value = canvas.toDataURL("image/jpeg"); 
      document.getElementById("avatarForm").submit(); 
     }  

希望はこれを使用すると、すべての特別な、それは接頭辞で、base64である

関連する問題