これは多すぎるかもしれませんが、Node.js https://nodejs.org/の短い JavaScript プログラムを次に示します。これは、読み取り可能なすべてのフレームを取り除き、現在のディレクトリに順番に番号が付けられた個別の jpg ファイルとして保存します。短いビデオ クリップでも何千ものフレームが生成される可能性があり、Node が使用する V8 JavaScript エンジンは非常に高速であるため、ファイル ブラウザーを閉じることをお勧めします。
ビデオ ファイルが大きすぎてバッファを作成できない場合、Node はエラーを発行して終了します。
その場合、最も簡単な方法は、シェル ユーティリティまたは HexEdit などのプログラムを使用してファイルをチャンクに分割することです。 http://www.hexedit.com/
ファイルを非同期で処理するようにこのコードを書き直せば問題は解決しますが、非同期コードを書いても不安が残ります。
var orgFile=process.cwd()+"/"+process.argv[2]; //Grab the video filename from the command line
var fs = require("fs"); //Load the filesystem module
var stats = fs.statSync(orgFile);//Get stats of video file
var fileSizeInBytes = stats["size"];//Get video file size from stats
var fdata=new Buffer(fileSizeInBytes);//Create a new buffer to hold the video data
var i=0;
var fStart=0;
var fStop=0;
var fCount=0;
fdata=fs.readFileSync(orgFile);//Read the video file into the buffer
//This section looks for the markers at the begining and end of each jpg image
//records their positions and then writes them as separate files.
while (i<fileSizeInBytes){
if (fdata[i]==0xFF){
//console.log("Found FF at "+i.toString);
if (fdata[i+1]==0xD8){
//console.log("Found D8 at "+(i+1).toString);
if (fdata[i+2]==0xFF){
//console.log("Found FF at "+(i+2).toString);
fStart=i;
}
}
}
if (fStart>0){
if (fdata[i]==0xFF){
if(fdata[i+1]==0xD9){
fStop=i+1;
}
}
if (fStart>0){
if (fStop>0){
fCount++;
fs.writeFileSync(orgFile+"."+fCount.toString()+".jpg",fdata.slice(fStart,fStop));
console.log (orgFile+"."+fCount.toString()+".jpg");
fStart=0;
fStop=0;
}
}
}
i++;
}
console.log ("Wrote "+fCount.toString()+" frames.");
上記のコードを mjpeg_parse.js として保存すると、呼び出しの例は次のようになります。
ノード mjepeg_parse.js videofile.avi