summaryrefslogtreecommitdiff
path: root/Layout/LayoutSurveySuccess.cpp
blob: 02dd197e0bc7b401d7f6e168d09eca1015b8687e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
#include "LayoutSurveySuccess.h"

LayoutSurveySuccess::LayoutSurveySuccess(DOGS102* lcd)
  : Layout(lcd),
    _lId(0, 0, "ID"),
    _lDr(8, 0, "DR"),
    _lPwr(13, 0, "P"),
    _lUp(0, 1, "UP"),
    _lDown(0, 2, "DWN"),
    _fId(2, 0, 5),
    _fDr(10, 0, 2),
    _fPwr(14, 0, 2),
    _fUpRssi(3, 1, 7),
    _fUpSnr(11, 1, 5),
    _fDownRssi(4, 2, 7),
    _fDownSnr(12, 2, 5),
    _fGpsLat(0, 4, 17),
    _fGpsLon(0, 3, 17),
    _fGpsTime(0, 5, 17),
    _fInfo(0, 6, 17),
    _fSw1(9, 7, 8),
    _fSw2(0, 7, 8)
{}

LayoutSurveySuccess::~LayoutSurveySuccess() {}

void LayoutSurveySuccess::display() {
    clear();
    startUpdate();

    writeLabel(_lId);
    writeLabel(_lDr);
    writeLabel(_lPwr);
    writeLabel(_lUp);
    writeLabel(_lDown);

    endUpdate();
}

void LayoutSurveySuccess::updateId(uint32_t id) {
    char buf[16];
    size_t size;

    size = snprintf(buf, sizeof(buf), "%lu", id);
    writeField(_fId, buf, size, true);
}

void LayoutSurveySuccess::updateRate(std::string rate) {
    writeField(_fDr, rate, true);
}

void LayoutSurveySuccess::updatePower(uint32_t power) {
    char buf[16];
    size_t size;

    size = snprintf(buf, sizeof(buf), "%lu", power);
    writeField(_fPwr, buf, size, true);
}

void LayoutSurveySuccess::updateStats(LoRaHandler::LoRaPing ping) {
    char buf[16];
    size_t size;

    startUpdate();

    size = snprintf(buf, sizeof(buf), "%3d dbm", ping.up.rssi);
    writeField(_fUpRssi, buf, size);

    memset(buf, 0, sizeof(buf));
    size = snprintf(buf, sizeof(buf), "%2d.%1d", ping.up.snr / 10, abs(ping.up.snr) % 10);
    writeField(_fUpSnr, buf, size);

    memset(buf, 0, sizeof(buf));
    size = snprintf(buf, sizeof(buf), "%3d dbm", ping.down.rssi);
    writeField(_fDownRssi, buf, size);

    memset(buf, 0, sizeof(buf));
    size = snprintf(buf, sizeof(buf), "%2d.%1d", ping.down.snr / 4, abs(ping.down.snr) % 10 * 25);
    writeField(_fDownSnr, buf, size);

    endUpdate();
}

void LayoutSurveySuccess::updateGpsLatitude(GPSPARSER::latitude lat) {
}

void LayoutSurveySuccess::updateGpsLongitude(GPSPARSER::longitude lon) {
}

void LayoutSurveySuccess::updateGpsTime(struct tm time) {
}

void LayoutSurveySuccess::updateInfo(std::string info) {
    writeField(_fInfo, info, true);
}

void LayoutSurveySuccess::updateSw1(std::string sw1) {
    writeField(_fSw1, sw1, true);
}

void LayoutSurveySuccess::updateSw2(std::string sw2) {
    writeField(_fSw2, sw2, true);
}

void LayoutSurveySuccess::updateCountdown(uint32_t seconds) {
    char buf[16];
    size_t size;

    memset(buf, 0, sizeof(buf));
    // for some reason, there's a % character that gets displayed in the last column
    // add the extra spaces to wipe it out
    writeField(_fInfo, "No Free Channel  ", true);
    size = snprintf(buf, sizeof(buf), "%lu s", seconds);
    writeField(_fSw2, buf, size, true);
}