mirror of
				https://github.com/Dejvino/lilybook.git
				synced 2025-10-29 19:15:22 +00:00 
			
		
		
		
	Added app modes, extracted into mode controllers.
This commit is contained in:
		
							parent
							
								
									f343983184
								
							
						
					
					
						commit
						a32fcd8785
					
				| @ -3,5 +3,5 @@ | ||||
| #
 | ||||
| # (Uses default behaviour of compiling all source files in directory, adding 'include' to include path.)
 | ||||
| 
 | ||||
| COMPONENT_SRCDIRS := .  | ||||
| COMPONENT_SRCDIRS := . core modes | ||||
| COMPONENT_ADD_INCLUDEDIRS := . | ||||
|  | ||||
| @ -1,4 +1,12 @@ | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| void buttons_init(); | ||||
| bool buttons_pressed_ok(); | ||||
| bool buttons_pressed_plus(); | ||||
| bool buttons_pressed_minus(); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
							
								
								
									
										7
									
								
								main/core/common.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								main/core/common.c
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,7 @@ | ||||
| #include "freertos/FreeRTOS.h" | ||||
| #include "freertos/task.h" | ||||
| 
 | ||||
| void delay(unsigned int ms) | ||||
| { | ||||
|     vTaskDelay(ms / portTICK_RATE_MS); | ||||
| } | ||||
							
								
								
									
										14
									
								
								main/core/common.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								main/core/common.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,14 @@ | ||||
| #ifndef _COMMON_H_ | ||||
| #define _COMMON_H_ | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| void delay(unsigned int ms); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| 
 | ||||
| #endif | ||||
| @ -1,3 +1,7 @@ | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| void display_init(); | ||||
| void spi_init(); | ||||
| void display_connect(); | ||||
| @ -9,3 +13,7 @@ void display_update(); | ||||
| 
 | ||||
| void display_wake(); | ||||
| void display_sleep(); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
							
								
								
									
										9
									
								
								main/core/storage.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								main/core/storage.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,9 @@ | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| int storage_init(); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
							
								
								
									
										114
									
								
								main/main.cpp
									
									
									
									
									
								
							
							
						
						
									
										114
									
								
								main/main.cpp
									
									
									
									
									
								
							| @ -4,8 +4,6 @@ | ||||
| #include <time.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
| #include "freertos/FreeRTOS.h" | ||||
| #include "freertos/task.h" | ||||
| #include "esp_system.h" | ||||
| #include "driver/gpio.h" | ||||
| #include "esp_system.h" | ||||
| @ -14,16 +12,15 @@ | ||||
| #include "esp_log.h" | ||||
| static const char *TAG = "main"; | ||||
| 
 | ||||
| extern "C" { | ||||
| #include "core/common.h" | ||||
| #include "config.h" | ||||
| #include "buttons.h" | ||||
| #include "storage.h" | ||||
| #include "display.h" | ||||
| } | ||||
| #include "core/buttons.h" | ||||
| #include "core/storage.h" | ||||
| #include "core/display.h" | ||||
| 
 | ||||
| #include "modes/ModeRunner.h" | ||||
| #include "modes/BootMode.h" | ||||
| 
 | ||||
| #include "Typesetter.h" | ||||
| #include "TextStorage.h" | ||||
| #include "PagePrinter.h" | ||||
| 
 | ||||
| static struct tm* tm_info; | ||||
| static char tmp_buff[128]; | ||||
| @ -32,11 +29,6 @@ static const char *file_fonts[3] = {"/spiffs/fonts/DotMatrix_M.fon", "/spiffs/fo | ||||
| static const char tag[] = "[LilyBook]"; | ||||
| esp_err_t ret; | ||||
| 
 | ||||
| void sleep(unsigned int ms) | ||||
| { | ||||
|     vTaskDelay(ms / portTICK_RATE_MS); | ||||
| } | ||||
| 
 | ||||
| extern "C" void app_main() | ||||
| { | ||||
|     printf("\n   LilyBook v%s\n\n", APP_VERSION); | ||||
| @ -46,99 +38,15 @@ extern "C" void app_main() | ||||
|     display_init(); | ||||
|     spi_init(); | ||||
| 
 | ||||
| 	sleep(500); | ||||
| 	delay(500); | ||||
| 
 | ||||
| 	display_connect(); | ||||
|     display_splash_screen(); | ||||
| 
 | ||||
|     sleep(500); | ||||
| 
 | ||||
| 	printf("==== START ====\r\n\n"); | ||||
| 
 | ||||
|     Typesetter typesetter; | ||||
|     PagePrinter pagePrinter; | ||||
|     TextStorage textStorage; | ||||
|     TextReader* textReader = textStorage.open("/sdcard/book.txt"); | ||||
|     Page* pageLast = NULL; | ||||
|     Page* pageCurrent = NULL; | ||||
| 
 | ||||
|     long bookmark = 0; | ||||
|     //bool displaySleeping = false;
 | ||||
| 
 | ||||
|     getModeRunner()->init(); | ||||
|     getModeRunner()->startMainMode(new BootMode()); | ||||
|     while (1) { | ||||
| 		char text[1024]; | ||||
|         if (textReader != NULL) { | ||||
|             if (pageCurrent == NULL) { | ||||
|                 size_t read = textReader->read(bookmark, text, sizeof(text)); | ||||
|                 pageCurrent = typesetter.preparePage(text, read); | ||||
|                 pageCurrent->start = bookmark; | ||||
|         getModeRunner()->loop(); | ||||
|     } | ||||
|             if (pageLast == NULL) { | ||||
|                 // align with the start?
 | ||||
|                 if (bookmark < sizeof(text)) { | ||||
|                     size_t read = textReader->read(0, text, sizeof(text)); | ||||
|                     pageLast = typesetter.preparePage(text, read); | ||||
|                     pageLast->start = 0; | ||||
|                 } else { | ||||
|                     size_t read = textReader->read((bookmark - sizeof(text)), text, sizeof(text)); | ||||
|                     pageLast = typesetter.preparePreviousPage(text, read); | ||||
|                     pageLast->start = bookmark - pageLast->len; | ||||
|                 } | ||||
|             } | ||||
|         } else { | ||||
|             typesetter.destroyPage(pageCurrent); | ||||
|             strcpy(text, "File could not be opened."); | ||||
|             pageCurrent = typesetter.preparePage(text, sizeof(text)); | ||||
|         } | ||||
| 
 | ||||
|         display_clear(); | ||||
|         pagePrinter.print(pageCurrent); | ||||
|         display_update(); | ||||
| 
 | ||||
|         //time_t idleStart = clock();
 | ||||
|         while (1) { | ||||
|             sleep(10); | ||||
|             if (buttons_pressed_ok()) { | ||||
|                 ESP_LOGI(TAG, "Clear page."); | ||||
|                 display_refresh(); | ||||
|                 break; | ||||
|             } | ||||
|             if (buttons_pressed_plus()) { | ||||
|                 ESP_LOGI(TAG, "Turn page PLUS."); | ||||
|                 if (pageCurrent != NULL) { | ||||
|                     bookmark = pageCurrent->start + pageCurrent->len; | ||||
|                     // TODO: limit bookmark to file size
 | ||||
|                     typesetter.destroyPage(pageLast); | ||||
|                     pageLast = pageCurrent; | ||||
|                     pageCurrent = NULL; | ||||
|                 } else { | ||||
|                     ESP_LOGW(TAG, "No current page."); | ||||
|                 } | ||||
|                 break; | ||||
|             } | ||||
|             if (buttons_pressed_minus()) { | ||||
|                 ESP_LOGI(TAG, "Turn page MINUS."); | ||||
|                 if (pageLast != NULL) { | ||||
|                     bookmark = pageLast->start; | ||||
|                     typesetter.destroyPage(pageCurrent); | ||||
|                     pageCurrent = pageLast; | ||||
|                     pageLast = NULL; | ||||
|                 } else { | ||||
|                     ESP_LOGW(TAG, "No last page."); | ||||
|                 } | ||||
|                 break; | ||||
|             } | ||||
|             /*if (!displaySleeping && (clock() - idleStart > DISPLAY_SLEEP_TIMEOUT)) {
 | ||||
|                 displaySleeping = true; | ||||
|                 ESP_LOGI(TAG, "Display going to sleep after %d ms.", DISPLAY_SLEEP_TIMEOUT); | ||||
|                 display_sleep(); | ||||
|             }*/ | ||||
|         } | ||||
|         /*if (displaySleeping) {
 | ||||
|             displaySleeping = false; | ||||
|             ESP_LOGI(TAG, "Display waking up."); | ||||
|             display_wake(); | ||||
|         }*/ | ||||
|     } | ||||
| 
 | ||||
| } | ||||
|  | ||||
							
								
								
									
										12
									
								
								main/modes/AppMode.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								main/modes/AppMode.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,12 @@ | ||||
| #ifndef _APPMODE_H_ | ||||
| #define _APPMODE_H_ | ||||
| 
 | ||||
| class AppMode | ||||
| { | ||||
| public: | ||||
|     virtual void start(); | ||||
|     virtual void loop(); | ||||
|     virtual void finish(); | ||||
| }; | ||||
| 
 | ||||
| #endif | ||||
							
								
								
									
										19
									
								
								main/modes/BootMode.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								main/modes/BootMode.cpp
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,19 @@ | ||||
| #include "core/common.h" | ||||
| #include "core/display.h" | ||||
| #include "ModeRunner.h" | ||||
| #include "MainMenuMode.h" | ||||
| #include "BootMode.h" | ||||
| 
 | ||||
| void BootMode::start() | ||||
| {} | ||||
| 
 | ||||
| void BootMode::loop() | ||||
| { | ||||
|     display_splash_screen(); | ||||
|     delay(500); | ||||
| 
 | ||||
|     getModeRunner()->startMainMode(new MainMenuMode()); | ||||
| } | ||||
| 
 | ||||
| void BootMode::finish() | ||||
| {} | ||||
							
								
								
									
										9
									
								
								main/modes/BootMode.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								main/modes/BootMode.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,9 @@ | ||||
| #include "AppMode.h" | ||||
| 
 | ||||
| class BootMode : public AppMode | ||||
| { | ||||
| public: | ||||
|     virtual void start(); | ||||
|     virtual void loop(); | ||||
|     virtual void finish(); | ||||
| }; | ||||
							
								
								
									
										25
									
								
								main/modes/MainMenuMode.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								main/modes/MainMenuMode.cpp
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,25 @@ | ||||
| #include "core/common.h" | ||||
| #include "core/buttons.h" | ||||
| #include "core/display.h" | ||||
| #include <EPD.h> | ||||
| #include "MainMenuMode.h" | ||||
| 
 | ||||
| void MainMenuMode::start() | ||||
| {} | ||||
| 
 | ||||
| void MainMenuMode::loop() | ||||
| { | ||||
|     display_clear(); | ||||
|     EPD_print("Main Menu", CENTER, 0); | ||||
|     display_update(); | ||||
| 
 | ||||
|     while(1) { | ||||
|         delay(5); | ||||
|         if (buttons_pressed_ok()) { | ||||
|             break; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void MainMenuMode::finish() | ||||
| {} | ||||
							
								
								
									
										9
									
								
								main/modes/MainMenuMode.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								main/modes/MainMenuMode.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,9 @@ | ||||
| #include "AppMode.h" | ||||
| 
 | ||||
| class MainMenuMode : public AppMode | ||||
| { | ||||
| public: | ||||
|     virtual void start(); | ||||
|     virtual void loop(); | ||||
|     virtual void finish(); | ||||
| }; | ||||
							
								
								
									
										55
									
								
								main/modes/ModeRunner.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								main/modes/ModeRunner.cpp
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,55 @@ | ||||
| #include "ModeRunner.h" | ||||
| 
 | ||||
| #include "esp_log.h" | ||||
| static const char *TAG = "ModeRunner"; | ||||
| 
 | ||||
| void ModeRunner::init() | ||||
| { | ||||
|     this->modeStackDepth = -1; | ||||
| } | ||||
| 
 | ||||
| void ModeRunner::loop() | ||||
| { | ||||
|     if (this->modeStackDepth < 0) { | ||||
|         ESP_LOGE(TAG, "Cannot run app mode. None activated (depth %d).", this->modeStackDepth); | ||||
|         return; | ||||
|     } | ||||
|     this->modeStack[this->modeStackDepth]->loop(); | ||||
| } | ||||
| 
 | ||||
| void ModeRunner::startMainMode(AppMode* mode) | ||||
| { | ||||
|     this->finishMode(NULL); | ||||
|     this->modeStackDepth = -1; | ||||
|     this->startInnerMode(mode); | ||||
| } | ||||
| 
 | ||||
| void ModeRunner::startInnerMode(AppMode* mode) | ||||
| { | ||||
|     if (this->modeStackDepth + 1 >= MODE_STACK_SIZE) { | ||||
|         ESP_LOGE(TAG, "Cannot start inner mode. Stack overflow."); | ||||
|         return; | ||||
|     } | ||||
|     this->modeStackDepth++; | ||||
|     this->modeStack[this->modeStackDepth] = mode; | ||||
|     ESP_LOGI(TAG, "Starting new mode (depth %d).", this->modeStackDepth); | ||||
|     mode->start(); | ||||
| } | ||||
| 
 | ||||
| void ModeRunner::finishMode(AppMode* mode) | ||||
| { | ||||
|     for (int i = this->modeStackDepth; i >= 0; i--) { | ||||
|         ESP_LOGI(TAG, "Finishing mode (depth %d).", this->modeStackDepth); | ||||
|         this->modeStack[i]->finish(); | ||||
|         this->modeStackDepth--; | ||||
|         if (mode == this->modeStack[i]) { | ||||
|             break; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| ModeRunner modeRunner; | ||||
| ModeRunner* getModeRunner() | ||||
| { | ||||
|     return &modeRunner; | ||||
| } | ||||
							
								
								
									
										20
									
								
								main/modes/ModeRunner.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								main/modes/ModeRunner.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,20 @@ | ||||
| #include "AppMode.h" | ||||
| #define MODE_STACK_SIZE 5 | ||||
| 
 | ||||
| class ModeRunner | ||||
| { | ||||
| public: | ||||
|     void init(); | ||||
|     void loop(); | ||||
| 
 | ||||
|     void startMainMode(AppMode* mode); | ||||
|     void startInnerMode(AppMode* mode); | ||||
| 
 | ||||
|     void finishMode(AppMode* mode); | ||||
| 
 | ||||
| private: | ||||
|     AppMode* modeStack[MODE_STACK_SIZE]; | ||||
|     int modeStackDepth = -1; | ||||
| }; | ||||
| 
 | ||||
| ModeRunner* getModeRunner(); | ||||
							
								
								
									
										106
									
								
								main/modes/ReaderMode.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										106
									
								
								main/modes/ReaderMode.cpp
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,106 @@ | ||||
| #include "core/common.h" | ||||
| #include "string.h" | ||||
| #include "core/buttons.h" | ||||
| #include "core/display.h" | ||||
| #include "reader/Typesetter.h" | ||||
| #include "reader/TextStorage.h" | ||||
| #include "reader/PagePrinter.h" | ||||
| #include "ReaderMode.h" | ||||
| 
 | ||||
| #include "esp_log.h" | ||||
| static const char *TAG = "ReaderMode"; | ||||
| 
 | ||||
| // TODO: class members
 | ||||
| Typesetter typesetter; | ||||
| PagePrinter pagePrinter; | ||||
| TextStorage textStorage; | ||||
| TextReader* textReader = textStorage.open("/sdcard/book.txt"); | ||||
| Page* pageLast = NULL; | ||||
| Page* pageCurrent = NULL; | ||||
| 
 | ||||
| long bookmark = 0; | ||||
| //bool displaySleeping = false;
 | ||||
| 
 | ||||
| void ReaderMode::start() | ||||
| { | ||||
| } | ||||
| 
 | ||||
| void ReaderMode::loop() | ||||
| { | ||||
|     char text[1024]; | ||||
|     if (textReader != NULL) { | ||||
|         if (pageCurrent == NULL) { | ||||
|             size_t read = textReader->read(bookmark, text, sizeof(text)); | ||||
|             pageCurrent = typesetter.preparePage(text, read); | ||||
|             pageCurrent->start = bookmark; | ||||
|         } | ||||
|         if (pageLast == NULL) { | ||||
|             // align with the start?
 | ||||
|             if (bookmark < sizeof(text)) { | ||||
|                 size_t read = textReader->read(0, text, sizeof(text)); | ||||
|                 pageLast = typesetter.preparePage(text, read); | ||||
|                 pageLast->start = 0; | ||||
|             } else { | ||||
|                 size_t read = textReader->read((bookmark - sizeof(text)), text, sizeof(text)); | ||||
|                 pageLast = typesetter.preparePreviousPage(text, read); | ||||
|                 pageLast->start = bookmark - pageLast->len; | ||||
|             } | ||||
|         } | ||||
|     } else { | ||||
|         typesetter.destroyPage(pageCurrent); | ||||
|         strcpy(text, "File could not be opened."); | ||||
|         pageCurrent = typesetter.preparePage(text, sizeof(text)); | ||||
|     } | ||||
| 
 | ||||
|     display_clear(); | ||||
|     pagePrinter.print(pageCurrent); | ||||
|     display_update(); | ||||
| 
 | ||||
|     //time_t idleStart = clock();
 | ||||
|     while (1) { | ||||
|         delay(10); | ||||
|         if (buttons_pressed_ok()) { | ||||
|             ESP_LOGI(TAG, "Clear page."); | ||||
|             display_refresh(); | ||||
|             break; | ||||
|         } | ||||
|         if (buttons_pressed_plus()) { | ||||
|             ESP_LOGI(TAG, "Turn page PLUS."); | ||||
|             if (pageCurrent != NULL) { | ||||
|                 bookmark = pageCurrent->start + pageCurrent->len; | ||||
|                 // TODO: limit bookmark to file size
 | ||||
|                 typesetter.destroyPage(pageLast); | ||||
|                 pageLast = pageCurrent; | ||||
|                 pageCurrent = NULL; | ||||
|             } else { | ||||
|                 ESP_LOGW(TAG, "No current page."); | ||||
|             } | ||||
|             break; | ||||
|         } | ||||
|         if (buttons_pressed_minus()) { | ||||
|             ESP_LOGI(TAG, "Turn page MINUS."); | ||||
|             if (pageLast != NULL) { | ||||
|                 bookmark = pageLast->start; | ||||
|                 typesetter.destroyPage(pageCurrent); | ||||
|                 pageCurrent = pageLast; | ||||
|                 pageLast = NULL; | ||||
|             } else { | ||||
|                 ESP_LOGW(TAG, "No last page."); | ||||
|             } | ||||
|             break; | ||||
|         } | ||||
|         /*if (!displaySleeping && (clock() - idleStart > DISPLAY_SLEEP_TIMEOUT)) {
 | ||||
|             displaySleeping = true; | ||||
|             ESP_LOGI(TAG, "Display going to sleep after %d ms.", DISPLAY_SLEEP_TIMEOUT); | ||||
|             display_sleep(); | ||||
|         }*/ | ||||
|     } | ||||
|     /*if (displaySleeping) {
 | ||||
|         displaySleeping = false; | ||||
|         ESP_LOGI(TAG, "Display waking up."); | ||||
|         display_wake(); | ||||
|     }*/ | ||||
| } | ||||
| 
 | ||||
| void ReaderMode::finish() | ||||
| {} | ||||
							
								
								
									
										9
									
								
								main/modes/ReaderMode.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								main/modes/ReaderMode.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,9 @@ | ||||
| #include "AppMode.h" | ||||
| 
 | ||||
| class ReaderMode : AppMode | ||||
| { | ||||
| public: | ||||
|     virtual void start(); | ||||
|     virtual void loop(); | ||||
|     virtual void finish(); | ||||
| }; | ||||
| @ -1,2 +0,0 @@ | ||||
| 
 | ||||
| int storage_init(); | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user