summaryrefslogtreecommitdiff
path: root/src/displayapp/DisplayApp.cpp
diff options
context:
space:
mode:
authorAvamander <avamander@gmail.com>2020-10-02 21:46:41 +0300
committerAvamander <avamander@gmail.com>2020-10-02 21:46:41 +0300
commite3fb2f0b8974f3e9a124d27f4b568e754ccfb782 (patch)
treebc43f58bca6920bfb5a78f3cf26d0ec5e8c0d5a0 /src/displayapp/DisplayApp.cpp
parent30c261028e27dab0e30aec19b9c21c37cc74e92b (diff)
Renamed DisplayApp/ to displayapp/
Diffstat (limited to 'src/displayapp/DisplayApp.cpp')
-rw-r--r--src/displayapp/DisplayApp.cpp271
1 files changed, 271 insertions, 0 deletions
diff --git a/src/displayapp/DisplayApp.cpp b/src/displayapp/DisplayApp.cpp
new file mode 100644
index 00000000..46e81f1d
--- /dev/null
+++ b/src/displayapp/DisplayApp.cpp
@@ -0,0 +1,271 @@
+#include "DisplayApp.h"
+#include <FreeRTOS.h>
+#include <task.h>
+#include <libraries/log/nrf_log.h>
+#include <nrf_font.h>
+#include <queue.h>
+#include <Components/DateTime/DateTimeController.h>
+#include <drivers/Cst816s.h>
+#include <string>
+#include <DisplayApp/Screens/Tile.h>
+#include <DisplayApp/Screens/Meter.h>
+#include <DisplayApp/Screens/Gauge.h>
+#include <DisplayApp/Screens/Brightness.h>
+#include <DisplayApp/Screens/SystemInfo.h>
+#include <DisplayApp/Screens/Music.h>
+#include <Components/Ble/NotificationManager.h>
+#include <DisplayApp/Screens/FirmwareUpdate.h>
+#include <DisplayApp/Screens/ApplicationList.h>
+#include <DisplayApp/Screens/FirmwareValidation.h>
+#include <DisplayApp/Screens/InfiniPaint.h>
+#include "../SystemTask/SystemTask.h"
+
+using namespace Pinetime::Applications;
+
+DisplayApp::DisplayApp(Drivers::St7789 &lcd, Components::LittleVgl &lvgl, Drivers::Cst816S &touchPanel,
+ Controllers::Battery &batteryController, Controllers::Ble &bleController,
+ Controllers::DateTime &dateTimeController, Drivers::WatchdogView &watchdog,
+ System::SystemTask &systemTask,
+ Pinetime::Controllers::NotificationManager& notificationManager) :
+ lcd{lcd},
+ lvgl{lvgl},
+ batteryController{batteryController},
+ bleController{bleController},
+ dateTimeController{dateTimeController},
+ watchdog{watchdog},
+ touchPanel{touchPanel},
+ currentScreen{new Screens::Clock(this, dateTimeController, batteryController, bleController) },
+ systemTask{systemTask},
+ notificationManager{notificationManager} {
+ msgQueue = xQueueCreate(queueSize, itemSize);
+ onClockApp = true;
+ modal.reset(new Screens::Modal(this));
+}
+
+void DisplayApp::Start() {
+ if (pdPASS != xTaskCreate(DisplayApp::Process, "displayapp", 512, this, 0, &taskHandle))
+ APP_ERROR_HANDLER(NRF_ERROR_NO_MEM);
+}
+
+void DisplayApp::Process(void *instance) {
+ auto *app = static_cast<DisplayApp *>(instance);
+ NRF_LOG_INFO("displayapp task started!");
+ app->InitHw();
+
+ // Send a dummy notification to unlock the lvgl display driver for the first iteration
+ xTaskNotifyGive(xTaskGetCurrentTaskHandle());
+
+ while (1) {
+
+ app->Refresh();
+
+ }
+}
+
+void DisplayApp::InitHw() {
+ brightnessController.Init();
+}
+
+uint32_t acc = 0;
+uint32_t count = 0;
+bool toggle = true;
+void DisplayApp::Refresh() {
+ TickType_t queueTimeout;
+ switch (state) {
+ case States::Idle:
+ IdleState();
+ queueTimeout = portMAX_DELAY;
+ break;
+ case States::Running:
+ RunningState();
+ queueTimeout = 20;
+ break;
+ default:
+ queueTimeout = portMAX_DELAY;
+ break;
+ }
+
+ Messages msg;
+ if (xQueueReceive(msgQueue, &msg, queueTimeout)) {
+ switch (msg) {
+ case Messages::GoToSleep:
+ brightnessController.Backup();
+ while(brightnessController.Level() != Controllers::BrightnessController::Levels::Off) {
+ brightnessController.Lower();
+ vTaskDelay(100);
+ }
+ lcd.DisplayOff();
+ systemTask.PushMessage(System::SystemTask::Messages::OnDisplayTaskSleeping);
+ state = States::Idle;
+ break;
+ case Messages::GoToRunning:
+ lcd.DisplayOn();
+ brightnessController.Restore();
+ state = States::Running;
+ break;
+ case Messages::UpdateDateTime:
+// modal->Show();
+ break;
+ case Messages::UpdateBleConnection:
+// clockScreen.SetBleConnectionState(bleController.IsConnected() ? Screens::Clock::BleConnectionStates::Connected : Screens::Clock::BleConnectionStates::NotConnected);
+ break;
+ case Messages::UpdateBatteryLevel:
+// clockScreen.SetBatteryPercentRemaining(batteryController.PercentRemaining());
+ break;
+ case Messages::NewNotification: {
+ auto notification = notificationManager.Pop();
+ modal->Show(notification.message.data());
+ }
+ break;
+ case Messages::TouchEvent: {
+ if (state != States::Running) break;
+ auto gesture = OnTouchEvent();
+ if(!currentScreen->OnTouchEvent(gesture)) {
+ switch (gesture) {
+ case TouchEvents::SwipeUp:
+ currentScreen->OnButtonPushed();
+ lvgl.SetFullRefresh(Components::LittleVgl::FullRefreshDirections::Up);
+ break;
+ case TouchEvents::SwipeDown:
+ currentScreen->OnButtonPushed();
+ lvgl.SetFullRefresh(Components::LittleVgl::FullRefreshDirections::Down);
+ break;
+ default:
+ break;
+ }
+ }
+ }
+ break;
+ case Messages::ButtonPushed:
+ if(onClockApp)
+ systemTask.PushMessage(System::SystemTask::Messages::GoToSleep);
+ else {
+ auto buttonUsedByApp = currentScreen->OnButtonPushed();
+ if (!buttonUsedByApp) {
+ systemTask.PushMessage(System::SystemTask::Messages::GoToSleep);
+ } else {
+ lvgl.SetFullRefresh(Components::LittleVgl::FullRefreshDirections::Up);
+ }
+ }
+
+// lvgl.SetFullRefresh(Components::LittleVgl::FullRefreshDirections::Down);
+// currentScreen.reset(nullptr);
+// if(toggle) {
+// currentScreen.reset(new Screens::Tile(this));
+// toggle = false;
+// } else {
+// currentScreen.reset(new Screens::Clock(this, dateTimeController, batteryController, bleController));
+// toggle = true;
+// }
+
+ break;
+ case Messages::BleFirmwareUpdateStarted:
+ lvgl.SetFullRefresh(Components::LittleVgl::FullRefreshDirections::Down);
+ currentScreen.reset(nullptr);
+ currentScreen.reset(new Screens::FirmwareUpdate(this, bleController));
+ onClockApp = false;
+
+ break;
+ }
+ }
+
+ if(state != States::Idle && touchMode == TouchModes::Polling) {
+ auto info = touchPanel.GetTouchInfo();
+ if(info.action == 2) {// 2 = contact
+ if(!currentScreen->OnTouchEvent(info.x, info.y)) {
+ lvgl.SetNewTapEvent(info.x, info.y);
+ }
+ }
+ }
+}
+
+void DisplayApp::RunningState() {
+// clockScreen.SetCurrentDateTime(dateTimeController.CurrentDateTime());
+
+ if(!currentScreen->Refresh()) {
+ currentScreen.reset(nullptr);
+ lvgl.SetFullRefresh(Components::LittleVgl::FullRefreshDirections::Up);
+ onClockApp = false;
+ switch(nextApp) {
+ case Apps::None:
+ case Apps::Launcher: currentScreen.reset(new Screens::ApplicationList(this)); break;
+ case Apps::Clock:
+ currentScreen.reset(new Screens::Clock(this, dateTimeController, batteryController, bleController));
+ onClockApp = true;
+ break;
+// case Apps::Test: currentScreen.reset(new Screens::Message(this)); break;
+ case Apps::SysInfo: currentScreen.reset(new Screens::SystemInfo(this, dateTimeController, batteryController, brightnessController, bleController, watchdog)); break;
+ case Apps::Meter: currentScreen.reset(new Screens::Meter(this)); break;
+ case Apps::Gauge: currentScreen.reset(new Screens::Gauge(this)); break;
+ case Apps::Paint: currentScreen.reset(new Screens::InfiniPaint(this, lvgl)); break;
+ case Apps::Brightness : currentScreen.reset(new Screens::Brightness(this, brightnessController)); break;
+ case Apps::Music : currentScreen.reset(new Screens::Music(this, systemTask.nimble().music())); break;
+ case Apps::FirmwareValidation: currentScreen.reset(new Screens::FirmwareValidation(this, validator)); break;
+ }
+ nextApp = Apps::None;
+ }
+ lv_task_handler();
+}
+
+void DisplayApp::IdleState() {
+
+}
+
+void DisplayApp::PushMessage(DisplayApp::Messages msg) {
+ BaseType_t xHigherPriorityTaskWoken;
+ xHigherPriorityTaskWoken = pdFALSE;
+ xQueueSendFromISR(msgQueue, &msg, &xHigherPriorityTaskWoken);
+ if (xHigherPriorityTaskWoken) {
+ /* Actual macro used here is port specific. */
+ // TODO : should I do something here?
+ }
+}
+
+TouchEvents DisplayApp::OnTouchEvent() {
+ auto info = touchPanel.GetTouchInfo();
+ if(info.isTouch) {
+ switch(info.gesture) {
+ case Pinetime::Drivers::Cst816S::Gestures::SingleTap:
+ if(touchMode == TouchModes::Gestures)
+ lvgl.SetNewTapEvent(info.x, info.y);
+ return TouchEvents::Tap;
+ case Pinetime::Drivers::Cst816S::Gestures::LongPress:
+ return TouchEvents::LongTap;
+ case Pinetime::Drivers::Cst816S::Gestures::DoubleTap:
+ return TouchEvents::DoubleTap;
+ case Pinetime::Drivers::Cst816S::Gestures::SlideRight:
+ return TouchEvents::SwipeRight;
+ case Pinetime::Drivers::Cst816S::Gestures::SlideLeft:
+ return TouchEvents::SwipeLeft;
+ case Pinetime::Drivers::Cst816S::Gestures::SlideDown:
+ return TouchEvents::SwipeDown;
+ case Pinetime::Drivers::Cst816S::Gestures::SlideUp:
+ return TouchEvents::SwipeUp;
+ case Pinetime::Drivers::Cst816S::Gestures::None:
+ default:
+ return TouchEvents::None;
+ }
+ }
+ return TouchEvents::None;
+}
+
+void DisplayApp::StartApp(Apps app) {
+ nextApp = app;
+}
+
+void DisplayApp::SetFullRefresh(DisplayApp::FullRefreshDirections direction) {
+ switch(direction){
+ case DisplayApp::FullRefreshDirections::Down:
+ lvgl.SetFullRefresh(Components::LittleVgl::FullRefreshDirections::Down);
+ break;
+ case DisplayApp::FullRefreshDirections::Up:
+ lvgl.SetFullRefresh(Components::LittleVgl::FullRefreshDirections::Up);
+ break;
+ default: break;
+ }
+
+}
+
+void DisplayApp::SetTouchMode(DisplayApp::TouchModes mode) {
+ touchMode = mode;
+}