Develop
2003.04.23 11:01
[c] OpenGL 관측점 이동
Views 7646 Comment 0
#include<GL/glut.h>
#include<math.h>
GLfloat vertices[][3] = {
{-1.0, -1.0, -1.0}, {1.0, -1.0, -1.0},
{1.0, 1.0, -1.0}, {-1.0, 1.0, -1.0}, {-1.0, -1.0, 1.0},
{1.0, -1.0, 1.0}, {1.0, 1.0, 1.0}, {-1.0, 1.0, 1.0}
};
GLfloat normals[][3] = {
{-1.0, -1.0, -1.0}, {1.0, -1.0, -1.0},
{1.0, 1.0, -1.0}, {-1.0, 1.0, -1.0}, {-1.0, -1.0, 1.0},
{1.0, -1.0, 1.0}, {1.0, 1.0, 1.0}, {-1.0, 1.0, 1.0}
};
GLfloat colors[][3] = {
{0.0, 0.0, 0.0}, {1.0, 0.0, 0.0},
{1.0, 1.0, 0.0}, {0.0, 1.1, 0.0}, {0.0, 0.0, 1.0},
{1.0, 0.0, 1.0}, {1.0, 1.0, 1.0}, {0.0, 1.0, 1.0}
};
void polygon(int a, int b, int c, int d){
glBegin(GL_POLYGON);
glColor3fv(colors[a]);
glNormal3fv(normals[a]);
glVertex3fv(vertices[a]);
glColor3fv(colors[b]);
glNormal3fv(normals[b]);
glVertex3fv(vertices[b]);
glColor3fv(colors[c]);
glNormal3fv(normals[c]);
glVertex3fv(vertices[c]);
glColor3fv(colors[d]);
glNormal3fv(normals[d]);
glVertex3fv(vertices[d]);
glEnd();
}
void colorcube(void){
polygon(0, 3, 2, 1);
polygon(2, 3, 7, 6);
polygon(0, 4, 7, 3);
polygon(1, 2, 6, 5);
polygon(4, 5, 6, 7);
polygon(0, 1, 5, 4);
}
static GLdouble viewer[] = {0.0, 0.0, 5.0};
GLdouble eyex=0.0, eyey=0.0, eyez=5.0;
GLdouble atx=0.0, aty=0.0, atz=0.0;
GLdouble upx=0.0, upy=1.0, upz=0.0;
GLdouble tmp;
void display(void){
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
glLoadIdentity();
gluLookAt(eyex, eyey, eyez, atx, aty, atz, upx, upy, upz);
colorcube();
glFlush();
glutSwapBuffers();
}
void mouse(int btn, int state, int x, int y){
int tm_x, tm_y;
if(btn==GLUT_LEFT_BUTTON && state==GLUT_DOWN){
if(x<250 && eyex>-10 && eyez>0){
tm_x = eyex - (250-x)/100;
}else if(x>250 && eyex<10 && eyez>0){
tm_x = eyex + (x-250)/100;
}
if(y<250 && eyey<10){
tm_y = eyey + (250-y)/100;
}else if(y>250 && eyey>-10){
tm_y = eyey - (y-250)/100;
}
tmp = 25 - tm_x*tm_x - tm_y*tm_y;
if(tmp>0){
eyez = sqrt( tmp );
eyex = tm_x;
eyey = tm_y;
}
glutPostRedisplay();
}
display();
}
void myReshape(int w, int h){
glViewport(0, 0, w, h);
glMatrixMode(GL_PROJECTION);
glLoadIdentity();
if(w<=h)
glFrustum(-2.0, 2.0, -2.0 * (GLfloat)h / (GLfloat)w, 2.0 * (GLfloat)h / (GLfloat)w, 2.0, 20.0);
else
glFrustum(-2.0, 2.0, -2.0 * (GLfloat)w / (GLfloat)h, 2.0 * (GLfloat)w / (GLfloat)h, 2.0, 20.0);
glMatrixMode(GL_MODELVIEW);
}
void main(int argc, char **argv){
glutInit(&argc, argv);
glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGB | GLUT_DEPTH);
glutInitWindowSize(500, 500);
glutCreateWindow("colorcube");
glutReshapeFunc(myReshape);
glutDisplayFunc(display);
glutMouseFunc(mouse);
glEnable(GL_DEPTH_TEST);
glutMainLoop();
}
No. | Category | Subject | Author | Date | Views |
---|---|---|---|---|---|
513 | Develop | [pdf] GPS의 동작 원리 ㅎㅎ | hooni | 2013.04.23 | 23908 |
512 | Etc | [flash] 자동차 엔진의 원리 (4행정 사이클 그림) | hooni | 2013.04.23 | 21288 |
511 | Develop | [doc] UI개발시 유용한 소프트웨어 (개발 및 디버깅 툴) | hooni | 2013.04.23 | 12936 |
510 | Develop | 모터에 대한 pid 제어.. ㅎㅎ | hooni | 2013.04.23 | 18942 |
509 | Develop | 레고 NXT 마인드스톰 밸런싱 로봇 ㅎㅎ | hooni | 2013.04.23 | 57773 |
508 | Etc | 아두이노 관련 정보.. | hooni | 2013.04.23 | 21822 |
507 | Develop | 레고 마인드스톰 NXT 수도쿠, 큐브 소스코드.. 20 | hooni | 2013.04.23 | 81604 |
506 | Develop | 밸런싱 로봇.. 최종.. (관련 논문도 첨부) ㅋㅋ | hooni | 2013.04.23 | 22881 |
505 | Develop | [js] 자바스크립트(Javascript) 코드를 동적으로 삽입하는 방법.. | hooni | 2013.04.23 | 22936 |
504 | Develop | [ios] Objective-C에서 SQLite 사용하기.. | hooni | 2013.04.23 | 14580 |
503 | Develop | [js] 동적(innerHTML)으로 자바스크립트 실행하기.. 2 | hooni | 2013.04.23 | 18238 |
502 | Develop | [js] 양원님이 공유해 주신 유료(5$란다ㅋ) 자료 ㅋㅋ | hooni | 2013.04.23 | 7948 |