Former-commit-id:9f19e3f712
[formerly 64fa9254b946eae7e61bbc3f513b7c3696c4f54f] Former-commit-id:06a8b51d6d
555 lines
16 KiB
C
555 lines
16 KiB
C
#include "gui.h"
|
|
#include "sharp95.h"
|
|
|
|
|
|
/*
|
|
* private rouines
|
|
*/
|
|
void obs_snd_load_gemfile (Widget, XtPointer, XtPointer);
|
|
void time_select_cb (Widget, XtPointer, XtPointer);
|
|
void mapproj_cb (Widget, XtPointer, XtPointer);
|
|
void mapunzoom_cb (Widget, XtPointer, XtPointer);
|
|
void mapzoom_cb (Widget, XtPointer, XtPointer);
|
|
|
|
Widget obs_snd_dialog = NULL;
|
|
Widget obs_snd_timelist, obs_snd_text;
|
|
|
|
extern mapstruct obs_map;
|
|
extern Widget toplevel;
|
|
extern char time_list[500][20];
|
|
|
|
|
|
void observed_sounding_cb (Widget wdgt)
|
|
/************************************************************************
|
|
* OBSERVED_SOUNDING_CB *
|
|
* *
|
|
* Display Observed Sounding Map and get user selection. *
|
|
** *
|
|
* Log: *
|
|
* T. Piper/SAIC 2/02 freed mapmenu.label *
|
|
* T. Piper/SAIC 01/04 removed NAWIPS_TABLES *
|
|
* T. Piper/SAIC 01/04 added NxmWarn_show *
|
|
***********************************************************************/
|
|
{
|
|
static Widget obs_form, obs_form2, obs_pane,
|
|
obs_snd_cancel, obs_snd_help,
|
|
obs_lbl_time, obs_lbl_station;
|
|
static Widget menubar, maparea_zoom, maparea_unzoom, button, obssel_opt,
|
|
obs_00_12;
|
|
XmString title_str;
|
|
char gemdevice[72];
|
|
|
|
int ii, iret = 0, ier, nmap;
|
|
Arg args[10];
|
|
Cardinal argcnt;
|
|
|
|
static _NXMmenuItem mapmenu[30], *obsmenu;
|
|
|
|
static char map_winname[] = "mapobs";
|
|
|
|
if (!obs_snd_dialog)
|
|
{
|
|
title_str = XmStringCreateLocalized ("Observed Sounding Selection");
|
|
obs_snd_dialog = XmCreateBulletinBoardDialog (toplevel, "obs_panel",
|
|
NULL, 0);
|
|
XtVaSetValues (obs_snd_dialog, XmNdialogTitle, title_str, NULL);
|
|
XmStringFree (title_str);
|
|
|
|
obs_pane = XtVaCreateManagedWidget ("obs_snd_pane",
|
|
xmPanedWindowWidgetClass,
|
|
obs_snd_dialog,
|
|
XmNsashWidth, 1,
|
|
XmNsashHeight, 1, NULL);
|
|
|
|
obs_form2 = XtVaCreateWidget ("form", xmFormWidgetClass,
|
|
obs_pane, NULL);
|
|
|
|
obs_form = XtVaCreateWidget ("form", xmFormWidgetClass,
|
|
obs_pane, XmNfractionBase, 7, NULL);
|
|
|
|
title_str = XmStringCreateLocalized ("00Z and 12Z only:");
|
|
obs_00_12 = XtVaCreateManagedWidget ("obs_00_12",
|
|
xmToggleButtonWidgetClass,
|
|
obs_form, XmNindicatorType,
|
|
XmN_OF_MANY, XmNlabelString,
|
|
title_str, NULL);
|
|
XtAddCallback (obs_00_12, XmNvalueChangedCallback, obs_snd_load_gemfile,
|
|
NULL);
|
|
XmStringFree (title_str);
|
|
|
|
title_str = XmStringCreateLocalized ("Sounding times:");
|
|
obs_lbl_time = XtVaCreateManagedWidget ("obsfile_time",
|
|
xmLabelWidgetClass, obs_form,
|
|
XmNlabelString, title_str,
|
|
XmNleftAttachment,
|
|
XmATTACH_POSITION,
|
|
XmNleftPosition, 0,
|
|
XmNtopAttachment,
|
|
XmATTACH_POSITION,
|
|
XmNtopPosition, 1, XmNalignment,
|
|
XmALIGNMENT_BEGINNING, NULL);
|
|
XmStringFree (title_str);
|
|
|
|
obs_snd_timelist = XmCreateScrolledList (obs_form, "times", NULL, 0);
|
|
|
|
XtVaSetValues (obs_snd_timelist,
|
|
XmNvisibleItemCount, 20,
|
|
XmNselectionPolicy, XmEXTENDED_SELECT, NULL);
|
|
XtVaSetValues (XtParent (obs_snd_timelist),
|
|
XmNleftAttachment, XmATTACH_POSITION,
|
|
XmNleftPosition, 0,
|
|
XmNtopAttachment, XmATTACH_WIDGET,
|
|
XmNtopWidget, obs_lbl_time,
|
|
XmNbottomAttachment, XmATTACH_FORM,
|
|
XmNrightAttachment, XmATTACH_POSITION,
|
|
XmNrightPosition, 2, NULL);
|
|
|
|
XtAddCallback (obs_snd_timelist,
|
|
XmNextendedSelectionCallback, time_select_cb, NULL);
|
|
|
|
XtManageChild (obs_snd_timelist);
|
|
|
|
obs_lbl_station = XtVaCreateManagedWidget ("obsmap",
|
|
xmDrawingAreaWidgetClass,
|
|
obs_form, XmNtopAttachment,
|
|
XmATTACH_POSITION,
|
|
XmNtopPosition, 1,
|
|
XmNleftAttachment,
|
|
XmATTACH_POSITION,
|
|
XmNleftPosition, 2,
|
|
XmNrightAttachment,
|
|
XmATTACH_FORM,
|
|
XmNbottomAttachment,
|
|
XmATTACH_FORM, XmNwidth, 560,
|
|
XmNheight, 560,
|
|
XmNbackground, pixels[0],
|
|
NULL);
|
|
|
|
XtAddCallback (obs_lbl_station, XmNexposeCallback,
|
|
(XtCallbackProc)mapw_exposeCb, NULL);
|
|
|
|
plotData.mode = STNSELECT;
|
|
XtAddEventHandler (obs_lbl_station, ButtonPressMask,
|
|
FALSE, (XtEventHandler) mapw_pickstnCb, NULL);
|
|
|
|
|
|
XtManageChild (obs_form);
|
|
|
|
/*
|
|
* create the menubar
|
|
*/
|
|
argcnt = 0;
|
|
XtSetArg (args[argcnt], XmNtopAttachment, XmATTACH_FORM);
|
|
argcnt++;
|
|
XtSetArg (args[argcnt], XmNleftAttachment, XmATTACH_FORM);
|
|
argcnt++;
|
|
XtSetArg (args[argcnt], XmNrightAttachment, XmATTACH_FORM);
|
|
argcnt++;
|
|
|
|
menubar = XmCreateMenuBar (obs_form2, "menubar", args, argcnt);
|
|
|
|
argcnt = 0;
|
|
XtSetArg (args[argcnt], XmNborderWidth, 1);
|
|
argcnt++;
|
|
|
|
obsmenu = NULL;
|
|
file_selection_menu (OBS_SND_TABLE, "nsharp", &obsmenu,
|
|
(XtCallbackProc)obs_snd_load_gemfile, &ier);
|
|
|
|
if (ier != 0)
|
|
{
|
|
NxmWarn_show (obs_form,
|
|
"NSHARP: ERROR opening $GEMTBL/nsharp/nsharp_observed.tbl\nSee system administrator.");
|
|
obs_snd_dialog = NULL;
|
|
return;
|
|
}
|
|
|
|
obssel_opt = NxmMenuPulldownBuild (menubar, NULL, "File",
|
|
0, obsmenu);
|
|
XtSetValues (obssel_opt, args, argcnt);
|
|
|
|
free (obsmenu);
|
|
|
|
/*
|
|
* Create Map pulldown menu
|
|
*
|
|
* Set the items for the menu bar for the map areas.
|
|
*/
|
|
nmap = nwxTable->nmap;
|
|
for (ii = 0; ii < nmap; ii++)
|
|
{
|
|
mapmenu[ii].label = (char *)
|
|
malloc (strlen (nwxTable->map_info[ii].name) + 1);
|
|
strcpy (mapmenu[ii].label, nwxTable->map_info[ii].name);
|
|
mapmenu[ii].class = &xmCascadeButtonGadgetClass;
|
|
mapmenu[ii].mnemonic = 0;
|
|
mapmenu[ii].accelerator = NULL;
|
|
mapmenu[ii].accel_text = NULL;
|
|
mapmenu[ii].callback = mapproj_cb;
|
|
mapmenu[ii].which_widget = (long)ii;
|
|
mapmenu[ii].subitems = NULL;
|
|
mapmenu[ii].sub_buttons = NULL;
|
|
}
|
|
mapmenu[nmap].label = NULL;
|
|
mapmenu[nmap].class = &xmCascadeButtonGadgetClass;
|
|
mapmenu[nmap].mnemonic = 0;
|
|
mapmenu[nmap].accelerator = NULL;
|
|
mapmenu[nmap].accel_text = NULL;
|
|
mapmenu[nmap].callback = NULL;
|
|
mapmenu[nmap].which_widget = (long)nmap;
|
|
mapmenu[nmap].subitems = NULL;
|
|
mapmenu[nmap].sub_buttons = NULL;
|
|
|
|
NxmMenuPulldownBuild (menubar, NULL, "Area", 0, mapmenu);
|
|
for (ii = 0; ii < nmap; ii++)
|
|
free (mapmenu[ii].label);
|
|
|
|
if ((button = XtNameToWidget (menubar, "Area")))
|
|
XtSetValues (button, args, argcnt);
|
|
|
|
maparea_zoom = XmCreateCascadeButton (menubar, "Zoom", NULL, 0);
|
|
XtAddCallback (maparea_zoom, XmNactivateCallback,
|
|
(XtCallbackProc) mapzoom_cb, obs_lbl_station);
|
|
XtSetValues (maparea_zoom, args, argcnt);
|
|
XtManageChild (maparea_zoom);
|
|
|
|
|
|
maparea_unzoom = XmCreateCascadeButton (menubar, "UnZoom", NULL, 0);
|
|
XtAddCallback (maparea_unzoom, XmNactivateCallback,
|
|
(XtCallbackProc) mapunzoom_cb, NULL);
|
|
XtSetValues (maparea_unzoom, args, argcnt);
|
|
XtManageChild (maparea_unzoom);
|
|
|
|
|
|
obs_snd_cancel = XmCreateCascadeButton (menubar, "Cancel", NULL, 0);
|
|
XtAddCallback (obs_snd_cancel, XmNactivateCallback,
|
|
(XtCallbackProc) popdown_cb, obs_snd_dialog);
|
|
XtSetValues (obs_snd_cancel, args, argcnt);
|
|
XtManageChild (obs_snd_cancel);
|
|
|
|
obs_snd_help = XmCreateCascadeButton (menubar, "Help", NULL, 0);
|
|
XtSetValues (obs_snd_help, args, argcnt);
|
|
XtAddCallback (obs_snd_help, XmNactivateCallback,
|
|
(XtCallbackProc) NxmHelp_helpBtnCb, (XtPointer) 2);
|
|
XtManageChild (obs_snd_help);
|
|
|
|
XtVaSetValues (menubar, XmNmenuHelpWidget, obs_snd_help, NULL);
|
|
XtManageChild (menubar);
|
|
|
|
XtManageChild (obs_form2);
|
|
XtManageChild (obs_pane);
|
|
XtManageChild (obs_snd_dialog);
|
|
|
|
obs_map.mapindx = 0;
|
|
obs_map.zoomflg = 0;
|
|
ii = nsharp_mapw_rgstr (obs_lbl_station, map_winname);
|
|
|
|
XtAddCallback (obs_lbl_station, XmNresizeCallback,
|
|
(XtCallbackProc) mapw_resizeCb, NULL);
|
|
|
|
}
|
|
|
|
|
|
/* draw the map accoring to mapw call back */
|
|
XtManageChild (obs_snd_dialog);
|
|
strcpy (gemdevice, map_winname);
|
|
gslwin (gemdevice, &iret, strlen (gemdevice));
|
|
Load_stationlist ();
|
|
}
|
|
|
|
/*========================================================================*/
|
|
/* ARGSUSED */
|
|
void obs_snd_load_gemfile (Widget wdgt, XtPointer clnt, XtPointer call)
|
|
/*************************************************************/
|
|
/* OBS_SND_LOAD_GEMFILE */
|
|
/*************************************************************/
|
|
{
|
|
int ier;
|
|
char path[256], tmpl[256];
|
|
static int only_00_12 = 0;
|
|
|
|
if (XtIsSubclass (wdgt, xmToggleButtonWidgetClass))
|
|
{
|
|
/* toggling 0Z and 12Z on/off */
|
|
Boolean is_set;
|
|
|
|
XtVaGetValues (wdgt, XmNset, &is_set, NULL);
|
|
if (is_set)
|
|
only_00_12 = 1;
|
|
else
|
|
only_00_12 = 0;
|
|
|
|
}
|
|
else if (!XtIsSubclass (wdgt, xmFileSelectionBoxWidgetClass))
|
|
{
|
|
/* Cascade menu entry */
|
|
char *choice;
|
|
XmString label_str;
|
|
|
|
XtVaGetValues (wdgt, XmNlabelString, &label_str, NULL);
|
|
choice = XmStringUnparse (label_str, NULL, XmCHARSET_TEXT,
|
|
XmCHARSET_TEXT, NULL, 0, XmOUTPUT_ALL);
|
|
XmStringFree (label_str);
|
|
|
|
if ((choice[0] == '\0') || (strcmp (choice, "BROWSE") == 0))
|
|
{
|
|
sprintf (tmpl, "*");
|
|
sprintf (path, ".");
|
|
}
|
|
else
|
|
{
|
|
get_file_alias (choice, path, tmpl, &ier,
|
|
strlen (choice), sizeof (path), sizeof (tmpl));
|
|
if (ier != 0)
|
|
{
|
|
sprintf (tmpl, "*");
|
|
sprintf (path, ".");
|
|
}
|
|
}
|
|
XtFree (choice);
|
|
if (strcmp (tmpl, "*") == 0)
|
|
{
|
|
file_browse_popup (path, tmpl, toplevel, obs_snd_load_gemfile);
|
|
return;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* file selection dialog entry of a single file */
|
|
char *choice;
|
|
XmFileSelectionBoxCallbackStruct *cbs =
|
|
(XmFileSelectionBoxCallbackStruct *) call;
|
|
|
|
if (cbs)
|
|
{
|
|
char *cpos;
|
|
choice = XmStringUnparse (cbs->value, NULL, XmCHARSET_TEXT,
|
|
XmCHARSET_TEXT, NULL, 0, XmOUTPUT_ALL);
|
|
cpos = strrchr (choice, '/');
|
|
path[0] = '\0';
|
|
if (cpos != NULL)
|
|
{
|
|
strcpy (tmpl, cpos + 1);
|
|
strncat (path, choice, cpos - choice);
|
|
}
|
|
else
|
|
{
|
|
strncat (path, ".", 1);
|
|
strcpy (tmpl, choice);
|
|
}
|
|
XtFree (choice);
|
|
}
|
|
}
|
|
|
|
{
|
|
char sep = ';';
|
|
int plen, tlen, rorder = (-1), flen, nfil;
|
|
int maxlen = MAX_LIST_LEN;
|
|
XtPointer userdata;
|
|
struct obs_file_times *olist;
|
|
char *filstr;
|
|
|
|
XtVaGetValues (obs_snd_timelist, XmNuserData, &userdata, NULL);
|
|
|
|
if (userdata == NULL)
|
|
{
|
|
olist =
|
|
(struct obs_file_times *) malloc (sizeof (struct obs_file_times));
|
|
olist->filstr = (char *) malloc (maxlen);
|
|
olist->filstr[0] = '\0';
|
|
olist->posindex = (int *) malloc (MAX_TIME_LIST * sizeof (int));
|
|
olist->selected_items = NULL;
|
|
olist->nitems = 0;
|
|
olist->path[0] = '\0';
|
|
XtVaSetValues (obs_snd_timelist, XmNuserData, (XtPointer) olist,
|
|
NULL);
|
|
}
|
|
else
|
|
{
|
|
olist = (struct obs_file_times *) userdata;
|
|
}
|
|
filstr = olist->filstr;
|
|
|
|
if (XtIsSubclass (wdgt, xmToggleButtonWidgetClass))
|
|
{
|
|
/* toggled */
|
|
ier = 0;
|
|
strcpy (path, olist->path);
|
|
}
|
|
else if (!XtIsSubclass (wdgt, xmFileSelectionBoxWidgetClass))
|
|
{
|
|
plen = strlen (path);
|
|
tlen = strlen (tmpl);
|
|
strcpy (olist->path, path);
|
|
cfl_scnd (path, &plen, tmpl, &tlen, &sep, &maxlen, &rorder, filstr,
|
|
&flen, &nfil, &ier);
|
|
}
|
|
else
|
|
{
|
|
ier = 0;
|
|
strcpy (filstr, tmpl);
|
|
strcpy (olist->path, path);
|
|
}
|
|
|
|
if (ier == -1)
|
|
{
|
|
printf ("too many files in directory\n");
|
|
}
|
|
else
|
|
{
|
|
char *spos, *epos;
|
|
int ii, posnum = 0, ntimes, sumtim = 0;
|
|
|
|
spos = filstr;
|
|
while (spos != NULL)
|
|
{
|
|
sprintf (gemsoundfile, "%s/", path);
|
|
epos = strchr (spos, sep);
|
|
if (epos != NULL)
|
|
strncat (gemsoundfile, spos, epos - spos);
|
|
else
|
|
strcat (gemsoundfile, spos);
|
|
|
|
get_gem_times (gemsoundfile, &only_00_12, &time_list[sumtim],
|
|
&ntimes, &ier, strlen (gemsoundfile),
|
|
20 /*sizeof(time_list) */ );
|
|
if (ier == 0)
|
|
{
|
|
for (ii = 0; ii < ntimes; ii++)
|
|
olist->posindex[sumtim + ii] = posnum;
|
|
sumtim += ntimes;
|
|
}
|
|
spos = epos;
|
|
if (spos != NULL)
|
|
spos++;
|
|
posnum++;
|
|
}
|
|
{
|
|
int i;
|
|
XmStringTable str_list;
|
|
|
|
str_list = (XmStringTable) XtMalloc ((size_t) sumtim *
|
|
sizeof (XmString *));
|
|
for (i = 0; i < sumtim; i++)
|
|
{
|
|
time_list[i][11] = '\0';
|
|
str_list[i] = XmStringCreateLocalized (time_list[i]);
|
|
}
|
|
XtVaSetValues (obs_snd_timelist,
|
|
XmNitemCount, sumtim, XmNitems, str_list, NULL);
|
|
XmListDeselectAllItems (obs_snd_timelist);
|
|
if (olist->selected_items != NULL)
|
|
{
|
|
free (olist->selected_items);
|
|
olist->nitems = 0;
|
|
olist->selected_items = NULL;
|
|
}
|
|
for (i = 0; i < sumtim; i++)
|
|
XmStringFree ((XmString) str_list[i]);
|
|
XtFree ((XtPointer) str_list);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/*========================================================================*/
|
|
/* ARGSUSED */
|
|
void time_select_cb (Widget wdgt, XtPointer clnt, XtPointer call)
|
|
/*************************************************************/
|
|
/* TIME_SELECT_CB */
|
|
/*************************************************************/
|
|
{
|
|
XmListCallbackStruct *cbs = (XmListCallbackStruct *) call;
|
|
struct obs_file_times *olist;
|
|
XtPointer userdata;
|
|
char *choice;
|
|
int top_item, fileindex;
|
|
|
|
if (cbs->reason == XmCR_EXTENDED_SELECT)
|
|
{
|
|
if (cbs->selected_item_count == 0)
|
|
return;
|
|
top_item = cbs->selected_item_positions[0];
|
|
XtVaGetValues (obs_snd_timelist, XmNuserData, &userdata, NULL);
|
|
if (userdata != NULL)
|
|
{
|
|
int ier;
|
|
char sep = ';';
|
|
olist = (struct obs_file_times *) userdata;
|
|
fileindex = olist->posindex[top_item - 1];
|
|
|
|
sprintf (gemsoundfile, "%s/", olist->path);
|
|
get_listitem (olist->filstr, fileindex, sep,
|
|
gemsoundfile + strlen (gemsoundfile), &ier);
|
|
|
|
olist->nitems = cbs->selected_item_count;
|
|
if (olist->selected_items != NULL)
|
|
free (olist->selected_items);
|
|
olist->selected_items =
|
|
(int *) malloc (olist->nitems * sizeof (int));
|
|
memcpy (olist->selected_items, cbs->selected_item_positions,
|
|
olist->nitems * sizeof (int));
|
|
}
|
|
choice = XmStringUnparse (cbs->selected_items[0], NULL, XmCHARSET_TEXT,
|
|
XmCHARSET_TEXT, NULL, 0, XmOUTPUT_ALL);
|
|
}
|
|
else
|
|
{
|
|
choice = XmStringUnparse (cbs->item, NULL, XmCHARSET_TEXT,
|
|
XmCHARSET_TEXT, NULL, 0, XmOUTPUT_ALL);
|
|
}
|
|
|
|
sprintf (gemsoundtime, "%s", choice);
|
|
XtFree (choice);
|
|
|
|
Load_stationlist ();
|
|
|
|
}
|
|
|
|
/*=====================================================================*/
|
|
|
|
void sta_select_cb (int which_sta)
|
|
/*************************************************************/
|
|
/* STA_SELECT_CB */
|
|
/*************************************************************/
|
|
{
|
|
char stanum[8], sta_tmp[12], snd_station[9] = "", sta_id[5] = "";
|
|
int ival;
|
|
|
|
ival = sscanf (stnList.stnName[which_sta],
|
|
"%s %s %s", sta_id, stanum, sta_tmp);
|
|
|
|
if (ival == 2)
|
|
sprintf (snd_station, "@%s", stanum);
|
|
else if (ival == 1)
|
|
sprintf (snd_station, "@%s", sta_id);
|
|
|
|
Load_gem_sounding (obs_snd_dialog, obs_snd_timelist, snd_station, sta_id);
|
|
}
|
|
|
|
/*========================================================================*/
|
|
/* ARGSUSED */
|
|
void mapproj_cb (Widget wdgt, XtPointer clnt, XtPointer call)
|
|
{
|
|
int item_no = (long)clnt;
|
|
/*-------------------------------------------------------------------------*/
|
|
obs_map.mapindx = item_no;
|
|
obs_map.zoomflg = 0;
|
|
Load_stationlist ();
|
|
}
|
|
|
|
/*========================================================================*/
|
|
/* ARGSUSED */
|
|
void mapunzoom_cb (Widget wdgt, XtPointer clnt, XtPointer call)
|
|
{
|
|
obs_map.zoomflg = 0;
|
|
Load_stationlist ();
|
|
}
|
|
|
|
/*========================================================================*/
|
|
/* ARGSUSED */
|
|
void mapzoom_cb (Widget wdgt, XtPointer clnt, XtPointer call)
|
|
{
|
|
Widget mapCanvW = (Widget) clnt;
|
|
_mapzoom_cb (mapCanvW, mapw_pickstnCb, &obs_map, Load_stationlist);
|
|
}
|