Compare commits
2 Commits
02a4ff420d
...
as5600
| Author | SHA1 | Date | |
|---|---|---|---|
| 16995b67ef | |||
| 8b4c00bc7f |
@@ -1,16 +1,17 @@
|
||||
{
|
||||
"tags": [{
|
||||
"TagUID" : "B3 26 D0 15",
|
||||
"audiofile" : "/Billy-Jean.mp3"
|
||||
},
|
||||
{
|
||||
"TagUID" : "1F E8 20 00",
|
||||
"audiofile" : "/Let_it_be.mp3"
|
||||
},
|
||||
{
|
||||
"TagUID" : "23 0E 2C 19",
|
||||
"audiofile" : "/ringoffire.mp3"
|
||||
}],
|
||||
"tags": [
|
||||
{
|
||||
"TagUID" : "B3 26 D0 15",
|
||||
"audiofile" : "/Billy-Jean.mp3"
|
||||
},
|
||||
{
|
||||
"TagUID" : "1F E8 20 00",
|
||||
"audiofile" : "/Let_it_be.mp3"
|
||||
},
|
||||
{
|
||||
"TagUID" : "23 0E 2C 19",
|
||||
"audiofile" : "/ringoffire.mp3"
|
||||
}],
|
||||
"WiFi": [
|
||||
{
|
||||
"ssid": "poes",
|
||||
@@ -19,6 +20,13 @@
|
||||
{
|
||||
"ssid": "wifi2",
|
||||
"psk": "pass2"
|
||||
}
|
||||
]
|
||||
}],
|
||||
|
||||
"AudioGain": 0.5,
|
||||
"ScanTimeout": 50,
|
||||
"HardwareVersion": 2,
|
||||
"GameTimeout": 10000,
|
||||
"PowerTimeout": 420000,
|
||||
"PowerOTADelay": 4000,
|
||||
"Brightness": 20
|
||||
}
|
||||
@@ -8,22 +8,30 @@
|
||||
; Please visit documentation for the other options and examples
|
||||
; https://docs.platformio.org/page/projectconf.html
|
||||
|
||||
[env]
|
||||
src_filter = +<*> -<.git/> -<.svn/> -<example/> -<examples/> -<test/> -<tests/>
|
||||
|
||||
|
||||
[env:esp32-pico]
|
||||
platform = espressif32
|
||||
board = m5stack-atom
|
||||
#board = m5stack-atom
|
||||
board = pico32
|
||||
framework = arduino
|
||||
lib_deps =
|
||||
bblanchon/ArduinoJson@^6.20.0
|
||||
fastled/FastLED@^3.5.0
|
||||
#robtillaart/AS5600 @ ^0.3.4
|
||||
robtillaart/AS5600 @ ^0.3.6
|
||||
|
||||
monitor_speed = 115200
|
||||
src_filter = ${env.build_src_filter}
|
||||
lib_ldf_mode = deep+
|
||||
extra_scripts = ./littlefsbuilder.py
|
||||
build_flags =
|
||||
-DHARDWARE=2
|
||||
-DCORE_DEBUG_LEVEL=3
|
||||
-DNDEF_DEBUG=1
|
||||
upload_protocol = esptool #espota
|
||||
#upload_port = muziekdoos.local
|
||||
extra_scripts = ./littlefsbuilder.py
|
||||
board_build.filesystem = littlefs
|
||||
|
||||
monitor_speed = 115200
|
||||
#upload_protocol = esptool
|
||||
upload_protocol = espota
|
||||
upload_port = muziekdoos.local
|
||||
|
||||
@@ -10,7 +10,6 @@ String nextAudioFile = "";
|
||||
uint8_t n = 0;
|
||||
|
||||
bool audioState = false;
|
||||
|
||||
bool audioInitOk = false;
|
||||
|
||||
const char *waveFile[] =
|
||||
@@ -93,7 +92,7 @@ void initAudio()
|
||||
delay(500);
|
||||
out = new AudioOutputI2S();
|
||||
out->SetPinout(I2S_BCLK, I2S_WCLK, I2S_DATA); // bclk, wclk, data
|
||||
out->SetGain(AUDIOGAIN);
|
||||
out->SetGain(getFloatParam("AudioGain", AUDIOGAIN));
|
||||
pinMode(DAC_SDMODE, OUTPUT);
|
||||
setAudioState(false);
|
||||
mp3 = new AudioGeneratorMP3();
|
||||
|
||||
@@ -8,12 +8,9 @@
|
||||
#include "AudioOutputI2S.h"
|
||||
|
||||
#include "game.h"
|
||||
#include "config.h"
|
||||
|
||||
#define AUDIOGAIN 0.7
|
||||
//#define AUDIONSONGS 3
|
||||
//#define AUDIOREPEATS 3
|
||||
|
||||
|
||||
#define AUDIOGAIN 0.5
|
||||
|
||||
void initAudio(void);
|
||||
void handleAudio(void);
|
||||
|
||||
@@ -5,7 +5,7 @@
|
||||
#include "ArduinoJson.h"
|
||||
|
||||
const char *tagConfigfile = "/settings.json";
|
||||
DynamicJsonDocument settingsDoc(512);
|
||||
DynamicJsonDocument settingsDoc(1024);
|
||||
|
||||
bool configInitOK = false;
|
||||
struct tagConfig
|
||||
@@ -48,6 +48,41 @@ String GetWifiPassword(String ssid)
|
||||
return "";
|
||||
}
|
||||
|
||||
|
||||
int GetIntparam(String param, int def)
|
||||
{
|
||||
|
||||
log_i("Get param %s",param );
|
||||
if(param == "")
|
||||
{
|
||||
log_e("No param(%s) given", param);
|
||||
return def;
|
||||
}
|
||||
if(!settingsDoc.containsKey(param))
|
||||
{
|
||||
log_e("param(%s) not found",param);
|
||||
return def;
|
||||
}
|
||||
return settingsDoc[param];
|
||||
}
|
||||
|
||||
|
||||
float getFloatParam(String param, int def)
|
||||
{
|
||||
log_i("Get param %s",param );
|
||||
if( param == "")
|
||||
{
|
||||
log_e("No param(%s) given",param);
|
||||
return def;
|
||||
}
|
||||
if(!settingsDoc.containsKey(param))
|
||||
{
|
||||
log_e("param(%s)",param);
|
||||
return def;
|
||||
}
|
||||
return settingsDoc[param];
|
||||
}
|
||||
|
||||
void loadConfig(const char *fname)
|
||||
{
|
||||
log_i("config: load");
|
||||
@@ -80,6 +115,9 @@ void loadConfig(const char *fname)
|
||||
}
|
||||
configInitOK = !hasError;
|
||||
}
|
||||
//test values
|
||||
int test = GetIntparam("ScanTimeout");
|
||||
log_i("retval(%i)",test);
|
||||
log_i("config: load done");
|
||||
}
|
||||
|
||||
|
||||
@@ -5,7 +5,8 @@
|
||||
String getConfigSong(String uid);
|
||||
bool getUIDvalid(String uid);
|
||||
String GetWifiPassword(String ssid);
|
||||
|
||||
int GetIntparam(String param, int def = -1);
|
||||
float getFloatParam( String param, int def = -1);
|
||||
|
||||
void initConfig(void);
|
||||
void handleConfig(void);
|
||||
@@ -96,9 +96,11 @@ void handleGame(void)
|
||||
handleNewState();
|
||||
setRFIDscanState(false);
|
||||
setAudioState(false);
|
||||
idleTime = millis();
|
||||
//idleTime = millis();
|
||||
}
|
||||
|
||||
idleTime = getLastTagTime();
|
||||
|
||||
if (!getRFIDlastUIDValid())
|
||||
{
|
||||
// no UID found, go RFID scanning
|
||||
|
||||
@@ -34,7 +34,7 @@ void SetLedColor(CRGB color, bool blink)
|
||||
void initLed(void)
|
||||
{
|
||||
FastLED.addLeds<SK6812, LED_PIN, GRB>(leds, NUM_LEDS); // GRB ordering is typical
|
||||
FastLED.setBrightness(20);
|
||||
FastLED.setBrightness(GetIntparam("Brightness", LEDDEFBRIGHT));
|
||||
}
|
||||
|
||||
void handleLed(void)
|
||||
|
||||
@@ -4,10 +4,12 @@
|
||||
#include "power.h"
|
||||
#include "audio.h"
|
||||
#include "rfid.h"
|
||||
#include "config.h"
|
||||
|
||||
#define NUM_LEDS 1
|
||||
#define LEDTIMEOUT 100
|
||||
#define LEDBLINKTIME 500
|
||||
#define LEDDEFBRIGHT 20
|
||||
|
||||
void initLed(void);
|
||||
void handleLed(void);
|
||||
|
||||
@@ -37,6 +37,7 @@ bool OtaProcess_class::initialize(void)
|
||||
m_psk = tmppsk;
|
||||
}
|
||||
else{
|
||||
log_w("using fallback SSID %s", SECRET_SSID);
|
||||
m_ssid = SECRET_SSID;
|
||||
m_psk = SECRET_PASS;
|
||||
}
|
||||
@@ -68,10 +69,10 @@ bool OtaProcess_class::initialize(void)
|
||||
|
||||
case otaConnect:
|
||||
{
|
||||
log_i("Otastate = initialize(connect)");
|
||||
uint32_t timeTemp = millis();
|
||||
if (timeTemp - m_lastconnectTime > WIFICONNECTINTERVAL)
|
||||
{
|
||||
log_i("Otastate = initialize(connect)");
|
||||
if (WiFi.status() != WL_CONNECTED)
|
||||
{
|
||||
log_e("Connection Failed! Retry...");
|
||||
|
||||
@@ -121,6 +121,7 @@ void handlePowerState(void)
|
||||
// init all
|
||||
log_i("powerinit");
|
||||
SetLedColor(CRGB::Green);
|
||||
//initConfig();
|
||||
powerstate = on;
|
||||
}
|
||||
break;
|
||||
|
||||
@@ -5,6 +5,10 @@ NfcAdapter nfc = NfcAdapter(pn532spi);
|
||||
|
||||
uint32_t lastRFID = 0;
|
||||
uint32_t lastRFIDlog = 0;
|
||||
uint32_t lastTagTime = 0;
|
||||
|
||||
//settings
|
||||
uint32_t scantimeout = 0;
|
||||
|
||||
String lastUid = "";
|
||||
|
||||
@@ -16,6 +20,7 @@ void initRfid()
|
||||
{
|
||||
log_i("RFID init:"); // shows in serial that it is ready to read
|
||||
nfc.begin(true);
|
||||
scantimeout = GetIntparam("ScanTimeout", RFIDTIMEOUT );
|
||||
RfidinitOK = true;
|
||||
log_i("RFID init: OK"); // shows in serial that it is ready to read
|
||||
}
|
||||
@@ -32,16 +37,22 @@ void handleRfid()
|
||||
lastRFIDlog = timeNow;
|
||||
}
|
||||
|
||||
if (nfc.tagPresent(80))
|
||||
if (nfc.tagPresent(RFIDTIMEOUT))
|
||||
{
|
||||
NfcTag tag = nfc.read();
|
||||
lastUid = tag.getUidString();
|
||||
lastTagTime = millis();
|
||||
log_i("found tag %s",lastUid.c_str());
|
||||
}
|
||||
lastRFID = timeNow;
|
||||
}
|
||||
}
|
||||
|
||||
uint32_t getLastTagTime(void)
|
||||
{
|
||||
return lastTagTime;
|
||||
}
|
||||
|
||||
bool getRFIDInitStatus(void)
|
||||
{
|
||||
return RfidinitOK;
|
||||
|
||||
@@ -2,6 +2,7 @@
|
||||
|
||||
#include "board.h"
|
||||
#include "game.h"
|
||||
#include "config.h"
|
||||
|
||||
#include <SPI.h>
|
||||
#include "PN532_SPI.h"
|
||||
@@ -9,8 +10,9 @@
|
||||
#include "NfcAdapter.h"
|
||||
|
||||
#define NDEF_SUPPORT_MIFARE_CLASSIC
|
||||
#define RFIDINTERVAL 800
|
||||
#define RFIDINTERVAL 200
|
||||
#define RFIDLOGINTERVAL 5000
|
||||
#define RFIDTIMEOUT 50
|
||||
|
||||
void initRfid(void);
|
||||
void handleRfid(void);
|
||||
@@ -18,4 +20,5 @@ bool getRFIDInitStatus(void);
|
||||
String getRFIDlastUID(void);
|
||||
void setRFIDscanState(bool state);
|
||||
bool getRFIDlastUIDValid(void);
|
||||
void clearRFIDlastUID(void);
|
||||
void clearRFIDlastUID(void);
|
||||
uint32_t getLastTagTime(void);
|
||||
|
||||
@@ -127,6 +127,11 @@ void handleBatterySensor(void)
|
||||
{
|
||||
uint32_t timeNow = millis();
|
||||
|
||||
if(getAudioState())
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
if (timeNow - lastVbatt > (VBATTINTERVALL - VBATTMEASPRECHARGE))
|
||||
{
|
||||
digitalWrite(MEAS_EN, LOW);
|
||||
@@ -150,17 +155,13 @@ void handleBatterySensor(void)
|
||||
void handleHallSensor(void)
|
||||
{
|
||||
uint32_t timeNow = millis();
|
||||
|
||||
// if(!getAudioState())
|
||||
// {
|
||||
|
||||
// }
|
||||
|
||||
if (timeNow - lastADS < ADSINTERVAL)
|
||||
{
|
||||
return;
|
||||
}
|
||||
lastADS = timeNow;
|
||||
if (timeNow - lastADS < ADSINTERVAL)
|
||||
{
|
||||
//wait for timer
|
||||
return;
|
||||
}
|
||||
lastADS = timeNow;
|
||||
|
||||
int angle = as5600.getCumulativePosition();
|
||||
log_v("sensor angle %d", angle);
|
||||
|
||||
@@ -9,32 +9,18 @@
|
||||
#include "Wire.h"
|
||||
#include "audio.h"
|
||||
|
||||
#define ADSINTERVAL 300
|
||||
#define ADSINTERVAL 100
|
||||
#define VBATTINTERVALL 15000
|
||||
#define VBATTMEASPRECHARGE 500
|
||||
#define LOWBATTPERIOD 30000
|
||||
|
||||
#define HALLINTERVAL 100
|
||||
// #define HALLCNTTHRESHOLD 20
|
||||
// #define HALLIDLETHRESHOLD 20
|
||||
// #define HALLIDLESAMPLES 15
|
||||
// #define HALLPLAYSAMPLES 24
|
||||
#define HALLTHRESHOLD 2
|
||||
|
||||
// typedef enum
|
||||
// {
|
||||
// hall_idle,
|
||||
// hall_increasing,
|
||||
// hall_tipover,
|
||||
// hall_decreasing,
|
||||
// }HALLSENSORSTATES;
|
||||
|
||||
#define HALLTHRESHOLD 5
|
||||
|
||||
void initSensor(void);
|
||||
void handleBatterySensor(void);
|
||||
void handleHallSensor(void);
|
||||
|
||||
|
||||
uint16_t getHall( void );
|
||||
bool hallIsIdle(void);
|
||||
uint16_t getvbatt(uint8_t dummy);
|
||||
|
||||
Reference in New Issue
Block a user