123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122 |
- TaskHandle_t primaryTask;
- TaskHandle_t animationTask;
- SemaphoreHandle_t animationMutex;
- void createSemaphore() {
- animationMutex = xSemaphoreCreateMutex();
- xSemaphoreGive(animationMutex);
- }
- void mutexLock() {
- xSemaphoreTake(animationMutex, portMAX_DELAY);
- }
- void mutexUnlock() {
- xSemaphoreGive(animationMutex);
- }
- void setAnimationCode(char filename) {
- Serial.println("Updating animation frame to " + String(filename));
- mutexLock();
- animation = filename;
- mutexUnlock();
- }
- char getAnimationCode() {
- char anicode = 'a';
- mutexLock();
- anicode = animation;
- mutexUnlock();
- return anicode;
- }
- bool getSwitchState() {
- int switchState = digitalRead(TOGGLE_SWITCH);
- return (switchState == 1);
- }
- void startCoreTasks() {
-
- xTaskCreatePinnedToCore(
- AnimationController,
- "animator",
- 10000,
- NULL,
- 1,
- &animationTask,
- 1
- );
- delay(500);
-
- xTaskCreatePinnedToCore(
- PrimaryController,
- "primary",
- 10000,
- NULL,
- 1,
- &primaryTask,
- 0
- );
- }
- void PrimaryController( void * pvParameters ) {
- Serial.println("Primary logic process started on core " + String(xPortGetCoreID()));
- clearFrame();
- bool switchPushed = getSwitchState();
- if (switchPushed) {
-
-
- setAnimationCode('w');
-
- WiFi.softAP(AP_SSID, NULL);
- Serial.print("Manual mode started. SSID=" + String(AP_SSID) + " listening on : ");
- Serial.println(WiFi.softAPIP());
- registerAPIEndpoints();
-
- dnsServer.setErrorReplyCode(DNSReplyCode::NoError);
- dnsServer.start(53, "*", WiFi.softAPIP());
-
- server.begin();
- for (;;) {
- dnsServer.processNextRequest();
- server.handleClient();
- }
- } else {
-
- int seqCounter = 0;
- for (;;) {
- switchPushed = getSwitchState();
- if (switchPushed) {
-
- executePushAnimationSequence(seqCounter);
- seqCounter++;
- } else {
-
- delay(100);
- }
- }
- }
- }
- void AnimationController( void * pvParameters ) {
- Serial.println("Animation render started on core " + String(xPortGetCoreID()));
- for (;;) {
- char anicode = getAnimationCode();
- handleAnimationRendering(anicode);
- }
- }
|