2017-01-04 20 views
12

画像データの検出方法を探していますが、破損しています。たとえばこの絵は: enter image description herejs画像の切り捨て/破損データのチェック

データの画像は、(それはIEの詳細有形だし、そのFirefoxのコンソールに警告として注意)完全ではありませんが、img.onerrorは解雇、およびimg.completedない事実です。

デモ:https://jsfiddle.net/7dd0ybb4/

var img = document.getElementById('MyPicture'); 

img.onerror =() => alert('error img'); 
img.onload =() => console.log(img.complete); //true 

img.src = "https://i.stack.imgur.com/nGkok.jpg"; 

私はそれを知るための方法をしたいです。画像に無効なデータがある場合

+0

理由「は、画像が完全にロードされ、破損した画像ではありませんだって。ネットワークアクティビティが中断されると、エラーが発生します。 –

+0

@AkhilArjun、何を探しているのではなく、どうしたのですか。 – dovid

+0

@lomedあなたは方法を見つけましたか? –

答えて

3

このコードのようにキャンバスで破損したピクセルをチェックすることができ:

var src = 'here comes your base64 data' 
var imageData = Uint8Array.from(atob(src.replace('data:image/jpeg;base64,', '')), c => c.charCodeAt(0)) 

JPEGファイル、start with the bytes FF D8 and end with FF D9なければならないので、作成された配列バッファの最後の2つの要素が255と217であるかどうかを確認します。live exampleを参照してください。

var imageCorrupted = ((imageData[imageData.length - 1] === 217) && (imageData[imageData.length - 2] === 255)); 

我々はバイトのシーケンスを含むPNG画像(live example)について同様のチェック、end with an IEND chunkを使用することができます。

// in hex: 00 00 00 00 49 45 4e 44 ae 42 60 82 
var sequence = [0, 0, 0, 0, 73, 69, 78, 68, 174, 66, 96, 130]; 
+0

'imageCorrupted == false'のため、[this' src'](https:///0bin.net/paste/VkxPPlgc9DWme4gw#jqp+X4qoIxlQi91s-mzMbW0S4INdxlMgcBZC5ek3kda)では動作しません。 –

4

あなたはバイトの配列に画像をデコードすることができます

var ctx = document.getElementById('canvas').getContext('2d'); 
 
var img = new Image(); 
 
img.onload = function(){ 
 
    ctx.drawImage(img,0,0); 
 
    var height=this.height; 
 
    var width=this.width; 
 
    var hCenter=Math.round(width/2); 
 
    var corruptedRowsCount=0; 
 
    for(var row=height;row>0;row--){ 
 
     var c = ctx.getImageData(hCenter, row, 1, 1).data; 
 
     if(c[0]==0 && c[1]==0 && c[2]==0 && c[3]==0) 
 
      corruptedRowsCount++; 
 
     else 
 
      break; 
 
    } 
 
    console.log(Math.round(corruptedRowsCount*100/height)+" precent of image is corrupted"); 
 
}; 
 

 
img.src="";
<canvas id="canvas">

+0

歓声!素敵な回避策.. –

+0

+1非常に素晴らしい!まだ答えていない。 解決策は透明ピクセルが無効であるとみなし、JPGではtrueですがPNGでは無効です。 https://jsfiddle.net/7L01yfb2/1/を参照してください。画像データは100%有効です。 – dovid

+0

申し訳ありませんが、ここで固定https://jsfiddle.net/7L01yfb2/3/ – dovid

関連する問題