Lab9-Blend-Chromakey


5530567321  นายศุภสิน วิจิตรตระการรุ่ง (COM21900) (9/20/2012 (11:44:33 AM))

MiniQuiz + TestScript
JLab>java Selftest 

JLab> testBlend     : ok ok ok ok ok  (5.0/5.0)
JLab> testChromaKey : ok ok ok ok ok  (5.0/5.0)
JLab> : -----------------------------
JLab> : ?????? 10.0 ????? (???? 10.0)
JLab> : -----------------------------
JLab> :<POINT>10.0</POINT> (<TOTAL>10.0</TOTAL> )
JLab>

ได้ 10 คะแนน
Source Code
import jlab.graphics.DWindow;

public class ChromaKey {

  public static void main(String[] args) {
    DWindow fg = new DWindow();
    fg.loadImage("bird.gif");
    int w = fg.getWidth();
    int h = fg.getHeight();

    DWindow bg = new DWindow();
    bg.loadImage("sky.jpg",w, h);
    DWindow out = new DWindow(w, h);
    
    fg.setLocation(10, 10);
    bg.setLocation(10 + fg.getWidth(), 10);
    out.setLocation(10 + 2*fg.getWidth(), 10);
  
    out.setPixmap(chromaKey(fg.getPixmap(), bg.getPixmap(), DWindow.GREEN));
  }
  //-----------------------------------------------------------------
  public static int[][] chromaKey(int[][] fg, int[][] bg, int c) {
    int w = fg.length;
    int h = fg[0].length;
    int[][] b = new int[w][h];
    int d[][] = new int[w][h];
    
    for (int i = 0; i < w; i++) {
     for (int j = 0; j < h; j++) {
       
      if (fg[i][j] == c) 
        d[i][j] = bg[i][j];
      else 
        d[i][j] = fg[i][j];
        
        
        b[i][j] = d[i][j];
  
      }
     }
    return b;
  }
  //-----------------------------------------------------------------
}
import jlab.graphics.DWindow; public class Blend { public static void main(String[] args) { int w = 300, h = 300; DWindow pic1 = new DWindow(w, h); DWindow pic2 = new DWindow(w, h); DWindow out = new DWindow(w, h); pic1.loadImage("cat.jpg", w, h); pic2.loadImage("baby.jpg", w, h); pic1.setLocation(10, 10); pic2.setLocation(10 + w, 10); out.setLocation(10 + 2 * w, 10); while (true) { for (double a = 0; a <= 1; a += 0.1) { int[][] b = blend(pic1.getPixmap(), pic2.getPixmap(), a); out.setPixmap(b); } for (double a = 1; a >= 0; a -= 0.1) { int[][] b = blend(pic1.getPixmap(), pic2.getPixmap(), a); out.setPixmap(b); } } } //----------------------------------------------------------------- public static int[][] blend(int[][] b1, int[][] b2, double a) { int w = b1.length; int h = b1[0].length; int[][] b3 = new int[w][h]; for (int i = 0; i < w; i++){ for (int j = 0; j < h; j++){ int r1 = DWindow.getR(b1[i][j]); int g1 = DWindow.getG(b1[i][j]); int B1 = DWindow.getB(b1[i][j]); int r2 = DWindow.getR(b2[i][j]); int g2 = DWindow.getG(b2[i][j]); int B2 = DWindow.getB(b2[i][j]); b3[i][j] = DWindow.mixRGB((int)((a * r1) + (1 - a) * r2),(int)((a * g1) + (1 - a) * g2),(int)((a * B1) + (1 - a) * B2)); } } return b3; } //----------------------------------------------------------------- }
SM=2, CM=28, ST=30, KY=456, TR=60:00
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;
ERR = 60:00 ;