[소스코드(컴퓨터 그래픽스)]midpoint, clipping알고리즘 scaling,translation,rotation 모두 구현
*열*
다운로드
장바구니
소개글
컴퓨터 그래픽스 라는 과목을 수강하면서과제로 나왔던 것입니다.
midpoint로 선을 그리는 소스와 clipping알고리즘을 이용하여 선을 클리핑하는 소스, 그리고 scaling,translation,rotation 모두 구현하였습니다...
마우스 오른쪽버튼을 누르면 midpoint알고리즘에 의해 선을 rubber banding하며 그립니다...
그리고 마우스 왼쪽버튼을 누르고 영영지정하면 선을 클리핑합니다.....
자바로 작성하였습니다. 이 프로그램을 작성하는데 꼬박 2주가 걸렸군요.....
그리고 소스코드를 작성하면서...주석을 달아 놓았습니다... 해석하기 편할거에요..
컴파일 실행환경
자바로 컴파일 하시고 실행하면 됩니다...jdk1.5 환경에서 하는것이 깔끔하고 좋을것 같군요
본문내용
import javax.swing.*;import java.awt.*;
import java.awt.event.*;
import java.lang.Math;
import java.util.Vector;
import javax.swing.JInternalFrame;
import java.awt.BorderLayout;
import java.awt.Color;
import javax.swing.JPanel;
import javax.swing.JDesktopPane;
import javax.swing.JButton;
import java.awt.FlowLayout;
import javax.swing.JTextField;
import javax.swing.JToolBar;
import javax.swing.SwingConstants;
import java.awt.Dimension;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import javax.swing.JLabel;
import javax.swing.JList;
public class e extends JPanel{
private JTextField textField_5;
int[] array1 = new int[100];
int[] array2 = new int[100];
int[] array3 = new int[100];
int[] array4 = new int[100];
int select; //여러선 중에서 하나의 선을 선택한 변수를 저장 하기 위해서
int count=0;
boolean flag=false; //러버 밴딩을 선택적으로 그래주기 위해
private JTextField textField_4;
private JTextField textField_3;
private JTextField textField_2;
private JTextField textField_1;
private JTextField textField;
int text1,text2; //텍스트 필드의 값을 받아오기 위한 정수 변수
int a,b,c,d; //마우스 오른쪽 버튼을 클릭 했을 때 초기값를 저장 할 변수
int last_c,last_d; //마우스 클릭했던 이전 값을 저장하여 선의 trace를 지우기 위한 변
int xmin,ymin,xmax,ymax;
Graphics g; //페인트 함수로 그림 그리기 위한 그래픽 객체 선언
JFrame f;
public e(){ //생성자
g=getGraphics();
f=new JFrame("컴퓨터 그래픽스 과제2");
f.getContentPane().setBackground(new Color(255, 255, 255));
///////////마우스 오른쪽 버튼을 누르면 선을 그릴 좌표를 인식하는 이밴트가 먹힌다....
addMouseListener(new MouseAdapter(){
public void mousePressed(MouseEvent e){ //마우스를 찍을 때 첫번째 좌표를 변수 x,y에 넣는다.
if ( SwingUtilities.isRightMouseButton(e) ) { //마우스 오른쪽 버튼을 눌렀을 때 이밴트가 먹히도록 한다....
flag=true;
a=e.getX(); //마우스가 눌러졌을 때 좌표를 변수에 저장
b=e.getY();
last_c=a;
last_d=b;
// repaint(); //페인트 함수를 불러서 해당되는 픽셀 값을 찍어줌
//System.out.println(a);
//System.out.println(b);
}
}
});
addMouseMotionListener(new MouseMotionAdapter(){
public void mouseDragged(MouseEvent e){ //마우스를 드래그 하는동안의 좌표를 변수 xe,ye에 넣는다.
if ( SwingUtilities.isRightMouseButton(e) ) { //마우스 오른쪽 버튼을 눌렀을 때 이밴트가 먹히도록 한다....
last_c=c; //마우스 찍었을 때 이전 좌표값을 저장
last_d=d;
c=e.getX(); //마우스 드래그 하는 동안의 좌표값을 저장
d=e.getY();
repaint(); //페인트 함수를 불러서 해당되는 픽셀 값을 찍어줌
}
//System.out.println(c);
//System.out.println(d);
}
});
addMouseListener(new MouseAdapter(){
public void mouseReleased(MouseEvent e){ //마우스를 뗏을 때의 좌표를 변수 xe,ye에 넣는다.
if ( SwingUtilities.isRightMouseButton(e) ) { //마우스 오른쪽 버튼을 눌렀을 때 이밴트가 먹히도록 한다....
flag=false;
array1[count]=a;
array2[count]=b;
array3[count]=c;
array4[count]=d;
count++;
//repaint(); //페인트 함수를 불러서 해당되는 픽셀 값을 찍어줌
}
//System.out.println(c);
//System.out.println(d);
}
});
/////////마우스 왼쪽 버튼을 누르면 클리핑 할 좌표를 인식하는 이밴트가 먹힌다....
addMouseListener(new MouseAdapter(){
public void mousePressed(MouseEvent ee){ //마우스 왼쪽 버튼을 눌렀을 때 이밴트가 먹히도록 한다....
if ( SwingUtilities.isLeftMouseButton(ee) ){
xmin = ee.getX();
ymin = ee.getY();
}
}
});
addMouseListener(new MouseAdapter(){
public void mouseReleased(MouseEvent ee){
if ( SwingUtilities.isLeftMouseButton(ee) ){ //마우스 왼쪽 버튼을 눌렀을 때 이밴트가 먹히도록 한다....
xmax = ee.getX();
ymax = ee.getY();
for(int i=0;i<count;i++){
boolean clip= LineClip(array1[i],array2[i],array3[i],array4[i], xmin, xmax, ymin, ymax); //코헨서틀랜드 알고리즘에 넣어 클리핑 영역에 해당 되는지 검사한다...
if(clip) //만약 클리핑 영역에 해당 된다면
{