31#include <wx/glcanvas.h>
32#include <wx/graphics.h>
33#include <wx/progdlg.h>
37#include <wx/tokenzr.h>
39extern double m_cursor_lat, m_cursor_lon;
46 m_pGribTable->m_gParent =
this;
50 wxGridCellAttr *datarow =
new wxGridCellAttr();
52 datarow->SetAlignment(wxALIGN_CENTRE, wxALIGN_CENTRE);
56 l.Append(toSDMM_PlugIn(1, m_cursor_lat))
58 .Append(toSDMM_PlugIn(2, m_cursor_lon));
59 m_pCursorPosition->SetLabel(l);
60 m_pCursorPosition->SetFont(
65 m_pGribTable->AppendCols(rsa->GetCount());
68 wxDateTime time, day, ptime;
70 for (
unsigned i = 0; i < rsa->GetCount(); i++) {
72 time = rsa->Item(i).m_Reference_Time;
77 m_pGribTable->SetColLabelValue(i, toUsrDateTimeFormat_Plugin(time, opts));
80 if (pTimeset == 0)
continue;
94 AddDataRow(nrows, i, _(
"Wind,Dir"), datarow);
96 GetWind(RecordArray, 1, wdir);
97 m_pGribTable->SetCellBackgroundColour(nrows, i, m_pDataCellsColour);
98 m_pGribTable->SetNumericalRow(nrows, i, R_WIND, wdir);
100 AddDataRow(nrows, i, _(
"Wind,Speed"), datarow);
102 .m_Units != GribOverlaySettings::BFS)
103 m_pGribTable->SetCellValue(nrows, i, GetWind(RecordArray, 2, wdir));
105 m_pGribTable->SetCellValue(nrows, i, GetWind(RecordArray, 3, wdir));
106 m_pGribTable->SetCellBackgroundColour(nrows, i, m_pDataCellsColour);
110 AddDataRow(nrows, i, _(
"Wind,Gust"), datarow);
112 .m_Units != GribOverlaySettings::BFS)
113 m_pGribTable->SetCellValue(nrows, i, GetWindGust(RecordArray, 1));
115 m_pGribTable->SetCellValue(nrows, i, GetWindGust(RecordArray, 2));
116 m_pGribTable->SetCellBackgroundColour(nrows, i, m_pDataCellsColour);
124 AddDataRow(nrows, i, _(
"Pressure"), datarow);
125 m_pGribTable->SetCellValue(nrows, i, GetPressure(RecordArray));
139 AddDataRow(nrows, i, _(
"Waves,Dir"), datarow);
141 m_pGribTable->SetNumericalRow(nrows, i, R_WAVES, wdir);
144 AddDataRow(nrows, i, _(
"Waves,Hsig"), datarow);
145 m_pGribTable->SetCellValue(nrows, i,
147 m_pGribTable->SetCellBackgroundColour(nrows, i, m_pDataCellsColour);
151 AddDataRow(nrows, i, _(
"Waves,Per"), datarow);
152 m_pGribTable->SetCellValue(nrows, i,
161 AddDataRow(nrows, i, _(
"Rainfall"), datarow);
162 m_pGribTable->SetCellValue(nrows, i, GetRainfall(RecordArray));
163 m_pGribTable->SetCellBackgroundColour(nrows, i, m_pDataCellsColour);
170 AddDataRow(nrows, i, _(
"Cloud Cover"), datarow);
171 m_pGribTable->SetCellValue(nrows, i, GetCloudCover(RecordArray));
172 m_pGribTable->SetCellBackgroundColour(nrows, i, m_pDataCellsColour);
179 AddDataRow(nrows, i, _(
"Air Temp."), datarow);
180 m_pGribTable->SetCellValue(nrows, i, GetAirTemp(RecordArray));
181 m_pGribTable->SetCellBackgroundColour(nrows, i, m_pDataCellsColour);
188 AddDataRow(nrows, i, _(
"Sea Temp."), datarow);
189 m_pGribTable->SetCellValue(nrows, i, GetSeaTemp(RecordArray));
190 m_pGribTable->SetCellBackgroundColour(nrows, i, m_pDataCellsColour);
198 AddDataRow(nrows, i, _(
"CAPE"), datarow);
199 m_pGribTable->SetCellValue(nrows, i, GetCAPE(RecordArray));
200 m_pGribTable->SetCellBackgroundColour(nrows, i, m_pDataCellsColour);
207 AddDataRow(nrows, i, _(
"C. Reflect."), datarow);
208 m_pGribTable->SetCellValue(nrows, i, GetCompRefl(RecordArray));
209 m_pGribTable->SetCellBackgroundColour(nrows, i, m_pDataCellsColour);
221 AddDataRow(nrows, i, _(
"Current,Dir"), datarow);
222 GetCurrent(RecordArray, 1, wdir);
223 m_pGribTable->SetCellBackgroundColour(nrows, i, m_pDataCellsColour);
224 m_pGribTable->SetNumericalRow(nrows, i, R_CURRENT, wdir);
227 AddDataRow(nrows, i, _(
"Current,Speed"), datarow);
228 m_pGribTable->SetCellValue(nrows, i, GetCurrent(RecordArray, 2, wdir));
229 m_pGribTable->SetCellBackgroundColour(nrows, i, m_pDataCellsColour);
232 m_pGribTable->AutoSizeColumn(i,
false);
233 wcols = wxMax(m_pGribTable->GetColSize(i), wcols);
236 m_pGribTable->SetGridCursor(m_pGribTable->GetNumberRows() - 1, 0);
238 m_pGribTable->SetDefaultColSize(wcols,
true);
242 m_pGribTable->SetColLabelSize(wxGRID_AUTOSIZE);
244 m_pGribTable->SetScrollLineX(wcols);
248 m_tScrollToNowTimer.Connect(
249 wxEVT_TIMER, wxTimerEventHandler(GRIBTable::OnScrollToNowTimer),
nullptr,
255 int x = -1, y = -1, w = -1, h = -1;
258 pConf->SetPath(_T(
"/Settings/GRIB"));
259 pConf->Read(_T(
"GribDataTablePosition_x"), &x);
260 pConf->Read(_T(
"GribDataTablePosition_y"), &y);
261 pConf->Read(_T(
"GribDataTableWidth"), &w);
262 pConf->Read(_T(
"GribDataTableHeight"), &h);
270 if (!(wxRect(pcw, scw).Contains(wxRect(final_pos, wxSize(w, h)))))
272 if (w < (m_pGribTable->GetRowLabelSize() + (m_pGribTable->GetColSize(0))) ||
273 h < (m_pGribTable->GetColLabelSize() + (m_pGribTable->GetRowSize(0))))
280 w = (scw.GetWidth() / 10) * 9;
281 h = (scw.GetHeight() / 10) * 9;
282 x = (scw.GetWidth() / 20);
283 y = (scw.GetHeight() / 50);
286 y = m_pGDialog->GetSize().GetHeight() * 11 / 10;
287 h = scw.GetHeight() - m_pGDialog->GetSize().GetHeight();
292 int w1 = m_pGribTable->GetRowLabelSize() +
293 (m_pGribTable->GetColSize(0) * m_pGribTable->GetNumberCols());
295 int h1 = m_pGribTable->GetColLabelSize() +
296 (m_pGribTable->GetRowSize(0) * (m_pGribTable->GetNumberRows() + 4));
299 this->SetClientSize(w, h);
300 this->Move(final_pos);
303 m_pGribTable->MakeCellVisible(0, m_pGribTable->GetNumberCols() - 1);
305 m_tScrollToNowTimer.Start(200, wxTIMER_ONE_SHOT);
308void GRIBTable::OnScrollToNowTimer(wxTimerEvent &event) {
309 m_pGribTable->MakeCellVisible(0, m_pIndex);
312void GRIBTable::OnClose(wxCloseEvent &event) {
314 this->EndModal(wxID_OK);
317void GRIBTable::OnOKButton(wxCommandEvent &event) {
319 this->EndModal(wxID_OK);
322void GRIBTable::CloseDialog() {
323 wxSize s = this->GetClientSize();
328 pConf->SetPath(_T (
"/Settings/GRIB" ));
330 pConf->Write(_T (
"GribDataTablePosition_x" ), p.x);
331 pConf->Write(_T (
"GribDataTablePosition_y" ), p.y);
332 pConf->Write(_T (
"GribDataTableWidth" ), s.GetWidth());
333 pConf->Write(_T (
"GribDataTableHeight" ), s.GetHeight());
337void GRIBTable::AddDataRow(
int num_rows,
int num_cols, wxString label,
338 wxGridCellAttr *row_attr) {
339 if (m_pGribTable->GetNumberRows() == num_rows) {
340 m_pGribTable->AppendRows(1);
341 m_pGribTable->SetRowLabelValue(num_rows, label);
343 m_pGribTable->SetRowAttr(num_rows, row_attr);
345 m_pDataCellsColour = m_pGribTable->GetCellBackgroundColour(
349void GRIBTable::AutoSizeDataRows() {
351 for (
int i = 0; i < m_pGribTable->GetNumberRows(); i++) {
352 m_pGribTable->AutoSizeRow(i,
false);
353 hrows = wxMax(m_pGribTable->GetRowHeight(i) + 3, hrows);
355 m_pGribTable->SetDefaultRowSize(hrows,
true);
357 m_pGribTable->SetScrollLineY(hrows);
360wxString GRIBTable::GetWind(
GribRecord **recordarray,
int datatype,
362 wxString skn(wxEmptyString);
368 recordarray[
Idx_WIND_VY + altitude], m_cursor_lon, m_cursor_lat)) {
374 GribOverlaySettings::WIND, vkn);
376 m_pGDialog->
pPlugIn->m_pGRIBOverlayFactory->GetGraphicColor(
377 GribOverlaySettings::WIND, cvkn);
378 skn.Printf(wxString::Format(
383 skn.Prepend(wxString::Format(
385 GribOverlaySettings::WIND),
386 (
int)wxRound(cvkn)) +
393wxString GRIBTable::GetWindGust(
GribRecord **recordarray,
int datatype) {
394 wxString skn(wxEmptyString);
397 m_cursor_lon, m_cursor_lat,
true);
398 if (vkn != GRIB_NOTDEF) {
400 GribOverlaySettings::WIND_GUST, vkn);
402 m_pGDialog->
pPlugIn->m_pGRIBOverlayFactory->GetGraphicColor(
403 GribOverlaySettings::WIND_GUST, cvkn);
405 skn.Printf(wxString::Format(
413 GribOverlaySettings::WIND_GUST),
414 (
int)wxRound(cvkn)) +
422wxString GRIBTable::GetPressure(
GribRecord **recordarray) {
423 wxString skn(wxEmptyString);
426 m_cursor_lon, m_cursor_lat,
true);
428 if (press != GRIB_NOTDEF) {
430 GribOverlaySettings::PRESSURE, press);
436 skn.Printf(wxString::Format(
438 GribOverlaySettings::PRESSURE),
445wxString GRIBTable::GetWaves(
GribRecord **recordarray,
int datatype,
447 wxString skn(wxEmptyString);
453 m_cursor_lon, m_cursor_lat,
true);
454 if (height != GRIB_NOTDEF) {
456 GribOverlaySettings::WAVE, height);
457 skn.Printf(wxString::Format(
459 GribOverlaySettings::WAVE),
462 m_pGDialog->
pPlugIn->m_pGRIBOverlayFactory->GetGraphicColor(
463 GribOverlaySettings::WAVE, cheight);
470 m_cursor_lon, m_cursor_lat,
true,
true);
478 m_cursor_lon, m_cursor_lat,
true);
479 if (period != GRIB_NOTDEF)
480 skn.Printf(wxString::Format(_T(
"%01ds"), (
int)(period + 0.5)));
486wxString GRIBTable::GetRainfall(
GribRecord **recordarray) {
487 wxString skn(wxEmptyString);
490 m_cursor_lon, m_cursor_lat,
true);
492 if (precip != GRIB_NOTDEF) {
494 GribOverlaySettings::PRECIPITATION, precip);
496 GribOverlaySettings::PRECIPITATION),
499 m_pGDialog->
pPlugIn->m_pGRIBOverlayFactory->GetGraphicColor(
500 GribOverlaySettings::PRECIPITATION, precip);
506wxString GRIBTable::GetCloudCover(
GribRecord **recordarray) {
507 wxString skn(wxEmptyString);
510 m_cursor_lon, m_cursor_lat,
true);
512 if (cloud != GRIB_NOTDEF) {
514 GribOverlaySettings::CLOUD, cloud);
515 skn.Printf(_T(
"%5.1f "), cloud);
517 GribOverlaySettings::CLOUD));
519 m_pGDialog->
pPlugIn->m_pGRIBOverlayFactory->GetGraphicColor(
520 GribOverlaySettings::CLOUD, cloud);
526wxString GRIBTable::GetAirTemp(
GribRecord **recordarray) {
527 wxString skn(wxEmptyString);
530 m_cursor_lon, m_cursor_lat,
true);
532 if (temp != GRIB_NOTDEF) {
534 GribOverlaySettings::AIR_TEMPERATURE, temp);
536 GribOverlaySettings::AIR_TEMPERATURE),
539 m_pGDialog->
pPlugIn->m_pGRIBOverlayFactory->GetGraphicColor(
540 GribOverlaySettings::AIR_TEMPERATURE, temp);
546wxString GRIBTable::GetSeaTemp(
GribRecord **recordarray) {
547 wxString skn(wxEmptyString);
550 m_cursor_lon, m_cursor_lat,
true);
552 if (temp != GRIB_NOTDEF) {
554 GribOverlaySettings::SEA_TEMPERATURE, temp);
556 GribOverlaySettings::SEA_TEMPERATURE),
559 m_pGDialog->
pPlugIn->m_pGRIBOverlayFactory->GetGraphicColor(
560 GribOverlaySettings::SEA_TEMPERATURE, temp);
566wxString GRIBTable::GetCAPE(
GribRecord **recordarray) {
567 wxString skn(wxEmptyString);
570 m_cursor_lon, m_cursor_lat,
true);
572 if (cape != GRIB_NOTDEF) {
574 GribOverlaySettings::CAPE, cape);
575 skn.Printf(wxString::Format(
577 GribOverlaySettings::CAPE),
580 m_pGDialog->
pPlugIn->m_pGRIBOverlayFactory->GetGraphicColor(
581 GribOverlaySettings::CAPE, cape);
587wxString GRIBTable::GetCompRefl(
GribRecord **recordarray) {
588 wxString skn(wxEmptyString);
591 m_cursor_lon, m_cursor_lat,
true);
593 if (refl != GRIB_NOTDEF) {
595 GribOverlaySettings::COMP_REFL, refl);
596 skn.Printf(wxString::Format(
598 GribOverlaySettings::COMP_REFL),
601 m_pGDialog->
pPlugIn->m_pGRIBOverlayFactory->GetGraphicColor(
602 GribOverlaySettings::COMP_REFL, refl);
608wxString GRIBTable::GetCurrent(
GribRecord **recordarray,
int datatype,
610 wxString skn(wxEmptyString);
621 GribOverlaySettings::CURRENT, vkn);
622 skn.Printf(wxString::Format(
624 GribOverlaySettings::CURRENT),
627 m_pGDialog->
pPlugIn->m_pGRIBOverlayFactory->GetGraphicColor(
628 GribOverlaySettings::CURRENT, vkn);
Specialized Grid Control for GRIB Data Display.
@ Idx_COMP_REFL
Composite radar reflectivity.
@ Idx_PRECIP_TOT
Total precipitation.
@ Idx_AIR_TEMP
Air temperature at 2m.
@ Idx_PRESSURE
Surface pressure.
@ Idx_WVDIR
Wave direction.
@ Idx_CLOUD_TOT
Total cloud cover.
@ Idx_WIND_GUST
Wind gust speed at surface.
@ Idx_WIND_VX
Surface wind velocity X component.
@ Idx_HTSIGW
Significant wave height.
@ Idx_SEACURRENT_VY
Sea current velocity Y component.
@ Idx_SEA_TEMP
Sea surface temperature.
@ Idx_WIND_VY
Surface wind velocity Y component.
@ Idx_SEACURRENT_VX
Sea current velocity X component.
@ Idx_CAPE
Convective Available Potential Energy.
GRIB Data Table View and Export Interface.
void SetTableSizePosition(int vpWidth, int vpHeight)
Set the table size and position relative to viewport.
void InitGribTable(const wxString zone, ArrayOfGribRecordSets *rsa)
Initialize the GRIB data table.
GribOverlaySettings m_OverlaySettings
Settings that control how GRIB data is displayed and overlaid.
grib_pi * pPlugIn
Plugin instance that owns this control bar.
GRIBFile * m_bGRIBActiveFile
Currently active GRIB file being displayed.
GribTimelineRecordSet * GetTimeLineRecordSet(wxDateTime time)
Retrieves or creates a temporally interpolated GRIB record set for a specific timestamp.
GribRecord * m_GribRecordPtrArray[Idx_COUNT]
Array of pointers to GRIB records representing different meteorological parameters.
Represents a meteorological data grid from a GRIB (Gridded Binary) file.
double getInterpolatedValue(double px, double py, bool numericalInterpolation=true, bool dir=false) const
Get spatially interpolated value at exact lat/lon position.
static bool getInterpolatedValues(double &M, double &A, const GribRecord *GRX, const GribRecord *GRY, double px, double py, bool numericalInterpolation=true)
Gets spatially interpolated wind or current vector values at a specific latitude/longitude point.
A specialized GribRecordSet that represents temporally interpolated weather data with isobar renderin...
int GetChartbarHeight(void)
Gets height of chart bar in pixels.
wxWindow * GetOCPNCanvasWindow()
Gets OpenCPN's main canvas window.
wxFont GetOCPNGUIScaledFont_PlugIn(wxString item)
Gets a uniquely scaled font copy for responsive UI elements.
wxFileConfig * GetOCPNConfigObject(void)
Gets OpenCPN's configuration object.
OpenGL Platform Abstraction Layer.