summaryrefslogtreecommitdiff
path: root/Mode/ModeSweep.h
blob: 4c95b63576ab9b135ea7e746abd7eeb94856be7b (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
#ifndef __MODESWEEP_H__
#define __MODESWEEP_H__

#include "Mode.h"
#include "LayoutHelp.h"
#include "LayoutFile.h"
#include "LayoutConfirm.h"
#include "LayoutSweepProgress.h"
#include "LayoutSurveySuccess.h"
#include "LayoutSurveyFailure.h"
#include "LayoutSweepComplete.h"

typedef std::pair<uint8_t, uint32_t> point;

class ModeSweep : public Mode {
    public:
        ModeSweep(DOGS102* lcd, ButtonHandler* buttons, mDot* dot, LoRaHandler* lora, GPSPARSER* gps, SensorHandler* sensors);
        ~ModeSweep();

        bool start();

    private:
        void displayHelp();
        void displaySuccess();
        std::vector<point> generatePoints();
        uint8_t payloadToRate(uint8_t payload);

        typedef enum {
            check_file = 0,
            confirm,
            show_help,
            in_progress,
            success,
            data,
            failure,
            complete
        } state;

        LayoutHelp _help;
        LayoutFile _file;
        LayoutConfirm _confirm;
        LayoutSweepProgress _progress;
        LayoutSurveySuccess _success;
        LayoutSurveyFailure _failure;
        LayoutSweepComplete _complete;
        DataItem _data;

        uint8_t _min_payload;
        uint8_t _max_payload;
        uint32_t _min_power;
        uint32_t _max_power;
        uint8_t _survey_current;
        uint8_t _survey_total;
        uint8_t _survey_success;
        uint8_t _survey_failure;
        std::vector<point> _points;
        Timer _display_timer;
};

#endif