-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathFrSkySportSensorFlvss.cpp
executable file
·109 lines (100 loc) · 3.21 KB
/
FrSkySportSensorFlvss.cpp
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
/*
FrSky FLVSS/MLVSS LiPo voltage sensor class for Teensy 3.x/4.0/LC, ESP8266, ATmega2560 (Mega) and ATmega328P based boards (e.g. Pro Mini, Nano, Uno)
(c) Pawelsky 202000503
Not for commercial use
*/
#include "FrSkySportSensorFlvss.h"
FrSkySportSensorFlvss::FrSkySportSensorFlvss(SensorId id) : FrSkySportSensor(id) { }
uint32_t FrSkySportSensorFlvss::setCellData(uint8_t cellNum, uint8_t firstCellNo, float cell1, float cell2)
{
uint16_t cell1Data = cell1 * 500.0;
uint16_t cell2Data = cell2 * 500.0;
uint32_t cellData = 0;
cellData = cell2Data & 0x0FFF;
cellData <<= 12;
cellData |= cell1Data & 0x0FFF;
cellData <<= 4;
cellData |= cellNum & 0x0F;
cellData <<= 4;
cellData |= firstCellNo & 0x0F;
return cellData;
}
void FrSkySportSensorFlvss::setData(float cell1, float cell2, float cell3, float cell4, float cell5, float cell6)
{
uint8_t numCells = 1; // We assume at least one cell
if(cell2 > 0)
{
numCells++;
if(cell3 > 0)
{
numCells++;
if(cell4 > 0)
{
numCells++;
if(cell5 > 0)
{
numCells++;
if(cell6 > 0)
{
numCells++;
}
}
}
}
}
cellData1 = setCellData(numCells, 0, cell1, cell2);
if(numCells > 2) cellData2 = setCellData(numCells, 2, cell3, cell4); else cellData2 = 0;
if(numCells > 4) cellData3 = setCellData(numCells, 4, cell5, cell6); else cellData3 = 0;
}
uint16_t FrSkySportSensorFlvss::send(FrSkySportSingleWireSerial& serial, uint8_t id, uint32_t now)
{
uint16_t dataId = SENSOR_NO_DATA_ID;
if(sensorId == id)
{
dataId = FLVSS_CELL_DATA_ID;
if(now > cellDataTime)
{
cellDataTime = now + FLVSS_CELL_DATA_PERIOD;
switch(sensorDataIdx)
{
case 0:
serial.sendData(dataId, cellData1); if(cellData2 != 0) sensorDataIdx = 1; else sensorDataIdx = 0;
break;
case 1:
serial.sendData(dataId, cellData2); if(cellData3 != 0) sensorDataIdx = 2; else sensorDataIdx = 0;
break;
case 2:
serial.sendData(dataId, cellData3); sensorDataIdx = 0;
break;
}
}
else
{
serial.sendEmpty(dataId);
dataId = SENSOR_EMPTY_DATA_ID;
}
}
return dataId;
}
uint16_t FrSkySportSensorFlvss::decodeData(uint8_t id, uint16_t appId, uint32_t data)
{
if((sensorId == id) || (sensorId == FrSkySportSensor::ID_IGNORE))
{
if(appId == FLVSS_CELL_DATA_ID)
{
uint8_t firstCellNo = data & 0x0F; data >>= 4;
uint8_t cellNum = data & 0x0F; data >>= 4;
cell[firstCellNo] = (data & 0x0FFF) / 500.0; data >>= 12;
cell[firstCellNo + 1] = (data & 0x0FFF) / 500.0;
for(uint8_t i = cellNum; i <= 5; i++) cell[i] = 0.0;
return appId;
}
}
return SENSOR_NO_DATA_ID;
}
float FrSkySportSensorFlvss::getCell1() { return cell[0]; }
float FrSkySportSensorFlvss::getCell2() { return cell[1]; }
float FrSkySportSensorFlvss::getCell3() { return cell[2]; }
float FrSkySportSensorFlvss::getCell4() { return cell[3]; }
float FrSkySportSensorFlvss::getCell5() { return cell[4]; }
float FrSkySportSensorFlvss::getCell6() { return cell[5]; }