grits_viewer_get_rotation(env->viewer, &x, &y, &z);
/* Setup projection */
- gint win_width = GTK_WIDGET(opengl)->allocation.width;
- gint win_height = GTK_WIDGET(opengl)->allocation.height;
- float scale = CLAMP(MIN(win_width,win_height)/2.0 * 0.1, 40, 100);
+ GtkAllocation alloc;
+ gtk_widget_get_allocation(GTK_WIDGET(opengl), &alloc);
+ float scale = CLAMP(MIN(alloc.width,alloc.height)/2.0 * 0.1, 40, 100);
float offset = scale + 20;
- glTranslatef(win_width - offset, offset, 0);
+ glTranslatef(alloc.width - offset, offset, 0);
/* Setup state */
- glClear(GL_DEPTH_BUFFER_BIT);
glEnable(GL_COLOR_MATERIAL);
- glEnable(GL_DEPTH_TEST);
- glDisable(GL_CULL_FACE);
glEnable(GL_POLYGON_SMOOTH);
glEnable(GL_LINE_SMOOTH);
/* Info */
static void info_expose(GritsCallback *compass, GritsOpenGL *opengl, gpointer _env)
{
- gint win_width = GTK_WIDGET(opengl)->allocation.width;
- gint win_height = GTK_WIDGET(opengl)->allocation.height;
+ GtkAllocation alloc;
+ gtk_widget_get_allocation(GTK_WIDGET(opengl), &alloc);
- /* Create cairo surface */
+ /* Create cairo surface */
guint tex = 0;
- const gchar *label0 = "Location: %7.3lf°, %8.3lf°, %4.0fm";
- const gchar *label1 = "Cursor: %7.3lf°, %8.3lf°, %4.0fm";
- gdouble width = 300;
+ gdouble width = 600;
gdouble height = 200;
cairo_surface_t *surface = cairo_image_surface_create(CAIRO_FORMAT_ARGB32, width, height);
cairo_t *cairo = cairo_create(surface);
- /* Text */
- gdouble lat, lon, elev;
+ /* Setup text */
+ gdouble lat, lon, elev, plat=0, plon=0, pelev=0;
grits_viewer_get_location(GRITS_VIEWER(opengl), &lat, &lon, &elev);
- gchar *text0 = g_strdup_printf(label0, lat, lon, elev);
- gchar *text1 = g_strdup_printf(label1, lat, lon, elev);
-
- /* Draw outline */
- cairo_set_line_width(cairo, 3);
- cairo_set_source_rgba(cairo, 0, 0, 0, 0.75);
- cairo_move_to(cairo, 2, 20); cairo_text_path(cairo, text0);
- cairo_move_to(cairo, 2, 40); cairo_text_path(cairo, text1);
- cairo_stroke(cairo);
-
- /* Draw filler */
- cairo_set_source_rgba(cairo, 1, 1, 1, 1);
- cairo_move_to(cairo, 2, 20); cairo_show_text(cairo, text0);
- cairo_move_to(cairo, 2, 40); cairo_show_text(cairo, text1);
+ grits_viewer_get_pointer(GRITS_VIEWER(opengl), &plat, &plon, &pelev);
+ const gchar *template =
+ "Location: %7.3lf°, %8.3lf°, %4.0fm\n"
+ "Cursor: %7.3lf°, %8.3lf°, %4.0fm\n" ;
+ gchar *string = g_strdup_printf(template,
+ lat, lon, elev,
+ plat, plon, pelev);
/* Setup pango */
PangoLayout *layout = pango_cairo_create_layout(cairo);
- PangoFontDescription *font = pango_font_description_from_string("Mono 9");
+ PangoFontDescription *font = pango_font_description_from_string("Mono 14");
pango_layout_set_font_description(layout, font);
pango_font_description_free(font);
- pango_layout_set_text(layout, text0, -1);
+ pango_layout_set_text(layout, string, -1);
pango_cairo_update_layout(cairo, layout);
cairo_set_line_join(cairo, CAIRO_LINE_JOIN_ROUND);
cairo_move_to(cairo, 2, 40);
glEnable(GL_TEXTURE_2D);
glBindTexture(GL_TEXTURE_2D, tex);
glDisable(GL_CULL_FACE);
- glTranslatef(win_width - width, win_height - height, 0);
+ glTranslatef(alloc.width - width, alloc.height - height, 0);
glBegin(GL_QUADS);
glTexCoord2f(1, 0); glVertex3f(width, 0 , 0); // 0 - 3 0
glTexCoord2f(1, 1); glVertex3f(width, height, 0); // 1 - | |
glTexCoord2f(0, 1); glVertex3f(0 , height, 0); // 2 - | |
glTexCoord2f(0, 0); glVertex3f(0 , 0 , 0); // 3 - 2----1
glEnd();
+
+ /* cleanup */
+ g_free(string);
}
/***********
/* Add compass */
GritsCallback *compass = grits_callback_new(compass_expose, env);
- grits_viewer_add(viewer, GRITS_OBJECT(compass), GRITS_LEVEL_HUD, FALSE);
+ grits_viewer_add(viewer, GRITS_OBJECT(compass), GRITS_LEVEL_HUD, TRUE);
g_signal_connect(compass, "clicked", G_CALLBACK(compass_click), viewer);
grits_object_set_cursor(GRITS_OBJECT(compass), GDK_CROSS);
env->refs = g_list_prepend(env->refs, compass);
/* Add info */
- //GritsCallback *info = grits_callback_new(info_expose, env);
- //grits_viewer_add(viewer, GRITS_OBJECT(info), GRITS_LEVEL_HUD, FALSE);
- //env->refs = g_list_prepend(env->refs, info);
- (void)info_expose;
+ GritsCallback *info = grits_callback_new(info_expose, env);
+ grits_viewer_add(viewer, GRITS_OBJECT(info), GRITS_LEVEL_HUD, TRUE);
+ env->refs = g_list_prepend(env->refs, info);
+ //(void)info_expose;
/* Add background */
//GritsTile *background = grits_tile_new(NULL, NORTH, SOUTH, EAST, WEST);
if (env->viewer) {
for (GList *cur = env->refs; cur; cur = cur->next)
grits_viewer_remove(env->viewer, cur->data);
- g_list_free(env->refs);
+ g_list_free_full(env->refs, g_object_unref);
g_object_unref(env->viewer);
g_object_unref(env->prefs);
glDeleteTextures(1, &env->tex);