Compare commits
No commits in common. "e66fd11e6848fac0244d154437221d19175fd928" and "58b8891d41dffe03b9317d0746e2cf56e97afbba" have entirely different histories.
e66fd11e68
...
58b8891d41
@ -104,7 +104,7 @@ boolean ConnectivityManager::isAPEnabled()
|
|||||||
unsigned char ConnectivityManager::RSSIPercent()
|
unsigned char ConnectivityManager::RSSIPercent()
|
||||||
{
|
{
|
||||||
int RSSIdBm = RSSI();
|
int RSSIdBm = RSSI();
|
||||||
return (RSSIdBm < MIN_RSSI) ? 0 : COEF_RSSI * ((double)RSSIdBm - (double)MIN_RSSI);
|
return COEF_RSSI * ((double)RSSIdBm - (double)MIN_RSSI);
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned char ConnectivityManager::getError() const
|
unsigned char ConnectivityManager::getError() const
|
||||||
|
@ -7,9 +7,9 @@
|
|||||||
#include "CFGDictionary.h"
|
#include "CFGDictionary.h"
|
||||||
#include "definition.h"
|
#include "definition.h"
|
||||||
|
|
||||||
#define MIN_RSSI -90
|
#define MIN_RSSI -81
|
||||||
#define MAX_RSSI -50
|
#define MAX_RSSI -50
|
||||||
#define COEF_RSSI 2.5
|
#define COEF_RSSI 3.225806452
|
||||||
|
|
||||||
#define STA_ENABLED_DISABLE_ERR B00001000
|
#define STA_ENABLED_DISABLE_ERR B00001000
|
||||||
#define AP_ENABLED_DISABLE_ERR B00000001
|
#define AP_ENABLED_DISABLE_ERR B00000001
|
||||||
|
@ -1,58 +0,0 @@
|
|||||||
#include "EventHandler.h"
|
|
||||||
|
|
||||||
EventHandler::EventHandler(uint8_t queueSize) : _maxQueueSize(queueSize)
|
|
||||||
{
|
|
||||||
//We set the various inputs needed
|
|
||||||
pinMode(GPIO_0, INPUT);
|
|
||||||
}
|
|
||||||
|
|
||||||
void EventHandler::run()
|
|
||||||
{
|
|
||||||
//FLASH_BUTTON PART
|
|
||||||
if(!digitalRead(GPIO_0) && !_flashBtnPushed && millis() - _flashBtnDebounceTs > 200)
|
|
||||||
{
|
|
||||||
_flashBtnPushed = true;
|
|
||||||
_flashBtnTs = millis();
|
|
||||||
}
|
|
||||||
|
|
||||||
if(!digitalRead(GPIO_0) && _flashBtnPushed && millis() - _flashBtnTs > 500 && !_flashBtnLongPressFired)
|
|
||||||
{
|
|
||||||
_flashBtnLongPressFired = true;
|
|
||||||
addEventCheckSizeLimit(FLASH_BUTTON_LONG_PRESS);
|
|
||||||
}
|
|
||||||
|
|
||||||
if(digitalRead(GPIO_0) && _flashBtnPushed && millis() - _flashBtnTs < 500)
|
|
||||||
{
|
|
||||||
_flashBtnPushed = false;
|
|
||||||
addEventCheckSizeLimit(FLASH_BUTTON_PRESS);
|
|
||||||
_flashBtnDebounceTs = millis();
|
|
||||||
}
|
|
||||||
else if(digitalRead(GPIO_0) && _flashBtnPushed && _flashBtnLongPressFired)
|
|
||||||
{
|
|
||||||
_flashBtnPushed = false;
|
|
||||||
_flashBtnLongPressFired = false;
|
|
||||||
_flashBtnDebounceTs = millis();
|
|
||||||
}
|
|
||||||
//FLASH_BUTTON END PART
|
|
||||||
}
|
|
||||||
|
|
||||||
EventHandler::Event EventHandler::getEvent()
|
|
||||||
{
|
|
||||||
if(_eventQueue.count() > 0)
|
|
||||||
return _eventQueue.remove();
|
|
||||||
|
|
||||||
return NO_EVENT;
|
|
||||||
}
|
|
||||||
|
|
||||||
void EventHandler::addEventCheckSizeLimit(Event e)
|
|
||||||
{
|
|
||||||
if(_eventQueue.count() < _maxQueueSize)
|
|
||||||
{
|
|
||||||
_eventQueue.add(e);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
delete _eventQueue.removeRef();
|
|
||||||
_eventQueue.add(e);
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,28 +0,0 @@
|
|||||||
/**
|
|
||||||
* Anatole SCHRAMM-HENRY
|
|
||||||
* 27/04/2020 à 19:45
|
|
||||||
* Tested, working
|
|
||||||
*/
|
|
||||||
#ifndef EVENTHANDLER_H
|
|
||||||
#define EVENTHANDLER_H
|
|
||||||
#include "definition.h"
|
|
||||||
#include "Queue.h"
|
|
||||||
|
|
||||||
class EventHandler
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
enum Event {NO_EVENT = -1,FLASH_BUTTON_PRESS, FLASH_BUTTON_LONG_PRESS};
|
|
||||||
EventHandler(uint8_t queueSize = 10);
|
|
||||||
void run();
|
|
||||||
Event getEvent();
|
|
||||||
protected:
|
|
||||||
private:
|
|
||||||
void addEventCheckSizeLimit(Event e);
|
|
||||||
|
|
||||||
Queue<Event> _eventQueue;
|
|
||||||
uint8_t _maxQueueSize;
|
|
||||||
unsigned long _flashBtnTs = 0, _flashBtnDebounceTs = 0;
|
|
||||||
boolean _flashBtnPushed = false, _flashBtnLongPressFired = false;
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif //EVENTHANDLER_H
|
|
@ -5,15 +5,13 @@
|
|||||||
#include "tasks.h"
|
#include "tasks.h"
|
||||||
#include "CFGDictionary.h"
|
#include "CFGDictionary.h"
|
||||||
#include "CFGParameterValue.h"
|
#include "CFGParameterValue.h"
|
||||||
#include "EventHandler.h"
|
|
||||||
#define DEBUG
|
#define DEBUG
|
||||||
|
|
||||||
SAB sab;
|
SAB sab;
|
||||||
EventHandler evHan;
|
|
||||||
EventHandler::Event evt;
|
|
||||||
|
|
||||||
unsigned long currentMs = 0;
|
unsigned long currentMs = 0, buttonDownMs(0), buttonUpMs(0);
|
||||||
volatile boolean ioStateChange(false);
|
volatile boolean ioStateChange(false);
|
||||||
|
boolean buttonPushSampled(false);
|
||||||
View1Packet v1p = {sab.getRtcManager().getDateTime(), sab.getSdCardManager().getSize(GBYTE), sab.getPowerManager().getPowerInfo(),0, sab.getSoftVersion(), &sab};
|
View1Packet v1p = {sab.getRtcManager().getDateTime(), sab.getSdCardManager().getSize(GBYTE), sab.getPowerManager().getPowerInfo(),0, sab.getSoftVersion(), &sab};
|
||||||
ViewAPPacket vap = {sab.getConnectivityManager().softAPmacAddress(), sab.getConnectivityManager().softAPSSID(), sab.getConnectivityManager().softAPIP(), sab.getConnectivityManager().softAPgetStationNum(), sab.getConnectivityManager().isAPEnabled()};
|
ViewAPPacket vap = {sab.getConnectivityManager().softAPmacAddress(), sab.getConnectivityManager().softAPSSID(), sab.getConnectivityManager().softAPIP(), sab.getConnectivityManager().softAPgetStationNum(), sab.getConnectivityManager().isAPEnabled()};
|
||||||
ViewSTAPacket vstap = {sab.getConnectivityManager().macAddress(), sab.getConnectivityManager().localIP(), sab.getConnectivityManager().RSSI(), sab.getConnectivityManager().isSTAEnabled()};
|
ViewSTAPacket vstap = {sab.getConnectivityManager().macAddress(), sab.getConnectivityManager().localIP(), sab.getConnectivityManager().RSSI(), sab.getConnectivityManager().isSTAEnabled()};
|
||||||
@ -117,26 +115,48 @@ void loop()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
evt = evHan.getEvent();
|
/*if(digitalRead(GPIO_0) == 0 && millis() - buttonMs > 500)
|
||||||
switch(evt)
|
|
||||||
{
|
{
|
||||||
case EventHandler::Event::FLASH_BUTTON_PRESS:
|
buttonMs = millis();
|
||||||
|
sab.getScreenManager().displayNextView();
|
||||||
|
#ifdef DEBUG
|
||||||
|
Serial.println("Changing view");
|
||||||
|
Serial.print("Selected view is : ");Serial.println(sab.getScreenManager().getCurrentViewUID());
|
||||||
|
#endif
|
||||||
|
}*/
|
||||||
|
|
||||||
|
if(digitalRead(GPIO_0) == 0 && !buttonPushSampled)
|
||||||
|
{
|
||||||
|
buttonPushSampled = true;
|
||||||
|
buttonDownMs = millis();
|
||||||
|
}
|
||||||
|
|
||||||
|
if(digitalRead(GPIO_0) == 1 && buttonPushSampled)
|
||||||
|
{
|
||||||
|
buttonPushSampled = false;
|
||||||
|
buttonUpMs = millis();
|
||||||
|
|
||||||
|
if(buttonUpMs - buttonDownMs < 700 && buttonUpMs - buttonDownMs > 200)//Short press
|
||||||
|
{
|
||||||
sab.getScreenManager().displayNextView();
|
sab.getScreenManager().displayNextView();
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
Serial.printf("Changing view\nSelected view is : %d\n",sab.getScreenManager().getCurrentViewUID());
|
Serial.printf("Changing view\nSelected view is : %d\n",sab.getScreenManager().getCurrentViewUID());
|
||||||
#endif
|
#endif
|
||||||
break;
|
}
|
||||||
case EventHandler::Event::FLASH_BUTTON_LONG_PRESS:
|
|
||||||
sab.getScreenManager().displayPreviousView();
|
|
||||||
#ifdef DEBUG
|
|
||||||
Serial.printf("Changing view\nSelected view is : %d\n",sab.getScreenManager().getCurrentViewUID());
|
|
||||||
#endif
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(digitalRead(GPIO_0) == 0 && buttonPushSampled && millis() - buttonDownMs > 700)
|
||||||
|
{
|
||||||
|
buttonPushSampled = false;
|
||||||
|
|
||||||
|
sab.getScreenManager().displayPreviousView();
|
||||||
|
#ifdef DEBUG
|
||||||
|
Serial.printf("Changing view\nSelected view is : %d\n",sab.getScreenManager().getCurrentViewUID());
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
//Run the different services
|
//Run the different services
|
||||||
sab.run();
|
sab.run();
|
||||||
evHan.run();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ICACHE_RAM_ATTR void ioISR()
|
ICACHE_RAM_ATTR void ioISR()
|
||||||
|
Loading…
Reference in New Issue
Block a user