|  |  |  | Grits Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | ||||
gdouble (*RoamHeightFunc) (gdouble lat,gdouble lon,gpointer user_data); struct RoamView; struct RoamPoint; RoamPoint * roam_point_new (double lat,double lon,double elev); void roam_point_add_triangle (RoamPoint *point,RoamTriangle *triangle); void roam_point_remove_triangle (RoamPoint *point,RoamTriangle *triangle); void roam_point_update_height (RoamPoint *point); void roam_point_update_projection (RoamPoint *point,RoamView *view); struct RoamTriangle; RoamTriangle * roam_triangle_new (RoamPoint *l,RoamPoint *m,RoamPoint *r,RoamDiamond *parent); void roam_triangle_free (RoamTriangle *triangle); void roam_triangle_add (RoamTriangle *triangle,RoamTriangle *left,RoamTriangle *base,RoamTriangle *right,RoamSphere *sphere); void roam_triangle_remove (RoamTriangle *triangle,RoamSphere *sphere); void roam_triangle_update_errors (RoamTriangle *triangle,RoamSphere *sphere); void roam_triangle_split (RoamTriangle *triangle,RoamSphere *sphere); void roam_triangle_draw (RoamTriangle *triangle); void roam_triangle_draw_normal (RoamTriangle *triangle); struct RoamDiamond; RoamDiamond * roam_diamond_new (RoamTriangle *parent0,RoamTriangle *parent1); void roam_diamond_add (RoamDiamond *diamond,RoamSphere *sphere); void roam_diamond_remove (RoamDiamond *diamond,RoamSphere *sphere); void roam_diamond_merge (RoamDiamond *diamond,RoamSphere *sphere); void roam_diamond_update_errors (RoamDiamond *diamond,RoamSphere *sphere); struct RoamSphere; RoamSphere * roam_sphere_new (); void roam_sphere_update_view (RoamSphere *sphere); void roam_sphere_update_errors (RoamSphere *sphere); void roam_sphere_split_one (RoamSphere *sphere); void roam_sphere_merge_one (RoamSphere *sphere); gint roam_sphere_split_merge (RoamSphere *sphere); void roam_sphere_draw (RoamSphere *sphere); void roam_sphere_draw_normals (RoamSphere *sphere); GList * roam_sphere_get_intersect (RoamSphere *sphere,gboolean all,gdouble n,gdouble s,gdouble e,gdouble w); void roam_sphere_free (RoamSphere *sphere);
A spherical version of the Realtime Optimally-Adapting Meshes (ROAM) algorithm is use for drawing the surface of the planet. ROAM provide a continuous level-of-detail mesh of the planet which is used by GritsOpenGL when drawing surface textures for GritsTiles.
This implementation of the ROAM algorithm is based on an octahedron as the base model.
gdouble (*RoamHeightFunc) (gdouble lat,gdouble lon,gpointer user_data);
See GritsHeightFunc
| 
 | the latitude | 
| 
 | the longitude | 
| 
 | user data passed to the function | 
| Returns : | the elevation | 
struct RoamView {
	gdouble model[16];
	gdouble proj[16];
	gint view[4];
	gint version;
};
Stores projection matrices
struct RoamPoint {
};
Points are used as vertices for triangles. A single point my be shared among several triangles in order to conceive space and avoid recalculating projections. Points also store a lot of cached data. The normal vertex normal is the averaged surface normal of each associated triangle.
RoamPoint * roam_point_new (double lat,double lon,double elev);
Create a new point at the given locaiton
| 
 | the latitude for the point | 
| 
 | the longitude for the point | 
| 
 | the elevation for the point | 
| Returns : | the new point | 
void roam_point_add_triangle (RoamPoint *point,RoamTriangle *triangle);
Associating a triangle with a point and update it's vertex normal.
| 
 | the point | 
| 
 | the to add | 
void roam_point_remove_triangle (RoamPoint *point,RoamTriangle *triangle);
Un-associating a triangle with a point and update it's vertex normal.
| 
 | the point | 
| 
 | the to add | 
void                roam_point_update_height            (RoamPoint *point);
Update the height (elevation) of a point based on the current height function
| 
 | the point | 
void roam_point_update_projection (RoamPoint *point,RoamView *view);
Updated the screen-space projection of a point.
| 
 | the point | 
| 
 | the view to use when projecting the point | 
struct RoamTriangle {
};
Triangles are one of the key datatypes in ROAM. The surface is made up of triangles. Each triangle has an associated "error". When the surface is being updated after the view changes, each triangles error is updated. Afterwards the triangles with the most error are split int to triangles, each with a lower error than the original.
Triangles store a lot of data about their location in the mesh so that they can be split and merged (unsplit) without having to recreate the mesh.
RoamTriangle * roam_triangle_new (RoamPoint *l,RoamPoint *m,RoamPoint *r,RoamDiamond *parent);
Create a new triangle consisting of three points.
| 
 | the left point | 
| 
 | the middle point | 
| 
 | the right point | 
| Returns : | the new triangle | 
void                roam_triangle_free                  (RoamTriangle *triangle);
Free data associated with a triangle
| 
 | the triangle | 
void roam_triangle_add (RoamTriangle *triangle,RoamTriangle *left,RoamTriangle *base,RoamTriangle *right,RoamSphere *sphere);
Add a triangle into the sphere's mesh using the given neighbors.
| 
 | the triangle | 
| 
 | the left neighbor | 
| 
 | the base neighbor | 
| 
 | the right neighbor | 
| 
 | the sphere to add the triangle to | 
void roam_triangle_remove (RoamTriangle *triangle,RoamSphere *sphere);
Remove a triangle from a sphere's mesh.
| 
 | the triangle | 
| 
 | the sphere to remove the triangle from | 
void roam_triangle_update_errors (RoamTriangle *triangle,RoamSphere *sphere);
Update the error value associated with a triangle. Called when the view changes.
| 
 | the triangle | 
| 
 | the sphere to use when updating errors | 
void roam_triangle_split (RoamTriangle *triangle,RoamSphere *sphere);
Split a triangle into two child triangles and update the sphere. triangle
| 
 | the triangle | 
| 
 | the sphere | 
void                roam_triangle_draw                  (RoamTriangle *triangle);
Draw the triangle. Use for debugging.
| 
 | the triangle | 
void                roam_triangle_draw_normal           (RoamTriangle *triangle);
Draw a normal vector for the triangle. Used while debugging.
| 
 | the triangle | 
struct RoamDiamond {
};
When two adjacent triangles are split, they, along with the four new child triangles, are added to a diamond which keeps track of them.
Like triangles, diamond have an error associated with it. However, when a diamonds error is small enough it is "merged". That is, the diamond along with the child triangles is removed and the original two triangles triangles are added back into the mesh.
RoamDiamond * roam_diamond_new (RoamTriangle *parent0,RoamTriangle *parent1);
Create a diamond to store information about two split triangles.
| 
 | a parent triangle | 
| 
 | a parent triangle | 
| Returns : | the new diamond | 
void roam_diamond_add (RoamDiamond *diamond,RoamSphere *sphere);
Add a diamond into the sphere's pool of diamonds. It will be check for possible merges.
| 
 | the diamond | 
| 
 | the sphere to add the diamond to | 
void roam_diamond_remove (RoamDiamond *diamond,RoamSphere *sphere);
Remove a diamond from the sphere's pool of diamonds.
| 
 | the diamond | 
| 
 | the sphere to remove the diamond from | 
void roam_diamond_merge (RoamDiamond *diamond,RoamSphere *sphere);
"Merge" a diamond back into two parent triangles. The original two triangles are added back into the sphere and the four child triangles as well as the diamond are removed.
| 
 | the diamond | 
| 
 | the sphere | 
void roam_diamond_update_errors (RoamDiamond *diamond,RoamSphere *sphere);
Update the error value associated with a diamond. Called when the view changes.
| 
 | the diamond | 
| 
 | the sphere to use when updating errors | 
struct RoamSphere {
};
The sphere keeps track of the triangles and diamonds in the mesh.
Originally the sphere consists of only 8 triangles forming a octahedron. These triangles are quickly split to create a smoother sphere.
void                roam_sphere_update_view             (RoamSphere *sphere);
Recreate the sphere's view matrices based on the current OpenGL state.
| 
 | the sphere | 
void                roam_sphere_update_errors           (RoamSphere *sphere);
Update triangle and diamond errors in the sphere.
| 
 | the sphere | 
void                roam_sphere_split_one               (RoamSphere *sphere);
Split the triangle with the greatest error.
| 
 | the sphere | 
void                roam_sphere_merge_one               (RoamSphere *sphere);
Merge the diamond with the lowest error.
| 
 | the sphere | 
gint                roam_sphere_split_merge             (RoamSphere *sphere);
Perform a predetermined number split-merge iterations.
| 
 | the sphere | 
| Returns : | the number splits and merges done | 
void                roam_sphere_draw                    (RoamSphere *sphere);
Draw the sphere. Use for debugging.
| 
 | the sphere | 
void                roam_sphere_draw_normals            (RoamSphere *sphere);
Draw all the surface normal vectors for the sphere. Used while debugging.
| 
 | the sphere | 
GList * roam_sphere_get_intersect (RoamSphere *sphere,gboolean all,gdouble n,gdouble s,gdouble e,gdouble w);
Lookup triangles withing the sphere that intersect a given lat-lon box.
| 
 | the sphere | 
| 
 | TRUE if non-leaf triangle should be returned as well | 
| 
 | the northern edge | 
| 
 | the southern edge | 
| 
 | the eastern edge | 
| 
 | the western edge | 
| Returns : | the list of intersecting triangles. | 
void                roam_sphere_free                    (RoamSphere *sphere);
Free data associated with a sphere
| 
 | the sphere |