/************************************************************************** * stars.c -- data structures and routines for managing and rendering stars. * * Written by Curtis Olson, started August 1997. * * Copyright (C) 1997 Curtis L. Olson - curt@infoplane.com * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as * published by the Free Software Foundation; either version 2 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. * * $Id$ * (Log is kept at end of this file) **************************************************************************/ #ifdef WIN32 # include #endif #include #include #include #include #include #include "stars.h" #include "../constants.h" #include "../general.h" #include "../GLUT/views.h" #include "../Aircraft/aircraft.h" #define EpochStart (631065600) #define DaysSinceEpoch(secs) (((secs)-EpochStart)*(1.0/(24*3600))) static GLint stars; /* Initialize the Star Management Subsystem */ void fgStarsInit() { FILE *fd; struct GENERAL *g; char path[1024]; char line[256], name[256]; char *tmp_ptr; double right_ascension, declination, magnitude; GLfloat mag[4] = {0.0, 0.0, 0.0, 1.0}; int count; g = &general; /* build the full path name to the stars data base file */ path[0] = '\0'; strcat(path, g->root_dir); strcat(path, "/Scenery/"); strcat(path, "Stars.dat"); printf("Loading Stars: %s\n", path); if ( (fd = fopen(path, "r")) == NULL ) { printf("Cannot open star file: '%s'\n", path); return; } stars = glGenLists(1); glNewList( stars, GL_COMPILE ); glBegin( GL_POINTS ); /* read in each line of the file */ count = 0; while ( (fgets(line, 256, fd) != NULL) && (count < FG_MAX_STARS) ) { tmp_ptr = line; /* advance to first non-whitespace character */ while ( (tmp_ptr[0] == ' ') || (tmp_ptr[0] == '\t') ) { tmp_ptr++; } if ( tmp_ptr[0] == '#' ) { /* comment */ } else if ( strlen(tmp_ptr) == 0 ) { /* blank line */ } else { /* star data line */ fscanf(fd, "%s %lf %lf %lf\n", name, &right_ascension, &declination, &magnitude); /* printf("Found star: %d %s, %.3f %.3f %.3f\n", count, name, right_ascension, declination, magnitude); */ count++; magnitude = magnitude * 0.8 + 0.2; mag[0] = mag[1] = mag[2] = magnitude; glColor3f( mag[0], mag[1], mag[2] ); glVertex3f( 190000.0 * sin(right_ascension) * cos(declination), 190000.0 * cos(right_ascension) * cos(declination), 190000.0 * sin(declination) ); } /* if valid line */ } /* while */ glEnd(); glEndList(); } /* Draw the Stars */ void fgStarsRender() { struct FLIGHT *f; struct VIEW *v; double angle; f = ¤t_aircraft.flight; v = ¤t_view; printf("RENDERING STARS\n"); glDisable( GL_FOG ); glDisable( GL_LIGHTING ); glPushMatrix(); /* set lighting parameters for stars */ /* amb[0] = amb[1] = amb[2] = 1.0; diff[0] = diff[1] = diff[2] = 1.0; glLightfv(GL_LIGHT0, GL_AMBIENT, amb ); glLightfv(GL_LIGHT0, GL_DIFFUSE, diff ); */ glTranslatef( v->view_pos.x, v->view_pos.y, v->view_pos.z ); angle = FG_2PI * fmod(DaysSinceEpoch(time(NULL)), 1.0); glRotatef( -angle * RAD_TO_DEG, 0.0, 0.0, 1.0 ); printf("Rotating stars by %.2f\n", -angle * RAD_TO_DEG); glCallList(stars); glPopMatrix(); glEnable( GL_LIGHTING ); glEnable( GL_FOG ); } /* $Log$ /* Revision 1.3 1997/08/29 17:55:28 curt /* Worked on properly aligning the stars. /* * Revision 1.2 1997/08/27 21:32:30 curt * Restructured view calculation code. Added stars. * * Revision 1.1 1997/08/27 03:34:48 curt * Initial revision. * */