]> git.mxchange.org Git - flightgear.git/blob - Scenery/mesh.h
75a144852e9d4d55f08a64205ee6b02f211ce88c
[flightgear.git] / Scenery / mesh.h
1 /**************************************************************************
2  * mesh.h -- data structures and routines for processing terrain meshes
3  *
4  * Written by Curtis Olson, started May 1997.
5  *
6  * Copyright (C) 1997  Curtis L. Olson  - curt@infoplane.com
7  *
8  * This program is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU General Public License as
10  * published by the Free Software Foundation; either version 2 of the
11  * License, or (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful, but
14  * WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
16  * General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program; if not, write to the Free Software
20  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
21  *
22  * $Id$
23  * (Log is kept at end of this file)
24  **************************************************************************/
25
26
27 #ifndef MESH_H
28 #define MESH_H
29
30
31 struct mesh {
32     /* start coordinates (in arc seconds) */
33     double originx, originy;
34
35     /* number of rows and columns */
36     int rows, cols;
37
38     /* Distance between row and column data points (in arc seconds) */
39     double row_step, col_step;
40
41     /* pointer to the actual mesh data dynamically allocated */
42     float *mesh_data;
43
44     /* a temporary values for the parser to use */
45     char option_name[32];
46     int do_data;
47     int cur_row, cur_col;
48 };
49
50
51 /* return a pointer to a new mesh structure (no data array allocated yet) */
52 struct mesh *(new_mesh)();
53
54 /* initialize the non-array mesh values */
55 void mesh_init(struct mesh *m);
56
57 /* return a pointer to a dynamically allocated array */
58 float *(new_mesh_data)(int nrows, int ncols);
59
60 /* set the option name in the mesh data structure */
61 void mesh_set_option_name(struct mesh *m, char *name);
62
63 /* set an option value in the mesh data structure */
64 void mesh_set_option_value(struct mesh *m, char *value);
65
66 /* do whatever needs to be done with the mesh now that it's been
67  * loaded, such as generating the OpenGL call list. */
68 void mesh_do_it(struct mesh *m);
69
70 /* return the current altitude based on mesh data.  We should rewrite
71  * this to interpolate exact values, but for now this is good enough */
72 double mesh_altitude(double lon, double lat);
73
74
75 #endif MESH_H
76
77
78 /* $Log$
79 /* Revision 1.4  1997/07/08 18:20:14  curt
80 /* Working on establishing a hard ground.
81 /*
82  * Revision 1.3  1997/06/22 21:44:41  curt
83  * Working on intergrating the VRML (subset) parser.
84  *
85  * Revision 1.2  1997/05/23 15:40:42  curt
86  * Added GNU copyright headers.
87  *
88  * Revision 1.1  1997/05/16 16:07:05  curt
89  * Initial revision.
90  *
91  */