現在地 >> メニュー >> サンプルコード::OpenGL >> 軌跡の描画+極座標

問題


以下の式はカージオイドである。

r = 1 + cosθ

この軌跡を描画せよ。


その他条件:

点をうって軌跡を描画。
ただし、glVertex()関数での点の座標設定は(0,0,0)固定。

移動には、glRotate()、glTranslate()を用いる。

答え


#include <cmath>
#include <cstdio>
#include <GL/glut.h>
#include <GL/glu.h>
#include <GL/gl.h>

void display();
void reshape(int w, int h);

void mouse(int button, int state,int x, int y);
void idle(void);


inline void DRAW_XYZ();
inline void CALC_AND_PLOT();

using namespace std;


inline void GLUT_INIT()
{
glutInitDisplayMode(GLUT_RGBA| GLUT_DOUBLE | GLUT_DEPTH);
glutInitWindowSize(400,400);
}

inline void GLUT_CALL_FUNC()
{
glutDisplayFunc(display);
glutReshapeFunc(reshape);
glutMouseFunc(mouse);
}

inline void MY_INIT()
{
glClearColor(1.0, 1.0, 1.0, 1.0);
}


int main(int argc, char **argv)
{
glutInit(&argc,argv);
GLUT_INIT();
glutCreateWindow("window name");
GLUT_CALL_FUNC();
MY_INIT();
glutMainLoop();

return 0;
}

/********[ここからコールバック]****************************************/
void display()
{

glLoadIdentity();
gluLookAt(5.0, 6.0, 7.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0);


DRAW_XYZ();


glEnable(GL_DEPTH_TEST);

glColor3d(0.7,0.1,0.5);
CALC_AND_PLOT();

glDisable(GL_DEPTH_TEST);


glutSwapBuffers();


}


double frame;
void reshape(int w, int h)
{
glViewport(0, 0, w, h);
glMatrixMode(GL_PROJECTION);
glLoadIdentity();
gluPerspective(30.0, (double)w / (double)h, 1.0, 100.0);
glMatrixMode(GL_MODELVIEW);
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
frame=0;
}



void mouse(int button, int state, int x, int y)
{
switch (button) {
case GLUT_LEFT_BUTTON:
if (state == GLUT_DOWN) {
glutIdleFunc(idle);
}
else {
glutIdleFunc(0);
}
break;
default:
break;
}
}

void idle(void)
{
glutPostRedisplay();
}

/**********[ここから各種関数]***********************/
inline void DRAW_XYZ()
{
glBegin(GL_LINES);

glColor3d(0,1,0);//x
glVertex2d(-100,0);
glVertex2d(100, 0);

glColor3d(1,0,0);//y
glVertex2d(0,0);
glVertex2d(0,100);

glColor3d(0,0,1);//z
glVertex3d(0,0,-100);
glVertex3d(0,0, 100);
glEnd();

}



inline void CALC_AND_PLOT()
{
#define PI_OVER_180 0.0174532925

static double r;

r = 1 + cos(frame*PI_OVER_180);

glRotated(frame,0,0,1);
glTranslated(r,0,0);
glPointSize(2);
glBegin(GL_POINTS);
glVertex3d(0,0,0);
glEnd();



frame++;
if(frame >360)
{
frame += 0.1;
}

}

目次

― その他 ―

Wiki内検索

計測中...(07.10.8〜)

Save The World






▲よろしければ広告のクリックもお願いします


▲ランキングに参加しました

管理人/副管理人のみ編集できます