Contents

Develop
2003.04.23 11:00

[c] OpenGL 임시로 여기 올림..

조회 수 10324 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
#include<stdlib.h>
#include<GL/glut.h>
#include<math.h>

typedef float point3[4];

point3 v[] = {
        {0.0, 0.0, 1.0}, {0.0, 0.942809, -0.33333},
        {-0.816497, -0.471405, -0.33333}, {0.816497, -0.471405, -0.333333}
};

static GLfloat theta[] = {0.0, 0.0, 0.0};
int n;
int mode;

void triangle(point3 a, point3 b, point3 c){
        if(mode==0) glBegin(GL_LINE_LOOP);
        else glBegin(GL_POLYGON);
                if (mode==1) glNormal3fv(a);
                if (mode==2) glNormal3fv(a);
                glVertex3fv(a);
                if (mode==2) glNormal3fv(b);
                glVertex3fv(b);
                if (mode==2) glNormal3fv(c);
                glVertex3fv(c);
        glEnd();
}

void normal(point3 p){
        //double sqrt();
        float d = 0.0;
        int i;

        for(i=0; i<3; i++) d += p[i] * p[i];
        d = sqrt(d);
        if(d>0.0) for(i=0; i<3; i++) p[i] /= d;
}

void divside_triangle(point3 a, point3 b, point3 c, int m){
        point3 v1, v2, v3;
        int j;
        
        if(m>0){
                for(j=0; j<3; j++) v1[j] = a[j] + b[j];
                normal(v1);
                for(j=0; j<3; j++) v2[j] = a[j] + c[j];
                normal(v2);
                for(j=0; j<3; j++) v3[j] = b[j] + c[j];
                normal(v3);
                divside_triangle(a, v1, v2, m-1);
                divside_triangle(c, v2, v3, m-1);
                divside_triangle(b, v3, v1, m-1);
                divside_triangle(v1, v3, v2, m-1);
        }
        else triangle(a, b, c);
}

void tetrahedron(int m){
        divside_triangle(v[0], v[1], v[2], m);
        divside_triangle(v[3], v[2], v[1], m);
        divside_triangle(v[0], v[3], v[1], m);
        divside_triangle(v[0], v[2], v[3], m);
}

void display(void){
        glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
        glLoadIdentity();
        mode = 0;
        tetrahedron(n);
        mode = 1;
        glTranslatef(-2.0, 0.0, 0.0);
        tetrahedron(n);
        mode = 2;
        glTranslatef(4.0, 0.0, 0.0);
        tetrahedron(n);

        glFlush();
}

void myReshape(int w, int h){
        glViewport(0, 0, w, h);
        glMatrixMode(GL_PROJECTION);
        glLoadIdentity();

        if(w<=h) glOrtho(-4.0, 4.0, -4.0 * (GLfloat)h / (GLfloat)w, 
                4.0 * (GLfloat)h / (GLfloat)w, -10.0, 10.0);
        else glOrtho(-4.0 * (GLfloat)w / (GLfloat)h, 
                4.0 * (GLfloat)w / (GLfloat)h, -4.0, 4.0, -10.0, 10.0);
        glMatrixMode(GL_MODELVIEW);
        display();
}

void myinit(){
        GLfloat mat_specular[] = {1.0, 1.0, 1.0, 1.0};
        GLfloat mat_diffuse[] = {1.0, 1.0, 1.0, 1.0};
        GLfloat mat_ambient[] = {1.0, 1.0, 1.0, 1.0};
        GLfloat mat_shininess = {100.0};
        GLfloat light_ambient[] = {0.0, 0.0, 0.0, 1.0};
        GLfloat light_diffuse[] = {1.0, 1.0, 1.0, 1.0};
        GLfloat light_specular[] = {1.0, 1.0, 1.0, 1.0};

        glLightfv(GL_LIGHT0, GL_AMBIENT, light_ambient);
        glLightfv(GL_LIGHT0, GL_DIFFUSE, light_diffuse);
        glLightfv(GL_LIGHT0, GL_SPECULAR, light_specular);

        glMaterialfv(GL_FRONT, GL_SPECULAR, mat_specular);
        glMaterialfv(GL_FRONT, GL_AMBIENT, mat_ambient);
        glMaterialfv(GL_FRONT, GL_DIFFUSE, mat_diffuse);
        glMaterialf(GL_FRONT, GL_SHININESS, mat_shininess);

        glShadeModel(GL_SMOOTH);
        glEnable(GL_LIGHTING);
        glEnable(GL_LIGHT0);
        glEnable(GL_DEPTH_TEST);
        glClearColor(1.0, 1.0, 1.0, 1.0);
        glColor3f(0.0, 0.0, 0.0);
}

void main(int argc, char **argv){
        //n = atoi(argv[1]);
        n = 5;

        glutInit(&argc, argv);
        glutInitDisplayMode(GLUT_SINGLE | GLUT_RGB | GLUT_DEPTH);
        glutInitWindowSize(500, 500);
        glutCreateWindow("sphere");
        myinit();
        glutReshapeFunc(myReshape);
        glutDisplayFunc(display);
        glutMainLoop();
}


?

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
189 Develop [android] 레이아웃 사이즈 변경 (동적; programmatically) hooni 2016.11.07 1482
188 Database [mysql] MacOS에 MySQL 설치, 설정, 암호 재설정 file hooni 2017.12.15 1469
187 System/OS OpenSSL로 ROOT CA 생성 및 SSL 인증서 발급하기 hooni 2017.10.28 1460
186 System/OS [mac] Mac OS에서 재생되는 사운드를 녹음하는 방법 file hooni 2016.10.03 1444
185 System/OS [linux] wget 명령 사용 예제 hooni 2020.05.26 1436
184 Etc IT감사 기법 시험 file hooni 2017.06.14 1421
183 Etc 아이폰의 터치스크린 정확도 file hooni 2015.04.01 1417
182 Develop What is difference between Get, Post, Put and Delete? hooni 2018.02.28 1406
181 System/OS 무료로 HTTPS 적용하기 (Let's Encrypt) file hooni 2017.10.28 1405
180 Develop [ios] Swift 4 String, Date, DateFormatter 예제 hooni 2018.10.18 1397
179 System/OS SSH Passwordless Login Using SSH Keygen in 5 Easy Steps file hooni 2019.11.22 1390
178 Develop [swift] popToRoot 모달뷰, 네비게이션컨트롤러 한꺼번에 닫기 file hooni 2021.01.29 1385
Board Pagination Prev 1 ... 78 79 80 81 82 83 84 85 86 87 ... 98 Next
/ 98