フレーム差分

このサンプルは、動作量を検出するためのコードです。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
//This code has been arranged by Yasushi Noguchi. Last updated on June 21, 2008.
/**
 * Frame Differencing 
 * by Golan Levin. 
 * 
 * Quantify the amount of movement in the video frame using frame-differencing.
 */ 
 
import processing.video.*;
 
int numPixels;    //画像のピクセルの総数
int[] previousFrame;    //一つ前のフレーム
int noiseFilter = 100;    //ノイズを拾わないためのフィルタ(値を増やすとフィルタが強くかかる)
Capture video;    //キャプチャ映像用の変数
 
void setup() {
  size(640, 480);
 
  video = new Capture(this, width, height, 24);
  //キャプチャーするビデオ画像の総ピクセル数
  numPixels = video.width * video.height;
  //現在のキャプチャ画像と比べるために一つ前のフレーム用の配列を作る
  previousFrame = new int[numPixels];
  loadPixels();
}
 
void draw() {
  if (video.available()) {  //もしキャプチャができたら、
    video.read(); //ビデオフレームの読み込み
    video.loadPixels(); //ビデオのピクセルを操作できるようにする
 
    int movementSum = 0; //一つのフレームでの動作量
    for (int i = 0; i < numPixels; i++) { //フレーム内のそれぞれのピクセルを検出
      color currColor = video.pixels[i];
      color prevColor = previousFrame[i];
 
      //現在のピクセルのR, G, Bを抜き出す
      int currR = (currColor >> 16) & 0xFF;
      int currG = (currColor >> 8 ) & 0xFF;
      int currB = currColor & 0xFF;
 
      //一つ前のフレームの色を抜き出す
      int prevR = (prevColor >> 16) & 0xFF;
      int prevG = (prevColor >> 8 ) & 0xFF;
      int prevB = prevColor & 0xFF;
 
      //現在のピクセルから前のピクセルの色を引いた絶対値
      int diffR = abs(currR - prevR);
      int diffG = abs(currG - prevG);
      int diffB = abs(currB - prevB);
 
      //noiseFilterの値よりも大きかったらmovementSumに足していく
      //そして、現在の色に更新
      if(diffR + diffG + diffB > noiseFilter){
        movementSum += diffR + diffG + diffB;
        pixels[i] = color(currR, currG, currB);
        //次のコードの方が高速に実行できるが、ちょっと難しい
        //pixels[i] = 0xFF000000 | (currR < < 16) | (currG << 8 ) | currB;        
      }
      else{
        //そうでない場合は黒
        pixels[i] = color(0);
      }
 
      //現在のフレームの色を前のフレームの色にする。
      previousFrame[i] = currColor;
    }
 
    updatePixels();    //ピクセルを更新
    println(movementSum);    //変化したピクセルの総数をプリント
  }
}