X-Git-Url: http://pileus.org/git/?p=grits;a=blobdiff_plain;f=src%2Fplugin-radar.c;h=f4b68d7ac0ec749505b668af54a2480648149397;hp=0722edd2952a5cd1a73d44b3f449186143add6d4;hb=8efa2df296f672505211b4360c10279d9d57be22;hpb=d527bfdb9682b1824e1c2df318a92291aaa48860 diff --git a/src/plugin-radar.c b/src/plugin-radar.c index 0722edd..f4b68d7 100644 --- a/src/plugin-radar.c +++ b/src/plugin-radar.c @@ -15,6 +15,9 @@ static int nred, ngreen, nblue; static char red[256], green[256], blue[256]; static guint sweep_tex = 0; +static AWeatherGui *gui = NULL; +static Radar *radar = NULL; + static guint8 get_alpha(guint8 db) { if (db == BADVAL) return 0; @@ -28,27 +31,6 @@ static guint8 get_alpha(guint8 db) else return 255; } -//#ifdef USE_TWO_BYTE_PRECISION -//#define F_FACTOR 100.0 -//#define F_DR_FACTOR 1000.0 -//#define F_DZ_RANGE_OFFSET 50 -//#else -//#define F_FACTOR 2.0 -//#define F_DR_FACTOR 10.0 -//#define F_DZ_RANGE_OFFSET 32 -//#endif -//#define F_OFFSET 4 -//static float dz_f(Range x) -//{ -// if (x >= F_OFFSET) -// return (((float)x-F_OFFSET)/F_FACTOR - F_DZ_RANGE_OFFSET); -// if (x == 0) return BADVAL; -// if (x == 1) return RFVAL; -// if (x == 2) return APFLAG; -// if (x == 3) return NOECHO; -// return BADVAL; -//} - /* Convert a sweep to an 2d array of data points */ static void bscan_sweep(Sweep *sweep, guint8 **data, int *width, int *height) { @@ -102,12 +84,15 @@ static void load_sweep(Sweep *sweep) } /* Load the default sweep */ -static gboolean configure(GtkWidget *da, GdkEventConfigure *event, gpointer user_data) +static gboolean map(GtkWidget *da, GdkEvent *event, gpointer user_data) { - g_message("radar:configure"); - Sweep *first = (Sweep*)user_data; + g_message("radar:map"); + aweather_gui_gl_begin(gui); + Sweep *first = radar->v[0]->sweep[0]; if (cur_sweep == NULL) load_sweep(first); + aweather_gui_gl_end(gui); + return FALSE; } @@ -175,19 +160,24 @@ static gboolean expose(GtkWidget *da, GdkEventExpose *event, gpointer user_data) glEnd(); glMatrixMode(GL_PROJECTION); glPopMatrix(); glMatrixMode(GL_MODELVIEW ); glPopMatrix(); - return FALSE; } -gboolean radar_init(AWeatherGui *gui) +//static void set_site(AWeatherView *view, char *site, gpointer user_data) +//{ +// g_message("location changed to %s", site); +//} + +gboolean radar_init(AWeatherGui *_gui) { + gui = _gui; drawing = GTK_WIDGET(aweather_gui_get_drawing(gui)); GtkNotebook *config = aweather_gui_get_tabs(gui); /* Parse hard coded file.. */ RSL_read_these_sweeps("all", NULL); //RSL_read_these_sweeps("all", NULL); - Radar *radar = RSL_wsr88d_to_radar("/scratch/aweather/data/level2/KNQA_20090501_1925.raw", "KNQA"); + radar = RSL_wsr88d_to_radar("/scratch/aweather/data/level2/KNQA_20090501_1925.raw", "KNQA"); RSL_load_refl_color_table(); RSL_get_color_table(RSL_RED_TABLE, red, &nred); RSL_get_color_table(RSL_GREEN_TABLE, green, &ngreen); @@ -221,8 +211,8 @@ gboolean radar_init(AWeatherGui *gui) gtk_notebook_append_page(GTK_NOTEBOOK(config), scroll, label); /* Set up OpenGL Stuff */ - g_signal_connect(drawing, "expose-event", G_CALLBACK(expose), NULL); - g_signal_connect(drawing, "configure-event", G_CALLBACK(configure), radar->v[0]->sweep[0]); + g_signal_connect(drawing, "map-event", G_CALLBACK(map), NULL); + g_signal_connect(drawing, "expose-event", G_CALLBACK(expose), NULL); return TRUE; }