1
0
mirror of https://github.com/thooge/esp32-nmea2000-obp60.git synced 2025-12-29 13:33:06 +01:00

Code part for more chart plots

This commit is contained in:
Ulrich Meine
2025-09-12 18:42:49 +02:00
parent be946440d3
commit b3e2dea45b
4 changed files with 393 additions and 204 deletions

View File

@@ -1,3 +1,4 @@
// Function lib for history buffer handling, true wind calculation, and other operations on boat data
#pragma once
#include <N2kMessages.h>
#include "OBPRingBuffer.h"

View File

@@ -0,0 +1,75 @@
// Function lib for display of boat data in various chart formats
#include "OBPcharts.h"
// --- Class Chart ---------------
void Chart::drawChrtHdr() {
// chart header label + lines
int i;
getdisplay().fillRect(0, top, cWidth, 2, commonData->fgcolor);
// horizontal chart labels
getdisplay().drawLine(cStart.x, cStart.y, cWidth, cStart.y);
getdisplay().fillRect(cStart.x, cStart.y, cWidth, 2, commonData->fgcolor);
getdisplay().setFont(&Ubuntu_Bold10pt8b);
getdisplay().setCursor(cStart.x, cStart.y + 12);
getdisplay().print(dbName); // Wind data name
getdisplay().setFont(&Ubuntu_Bold12pt8b);
if (chrtSze == 0) {
i = -1 * (chrtIntv / 8 - 2);
} else {
i = -1 * (chrtIntv / 4 - 2);
}
for (int j = 50; j <= (cWidth - 50); j += 50 ) {
getdisplay().setCursor(cStart.x + j - 16, cStart.y + 12);
getdisplay().print(i++); // time interval
// i++;
getdisplay().drawLine(cStart.x + j - 30, cStart.y, cStart.x - 30, cHeight + top);
}
}
void Chart::drawChrtGrd(const int chrtRng) {
// chart Y axis labels + lines
int i;
getdisplay().setFont(&Ubuntu_Bold8pt8b);
if (chrtDir == 0) {
i = -1 * (chrtRng / 4 - 2);
for (int j = cStart.x; j <= (cHeight - (cHeight / 4)); j += cHeight / 4 ) {
getdisplay().drawLine(0, cStart.y, cWidth, cStart.y);
getdisplay().setCursor(0, cStart.y + 12);
if (i < 10)
getdisplay().printf("!!%1d", i); // Range value
else if (i < 100)
getdisplay().printf("!%2d", i); // Range value
else
getdisplay().printf("%3d", i); // Range value
i += (chrtRng / 4);
}
} else {
i = -1 * (chrtRng / 8 - 2);
for (int j = cStart.x; j <= (cHeight - (cHeight / 8)); j += cHeight / 8 ) {
getdisplay().drawLine(cStart.x + j - 30, cStart.y, cStart.x - 30, cHeight + top);
getdisplay().setCursor(0, cStart.y + 12);
if (i < 10)
getdisplay().printf("!!%1d", i); // Range value
else if (i < 100)
getdisplay().printf("!%2d", i); // Range value
else
getdisplay().printf("%3d", i); // Range value
i += (chrtRng / 4);
}
}
}
bool Chart::drawChrt(int8_t chrtIntv, int dfltRng) {
// hstryBuf = buffer to display
// bValue = present value to display additionally to chart
// chrtDir = chart direction: [0] = vertical, [1] = horizontal
// chrtSze = chart size: [0] = full size, [1] = half size left half/top, [2] half size right half/bottom
// chrtIntv = chart time interval: [1] 4 min., [2] 8 min., [3] 12 min., [4] 16 min., [5] 32 min.
// dfltRng = default range of chart, e.g. 30 = [0..30]
}
// --- Class Chart ---------------

103
lib/obp60task/OBPcharts.h Normal file
View File

@@ -0,0 +1,103 @@
// Function lib for display of boat data in various chart formats
#pragma once
#include "OBP60Extensions.h"
#include "Pagedata.h"
// #include "OBPDataOperations.h"
// #include "OBPRingBuffer.h"
struct Point {
int x;
int y;
};
class Chart {
protected:
RingBuffer<uint16_t>* dataBuf; // Buffer to display
GwApi::BoatValue* bValue; // Present value to display additionally to chart
int8_t chrtDir; // Chart direction: [0] = vertical, [1] = horizontal
int8_t chrtSze; // Chart size: [0] = full size, [1] = half size left/top, [2] half size right/bottom
int8_t chrtIntv; // Chart time interval: [4] 4 min., [8] 8 min., [12] 12 min., [16] 16 min., [32] 32 min.
int dfltRng; // Default range of chart, e.g. 30 = [0..30]
int top = 48; // display top header lines
int bottom = 22; // display bottom lines
int gap = 4; // gap between 2 charts; actual gap is 2x <gap>
int cWidth;
int cHeight;
Point cStart; // start point for chart area
int cLines; // number of chart lines
int xCenter; // x center point of chart
String dbName, dbFormat;
int16_t dbMAX_VAL;
size_t bufSize;
GwApi::BoatValue* bValue;
public:
Chart(RingBuffer<uint16_t>* dataBuf, GwApi::BoatValue* bValue, int8_t chrtDir, int8_t chrtSz, int8_t chrtIntv, int dfltRng, GwLog* logger)
: dataBuf(dataBuf)
, bValue(bValue)
, chrtDir(chrtDir)
, chrtSze(chrtSze)
, chrtIntv(chrtIntv)
, dfltRng(dfltRng)
{
cWidth = getdisplay().width();
cHeight = getdisplay().height();
cHeight = cHeight - top - bottom;
if (chrtDir == 0) {
// vertical chart
switch (chrtSze) {
case 0:
// default is already set
break;
case 1:
cWidth = cWidth;
cHeight = cHeight / 2 - gap;
cStart = { 30, cHeight + top };
break;
case 2:
cWidth = cWidth;
cHeight = cHeight / 2 - gap;
cStart = { cWidth + gap, top };
break;
default:
LOG_DEBUG(GwLog::DEBUG, "displayChart: wrong parameter");
return;
}
} else if (chrtDir == 1) {
// horizontal chart
switch (chrtSze) {
case 0:
cStart = { 0, cHeight - bottom };
break;
case 1:
cWidth = cWidth / 2 - gap;
cHeight = cHeight;
cStart = { 0, cHeight - bottom };
break;
case 2:
cWidth = cWidth / 2 - gap;
cHeight = cHeight;
cStart = { cWidth + gap, cHeight - bottom };
break;
default:
LOG_DEBUG(GwLog::DEBUG, "displayChart: wrong parameter");
return;
}
} else {
LOG_DEBUG(GwLog::DEBUG, "displayChart: wrong parameter");
return;
}
xCenter = cWidth / 2;
cLines = cHeight - 22;
dataBuf->getMetaData(dbName, dbFormat);
dbMAX_VAL = dataBuf->getMaxVal();
bufSize = dataBuf->getCapacity();
bValue->setFormat(dataBuf->getFormat());
};
void drawChrtHdr();
void drawChrtGrd(const int chrtRng);
bool drawChrt(int8_t chrtIntv, int dfltRng);
};

View File

@@ -1,10 +1,11 @@
#if defined BOARD_OBP60S3 || defined BOARD_OBP40S3
#include "Pagedata.h"
#include "OBP60Extensions.h"
#include "OBPRingBuffer.h"
#include "OBPDataOperations.h"
#include "BoatDataCalibration.h"
#include "OBP60Extensions.h"
#include "OBPDataOperations.h"
#include "OBPRingBuffer.h"
#include "OBPcharts.h"
#include "Pagedata.h"
#include <vector>
static const double radToDeg = 180.0 / M_PI; // Conversion factor from radians to degrees
@@ -99,13 +100,12 @@ public:
// holdValues = common.config->getBool(common.config->holdvalues);
flashLED = common.config->getString(common.config->flashLED);
backlightMode = common.config->getString(common.config->backlight);
}
virtual void setupKeys()
{
Page::setupKeys();
// commonData->keydata[0].label = "MODE";
commonData->keydata[0].label = "MODE";
#if defined BOARD_OBP60S3
commonData->keydata[1].label = "SRC";
commonData->keydata[4].label = "INTV";
@@ -161,7 +161,8 @@ public:
return key;
}
virtual void displayNew(PageData &pageData){
virtual void displayNew(PageData& pageData)
{
#ifdef BOARD_OBP40S3
String wndSrc; // Wind source true/apparant wind - preselection for OBP40
@@ -280,6 +281,7 @@ public:
oldShowTruW = showTruW;
}
if (chrtMode == 'D') {
// Identify buffer size and buffer start position for chart
count = wdHstry->getCurrentSize();
currIdx = wdHstry->getLastIdx();
@@ -500,6 +502,14 @@ public:
}
getdisplay().printf("%3d", chrtLbl); // Wind value label
}
} else if (chrtMode == 'S') {
wsValue = wsHstry->getLast();
Chart twsChart(wsHstry, wsBVal, 0, 0, dataIntv, dfltRng, logger);
twsChart.drawChrtHdr();
twsChart.drawChrtGrd(40);
} else if (chrtMode == 'B') {
}
LOG_DEBUG(GwLog::DEBUG, "PageWindPlot time: %ld", millis() - timer);
return PAGE_UPDATE;