average pressure
This commit is contained in:
parent
8cd22d1cf1
commit
1881b830b3
@ -28,7 +28,7 @@
|
|||||||
int pressure, pressure_low, pressure_high;
|
int pressure, pressure_low, pressure_high;
|
||||||
bool is_on_pump, is_on_display, display_cur_pressure;
|
bool is_on_pump, is_on_display, display_cur_pressure;
|
||||||
unsigned long last_time1, last_time2, last_time3, last_time_pressure;
|
unsigned long last_time1, last_time2, last_time3, last_time_pressure;
|
||||||
|
const int NUM_READ = 5;
|
||||||
|
|
||||||
EncButton<EB_TICK, S1, S2, KEY> enc;
|
EncButton<EB_TICK, S1, S2, KEY> enc;
|
||||||
GyverTM1637 disp(CLK, DIO);
|
GyverTM1637 disp(CLK, DIO);
|
||||||
@ -44,6 +44,13 @@ int get_constrained_pressure_high(int pressure_high_local) {
|
|||||||
return constrain(pressure_high_local, pressure_low+10, MAX_PRESSURE);
|
return constrain(pressure_high_local, pressure_low+10, MAX_PRESSURE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int getAveragedPressure() {
|
||||||
|
long sum = 0; // локальная переменная sum
|
||||||
|
for (int i = 0; i < NUM_READ; i++) // согласно количеству усреднений
|
||||||
|
sum += analogRead(pressure_port); // суммируем значения с любого датчика в переменную sum
|
||||||
|
return ((float)sum / NUM_READ);
|
||||||
|
}
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
if (DEBUG) {
|
if (DEBUG) {
|
||||||
Serial.begin(9600);
|
Serial.begin(9600);
|
||||||
@ -119,7 +126,7 @@ void loop() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Датчик давления 0 - 1000 0 - 10 атмосфер
|
// Датчик давления 0 - 1000 0 - 10 атмосфер
|
||||||
pressure = analogRead(pressure_port);
|
pressure = getAveragedPressure();
|
||||||
|
|
||||||
// Если прошло 7 сек с момента взаимодействия с энкодером, то отключить дисплей
|
// Если прошло 7 сек с момента взаимодействия с энкодером, то отключить дисплей
|
||||||
if (millis() - last_time2 > 7000) {
|
if (millis() - last_time2 > 7000) {
|
||||||
@ -137,8 +144,8 @@ void loop() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// измерение каждые 700 мс
|
// измерение каждые 1500 мс
|
||||||
if (millis() - last_time_pressure > 700) {
|
if (millis() - last_time_pressure > 1500) {
|
||||||
last_time_pressure = millis();
|
last_time_pressure = millis();
|
||||||
|
|
||||||
// Если текущее давление ниже нижнего порога - включить насос
|
// Если текущее давление ниже нижнего порога - включить насос
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user