proper scale, 1min == 1day, accel/deccel time, object scale x12, orbit movement
This commit is contained in:
parent
456a3e0a76
commit
bd43f5bc79
@ -102,7 +102,7 @@ surface_t * mkCube(void) {
|
|||||||
/*!\brief fabrique et renvoie une surface représentant une sphère
|
/*!\brief fabrique et renvoie une surface représentant une sphère
|
||||||
* centrée en zéro et de rayon 1. Elle est découpée en \a longitudes
|
* centrée en zéro et de rayon 1. Elle est découpée en \a longitudes
|
||||||
* longitudes et \a latitudes latitudes. */
|
* longitudes et \a latitudes latitudes. */
|
||||||
surface_t * mkSphere(int longitudes, int latitudes, double s) {
|
surface_t * mkSphere(int longitudes, int latitudes) {
|
||||||
triangle_t * t;
|
triangle_t * t;
|
||||||
vertex_t * data;
|
vertex_t * data;
|
||||||
double phi, theta, r, y;
|
double phi, theta, r, y;
|
||||||
@ -118,8 +118,8 @@ surface_t * mkSphere(int longitudes, int latitudes, double s) {
|
|||||||
assert(t);
|
assert(t);
|
||||||
for(z = 0, k = 0; z <= latitudes; ++z) {
|
for(z = 0, k = 0; z <= latitudes; ++z) {
|
||||||
theta = -M_PI_2 + z * cMPI_Lat;
|
theta = -M_PI_2 + z * cMPI_Lat;
|
||||||
y = sin(theta) * s;
|
y = sin(theta);
|
||||||
r = cos(theta) * s;
|
r = cos(theta);
|
||||||
for(x = 0; x <= longitudes; ++x, ++k) {
|
for(x = 0; x <= longitudes; ++x, ++k) {
|
||||||
phi = x * c2MPI_Long;
|
phi = x * c2MPI_Long;
|
||||||
data[k].position.x = r * cos(phi);
|
data[k].position.x = r * cos(phi);
|
||||||
|
2
moteur.h
2
moteur.h
@ -155,7 +155,7 @@ extern "C" {
|
|||||||
/* dans geometry.c */
|
/* dans geometry.c */
|
||||||
extern surface_t * mkQuad(void);
|
extern surface_t * mkQuad(void);
|
||||||
extern surface_t * mkCube(void);
|
extern surface_t * mkCube(void);
|
||||||
extern surface_t * mkSphere(int longitudes, int latitudes, double s);
|
extern surface_t * mkSphere(int longitudes, int latitudes);
|
||||||
# ifdef __cplusplus
|
# ifdef __cplusplus
|
||||||
}
|
}
|
||||||
# endif
|
# endif
|
||||||
|
37
window.c
37
window.c
@ -54,6 +54,7 @@ static int _wW = 1200, _wH = 1000;
|
|||||||
static int _xm = 400, _ym = 300;
|
static int _xm = 400, _ym = 300;
|
||||||
|
|
||||||
static int _pause = 0;
|
static int _pause = 0;
|
||||||
|
static float _s = 1.0f;
|
||||||
|
|
||||||
/*!\brief paramètre l'application et lance la boucle infinie. */
|
/*!\brief paramètre l'application et lance la boucle infinie. */
|
||||||
int main(int argc, char ** argv) {
|
int main(int argc, char ** argv) {
|
||||||
@ -91,12 +92,12 @@ void init(void) {
|
|||||||
uint sun_id, mercury_id, venus_id, earth_id;
|
uint sun_id, mercury_id, venus_id, earth_id;
|
||||||
/*vec4 g = {0, 1, 0, 1};*/
|
/*vec4 g = {0, 1, 0, 1};*/
|
||||||
/* on créé nos trois type de surfaces */
|
/* on créé nos trois type de surfaces */
|
||||||
_sun = mkSphere(12, 12, 1); /*ça fait 12x12x2 trianles !*/
|
_sun = mkSphere(12, 12); /*ça fait 12x12x2 trianles !*/
|
||||||
/* on change les couleurs de surfaces */
|
/* on change les couleurs de surfaces */
|
||||||
/*_sun->dcolor = g; */
|
/*_sun->dcolor = g; */
|
||||||
_planet[0] = mkSphere(12, 12, (1/227.0f) * 12.0f);
|
_planet[0] = mkSphere(12, 12);
|
||||||
_planet[1] = mkSphere(12, 12, (1/113.0f) * 12.0f);
|
_planet[1] = mkSphere(12, 12);
|
||||||
_planet[2] = mkSphere(12, 12, (1/108.0f) * 12.0f);
|
_planet[2] = mkSphere(12, 12);
|
||||||
|
|
||||||
sun_id = getTexFromBMP("images/2k-sun.bmp");
|
sun_id = getTexFromBMP("images/2k-sun.bmp");
|
||||||
mercury_id = getTexFromBMP("images/2k-mercury.bmp");
|
mercury_id = getTexFromBMP("images/2k-mercury.bmp");
|
||||||
@ -154,28 +155,34 @@ void draw(void) {
|
|||||||
/*_cam.y = 1.0 - (_ym - (_wH >> 1)) / 300.0f;*/
|
/*_cam.y = 1.0 - (_ym - (_wH >> 1)) / 300.0f;*/
|
||||||
lookAt(mvMat, _cam.x, _cam.y, _cam.z, _cam.x - sin(_cam.theta), 1.0 - (_ym - (_wH >> 1)) / 300.0f, _cam.z - cos(_cam.theta), 0.0, 1.0, 0.0);
|
lookAt(mvMat, _cam.x, _cam.y, _cam.z, _cam.x - sin(_cam.theta), 1.0 - (_ym - (_wH >> 1)) / 300.0f, _cam.z - cos(_cam.theta), 0.0, 1.0, 0.0);
|
||||||
|
|
||||||
|
// scales https://www.jpl.nasa.gov/infographics/infographic.view.php?id=10749
|
||||||
|
|
||||||
/* la sphère est laissée au centre et tourne autour de son axe y */
|
/* la sphère est laissée au centre et tourne autour de son axe y */
|
||||||
memcpy(nmv, mvMat, sizeof nmv); /* copie mvMat dans nmv */
|
memcpy(nmv, mvMat, sizeof nmv); /* copie mvMat dans nmv */
|
||||||
rotate(nmv, a, 0.0f, 1.0f, 0.0f);
|
rotate(nmv, (a / 24.5f), 0.0f, 1.0f, 0.0f);
|
||||||
translate(nmv, 0.0f, 1.0f, 0.0f);
|
translate(nmv, 0.0f, 1.0f, 0.0f);
|
||||||
|
scale(nmv, 2,2,2);
|
||||||
transform_n_raster(_sun, nmv, projMat);
|
transform_n_raster(_sun, nmv, projMat);
|
||||||
|
|
||||||
memcpy(nmv, mvMat, sizeof nmv); /* copie mvMat dans nmv */
|
memcpy(nmv, mvMat, sizeof nmv); /* copie mvMat dans nmv */
|
||||||
rotate(nmv, a, 0.0f, 1.0f, 0.0f); // orbit mouvement
|
rotate(nmv, (a / 88.0f), 0.0f, 1.0f, 0.0f); // orbit mouvement
|
||||||
translate(nmv, 10.0f, 1.0f, 0.0f);
|
translate(nmv, 10.0f, 1.0f, 0.0f);
|
||||||
rotate(nmv, a, 0.0f, 1.0f, 0.0f); // rotation
|
scale(nmv, (1/227.0f) * 12.0f, (1/227.0f) * 12.0f, (1/227.0f) * 12.0f);
|
||||||
|
rotate(nmv, (a / 176.0f), 0.0f, 1.0f, 0.0f); // rotation
|
||||||
transform_n_raster(_planet[0], nmv, projMat);
|
transform_n_raster(_planet[0], nmv, projMat);
|
||||||
|
|
||||||
memcpy(nmv, mvMat, sizeof nmv); /* copie mvMat dans nmv */
|
memcpy(nmv, mvMat, sizeof nmv); /* copie mvMat dans nmv */
|
||||||
rotate(nmv, a - 10, 0.0f, 1.0f, 0.0f); // orbit mouvement
|
rotate(nmv, (a / 224.7f), 0.0f, 1.0f, 0.0f); // orbit mouvement
|
||||||
translate(nmv, 20.0f, 1.0f, 0.0f);
|
translate(nmv, 20.0f, 1.0f, 0.0f);
|
||||||
rotate(nmv, a, 0.0f, -1.0f, 0.0f); // rotation anti-clockwise
|
scale(nmv, (1/113.0f) * 12.0f, (1/113.0f) * 12.0f, (1/113.0f) * 12.0f);
|
||||||
|
rotate(nmv, (a / 116.75f), 0.0f, -1.0f, 0.0f); // rotation anti-clockwise
|
||||||
transform_n_raster(_planet[1], nmv, projMat);
|
transform_n_raster(_planet[1], nmv, projMat);
|
||||||
|
|
||||||
memcpy(nmv, mvMat, sizeof nmv); /* copie mvMat dans nmv */
|
memcpy(nmv, mvMat, sizeof nmv); /* copie mvMat dans nmv */
|
||||||
rotate(nmv, a - 20, 0.0f, 1.0f, 0.0f); // orbit mouvement
|
rotate(nmv, (a / 365.2425f), 0.0f, 1.0f, 0.0f);
|
||||||
translate(nmv, 30.0f, 1.0f, 0.0f);
|
translate(nmv, 30.0f, 1.0f, 0.0f);
|
||||||
rotate(nmv, a, 0.0f, 1.0f, 0.0f); // rotation
|
scale(nmv, (1/108.0f) * 12.0f, (1/108.0f) * 12.0f, (1/108.0f) * 12.0f);
|
||||||
|
rotate(nmv, a, 0.0f, 1.0f, 0.0f);
|
||||||
transform_n_raster(_planet[2], nmv, projMat);
|
transform_n_raster(_planet[2], nmv, projMat);
|
||||||
|
|
||||||
/* déclarer qu'on a changé (en bas niveau) des pixels du screen */
|
/* déclarer qu'on a changé (en bas niveau) des pixels du screen */
|
||||||
@ -183,7 +190,7 @@ void draw(void) {
|
|||||||
/* fonction permettant de raffraîchir l'ensemble de la fenêtre*/
|
/* fonction permettant de raffraîchir l'ensemble de la fenêtre*/
|
||||||
gl4dpUpdateScreen(NULL);
|
gl4dpUpdateScreen(NULL);
|
||||||
if (_pause != 1)
|
if (_pause != 1)
|
||||||
a += 360 * dt;
|
a += (dt * 60) * _s; // 1 minute == 1 day
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!\brief intercepte l'événement clavier pour modifier les options. */
|
/*!\brief intercepte l'événement clavier pour modifier les options. */
|
||||||
@ -195,8 +202,10 @@ void key(int keycode) {
|
|||||||
case GL4DK_DOWN:
|
case GL4DK_DOWN:
|
||||||
break;
|
break;
|
||||||
case GL4DK_RIGHT:
|
case GL4DK_RIGHT:
|
||||||
|
_s += 30.0f;
|
||||||
break;
|
break;
|
||||||
case GL4DK_LEFT:
|
case GL4DK_LEFT:
|
||||||
|
_s -= 30.0f;
|
||||||
break;
|
break;
|
||||||
case GL4DK_w:
|
case GL4DK_w:
|
||||||
_cam.x += -_v * step * sin(_cam.theta);
|
_cam.x += -_v * step * sin(_cam.theta);
|
||||||
@ -230,6 +239,10 @@ void key(int keycode) {
|
|||||||
_v = 0.5f;
|
_v = 0.5f;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case GL4DK_f:
|
||||||
|
break;
|
||||||
|
case GL4DK_z:
|
||||||
|
break;
|
||||||
case GL4DK_t: /* 't' la texture */
|
case GL4DK_t: /* 't' la texture */
|
||||||
_use_tex = !_use_tex;
|
_use_tex = !_use_tex;
|
||||||
if(_use_tex) {
|
if(_use_tex) {
|
||||||
|
Loading…
Reference in New Issue
Block a user