mirror of
https://github.com/betaflight/betaflight.git
synced 2025-07-18 13:55:18 +03:00
Merge branch 'bfdev-osd-cms-separation-poc' of https://github.com/jflyper/cleanflight into bfdev-osd-cms-separation-poc
This commit is contained in:
commit
f66a08d457
10 changed files with 176 additions and 170 deletions
1
Makefile
1
Makefile
|
@ -562,6 +562,7 @@ HIGHEND_SRC = \
|
||||||
flight/gps_conversion.c \
|
flight/gps_conversion.c \
|
||||||
io/gps.c \
|
io/gps.c \
|
||||||
io/ledstrip.c \
|
io/ledstrip.c \
|
||||||
|
io/displayport_oled.c \
|
||||||
io/dashboard.c \
|
io/dashboard.c \
|
||||||
sensors/sonar.c \
|
sensors/sonar.c \
|
||||||
sensors/barometer.c \
|
sensors/barometer.c \
|
||||||
|
|
|
@ -29,6 +29,7 @@ void displayClear(displayPort_t *instance)
|
||||||
instance->vTable->clear(instance);
|
instance->vTable->clear(instance);
|
||||||
instance->cleared = true;
|
instance->cleared = true;
|
||||||
instance->cursorRow = -1;
|
instance->cursorRow = -1;
|
||||||
|
instance->inCMS = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void displayOpen(displayPort_t *instance)
|
void displayOpen(displayPort_t *instance)
|
||||||
|
|
|
@ -26,6 +26,7 @@ typedef struct displayPort_s {
|
||||||
// CMS state
|
// CMS state
|
||||||
bool cleared;
|
bool cleared;
|
||||||
int8_t cursorRow;
|
int8_t cursorRow;
|
||||||
|
bool inCMS;
|
||||||
} displayPort_t;
|
} displayPort_t;
|
||||||
|
|
||||||
typedef struct displayPortVTable_s {
|
typedef struct displayPortVTable_s {
|
||||||
|
|
|
@ -77,9 +77,11 @@
|
||||||
#include "io/cms_ledstrip.h"
|
#include "io/cms_ledstrip.h"
|
||||||
|
|
||||||
// Forwards
|
// Forwards
|
||||||
long cmsx_InfoInit(void);
|
static long cmsx_InfoInit(void);
|
||||||
|
#if 0
|
||||||
long cmsx_FeatureRead(void);
|
long cmsx_FeatureRead(void);
|
||||||
long cmsx_FeatureWriteback(void);
|
long cmsx_FeatureWriteback(void);
|
||||||
|
#endif
|
||||||
|
|
||||||
// Device management
|
// Device management
|
||||||
|
|
||||||
|
@ -87,10 +89,9 @@ long cmsx_FeatureWriteback(void);
|
||||||
#define CMS_MAX_DEVICE 4
|
#define CMS_MAX_DEVICE 4
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
cmsDeviceInitFuncPtr cmsDeviceInitFunc[CMS_MAX_DEVICE];
|
static cmsDeviceInitFuncPtr cmsDeviceInitFunc[CMS_MAX_DEVICE];
|
||||||
int cmsDeviceCount;
|
static int cmsDeviceCount;
|
||||||
int cmsCurrentDevice = -1;
|
static int cmsCurrentDevice = -1;
|
||||||
int cmsLastDevice = -1;
|
|
||||||
|
|
||||||
bool cmsDeviceRegister(cmsDeviceInitFuncPtr func)
|
bool cmsDeviceRegister(cmsDeviceInitFuncPtr func)
|
||||||
{
|
{
|
||||||
|
@ -102,7 +103,7 @@ bool cmsDeviceRegister(cmsDeviceInitFuncPtr func)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
cmsDeviceInitFuncPtr cmsDeviceSelectCurrent(void)
|
static cmsDeviceInitFuncPtr cmsDeviceSelectCurrent(void)
|
||||||
{
|
{
|
||||||
if (cmsDeviceCount == 0)
|
if (cmsDeviceCount == 0)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -113,7 +114,7 @@ cmsDeviceInitFuncPtr cmsDeviceSelectCurrent(void)
|
||||||
return cmsDeviceInitFunc[cmsCurrentDevice];
|
return cmsDeviceInitFunc[cmsCurrentDevice];
|
||||||
}
|
}
|
||||||
|
|
||||||
cmsDeviceInitFuncPtr cmsDeviceSelectNext(void)
|
static cmsDeviceInitFuncPtr cmsDeviceSelectNext(void)
|
||||||
{
|
{
|
||||||
if (cmsDeviceCount == 0)
|
if (cmsDeviceCount == 0)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -125,7 +126,7 @@ cmsDeviceInitFuncPtr cmsDeviceSelectNext(void)
|
||||||
|
|
||||||
#define CMS_UPDATE_INTERVAL 50 // msec
|
#define CMS_UPDATE_INTERVAL 50 // msec
|
||||||
|
|
||||||
void cmsScreenInit(displayPort_t *pDisp, cmsDeviceInitFuncPtr cmsDeviceInitFunc)
|
static void cmsScreenInit(displayPort_t *pDisp, cmsDeviceInitFuncPtr cmsDeviceInitFunc)
|
||||||
{
|
{
|
||||||
cmsDeviceInitFunc(pDisp);
|
cmsDeviceInitFunc(pDisp);
|
||||||
}
|
}
|
||||||
|
@ -151,38 +152,37 @@ void cmsScreenInit(displayPort_t *pDisp, cmsDeviceInitFuncPtr cmsDeviceInitFunc)
|
||||||
#define RIGHT_MENU_COLUMN(p) ((p)->cols - 8)
|
#define RIGHT_MENU_COLUMN(p) ((p)->cols - 8)
|
||||||
#define MAX_MENU_ITEMS(p) ((p)->rows - 2)
|
#define MAX_MENU_ITEMS(p) ((p)->rows - 2)
|
||||||
|
|
||||||
displayPort_t currentDisplay;
|
static displayPort_t currentDisplay;
|
||||||
|
|
||||||
bool cmsInMenu = false;
|
static bool cmsInMenu = false;
|
||||||
|
|
||||||
CMS_Menu menuMain;
|
static CMS_Menu menuMain;
|
||||||
CMS_Menu *currentMenu; // Points to top entry of the current page
|
static CMS_Menu *currentMenu; // Points to top entry of the current page
|
||||||
|
|
||||||
// XXX Does menu backing support backing into second page???
|
// XXX Does menu backing support backing into second page???
|
||||||
|
|
||||||
CMS_Menu *menuStack[10]; // Stack to save menu transition
|
static CMS_Menu *menuStack[10]; // Stack to save menu transition
|
||||||
uint8_t menuStackHistory[10]; // cursorRow in a stacked menu
|
static uint8_t menuStackHistory[10];// cursorRow in a stacked menu
|
||||||
uint8_t menuStackIdx = 0;
|
static uint8_t menuStackIdx = 0;
|
||||||
|
|
||||||
OSD_Entry *pageTop; // Points to top entry of the current page
|
static OSD_Entry *pageTop; // Points to top entry of the current page
|
||||||
OSD_Entry *pageTopAlt; // Only 2 pages are allowed (for now)
|
static OSD_Entry *pageTopAlt; // Only 2 pages are allowed (for now)
|
||||||
uint8_t maxRow; // Max row in the current page
|
static uint8_t maxRow; // Max row in the current page
|
||||||
|
|
||||||
int8_t entryPos; // Absolute position of the cursor
|
static int8_t cursorRow;
|
||||||
int8_t cursorRow; // Position of the cursor relative to pageTop
|
|
||||||
|
|
||||||
// Broken menu substitution
|
// Broken menu substitution
|
||||||
|
|
||||||
char menuErrLabel[21 + 1];
|
static char menuErrLabel[21 + 1];
|
||||||
|
|
||||||
OSD_Entry menuErrEntries[] = {
|
static OSD_Entry menuErrEntries[] = {
|
||||||
{ "BROKEN MENU", OME_Label, NULL, NULL, 0 },
|
{ "BROKEN MENU", OME_Label, NULL, NULL, 0 },
|
||||||
{ menuErrLabel, OME_String, NULL, NULL, 0 },
|
{ menuErrLabel, OME_String, NULL, NULL, 0 },
|
||||||
{ "BACK", OME_Back, NULL, NULL, 0 },
|
{ "BACK", OME_Back, NULL, NULL, 0 },
|
||||||
{ NULL, OME_END, NULL, NULL, 0 }
|
{ NULL, OME_END, NULL, NULL, 0 }
|
||||||
};
|
};
|
||||||
|
|
||||||
CMS_Menu menuErr = {
|
static CMS_Menu menuErr = {
|
||||||
"MENU CONTENT BROKEN",
|
"MENU CONTENT BROKEN",
|
||||||
OME_MENU,
|
OME_MENU,
|
||||||
NULL,
|
NULL,
|
||||||
|
@ -208,7 +208,7 @@ CMS_Menu menuErr = {
|
||||||
#define BUTTON_TIME 250 // msec
|
#define BUTTON_TIME 250 // msec
|
||||||
#define BUTTON_PAUSE 500 // msec
|
#define BUTTON_PAUSE 500 // msec
|
||||||
|
|
||||||
void cmsUpdateMaxRow(displayPort_t *instance)
|
static void cmsUpdateMaxRow(displayPort_t *instance)
|
||||||
{
|
{
|
||||||
OSD_Entry *ptr;
|
OSD_Entry *ptr;
|
||||||
|
|
||||||
|
@ -249,7 +249,7 @@ static void cmsFormatFloat(int32_t value, char *floatString)
|
||||||
floatString[0] = ' ';
|
floatString[0] = ' ';
|
||||||
}
|
}
|
||||||
|
|
||||||
void cmsPadToSize(char *buf, int size)
|
static void cmsPadToSize(char *buf, int size)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
@ -265,7 +265,7 @@ void cmsPadToSize(char *buf, int size)
|
||||||
buf[size] = 0;
|
buf[size] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int cmsDrawMenuEntry(displayPort_t *pDisplay, OSD_Entry *p, uint8_t row, bool drawPolled)
|
static int cmsDrawMenuEntry(displayPort_t *pDisplay, OSD_Entry *p, uint8_t row, bool drawPolled)
|
||||||
{
|
{
|
||||||
char buff[10];
|
char buff[10];
|
||||||
int cnt = 0;
|
int cnt = 0;
|
||||||
|
@ -389,7 +389,7 @@ int cmsDrawMenuEntry(displayPort_t *pDisplay, OSD_Entry *p, uint8_t row, bool dr
|
||||||
return cnt;
|
return cnt;
|
||||||
}
|
}
|
||||||
|
|
||||||
void cmsDrawMenu(displayPort_t *pDisplay)
|
static void cmsDrawMenu(displayPort_t *pDisplay)
|
||||||
{
|
{
|
||||||
uint8_t i;
|
uint8_t i;
|
||||||
OSD_Entry *p;
|
OSD_Entry *p;
|
||||||
|
@ -507,7 +507,7 @@ long cmsMenuChange(displayPort_t *pDisplay, void *ptr)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
long cmsMenuBack(displayPort_t *pDisplay)
|
static long cmsMenuBack(displayPort_t *pDisplay)
|
||||||
{
|
{
|
||||||
if (currentMenu->onExit)
|
if (currentMenu->onExit)
|
||||||
currentMenu->onExit();
|
currentMenu->onExit();
|
||||||
|
@ -530,7 +530,7 @@ long cmsMenuBack(displayPort_t *pDisplay)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void cmsMenuOpen(void)
|
static void cmsMenuOpen(void)
|
||||||
{
|
{
|
||||||
cmsDeviceInitFuncPtr initfunc;
|
cmsDeviceInitFuncPtr initfunc;
|
||||||
|
|
||||||
|
@ -554,7 +554,7 @@ void cmsMenuOpen(void)
|
||||||
cmsMenuChange(¤tDisplay, currentMenu);
|
cmsMenuChange(¤tDisplay, currentMenu);
|
||||||
}
|
}
|
||||||
|
|
||||||
void cmsTraverseGlobalExit(CMS_Menu *pMenu)
|
static void cmsTraverseGlobalExit(CMS_Menu *pMenu)
|
||||||
{
|
{
|
||||||
OSD_Entry *p;
|
OSD_Entry *p;
|
||||||
|
|
||||||
|
@ -566,7 +566,7 @@ void cmsTraverseGlobalExit(CMS_Menu *pMenu)
|
||||||
pMenu->onGlobalExit();
|
pMenu->onGlobalExit();
|
||||||
}
|
}
|
||||||
|
|
||||||
long cmsMenuExit(displayPort_t *pDisplay, void *ptr)
|
static long cmsMenuExit(displayPort_t *pDisplay, void *ptr)
|
||||||
{
|
{
|
||||||
if (ptr) {
|
if (ptr) {
|
||||||
displayClear(pDisplay);
|
displayClear(pDisplay);
|
||||||
|
@ -597,7 +597,7 @@ long cmsMenuExit(displayPort_t *pDisplay, void *ptr)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint16_t cmsHandleKey(displayPort_t *pDisplay, uint8_t key)
|
static uint16_t cmsHandleKey(displayPort_t *pDisplay, uint8_t key)
|
||||||
{
|
{
|
||||||
uint16_t res = BUTTON_TIME;
|
uint16_t res = BUTTON_TIME;
|
||||||
OSD_Entry *p;
|
OSD_Entry *p;
|
||||||
|
@ -773,7 +773,7 @@ uint16_t cmsHandleKey(displayPort_t *pDisplay, uint8_t key)
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
void cmsUpdate(displayPort_t *pDisplay, uint32_t currentTime)
|
static void cmsUpdate(displayPort_t *pDisplay, uint32_t currentTime)
|
||||||
{
|
{
|
||||||
static int16_t rcDelay = BUTTON_TIME;
|
static int16_t rcDelay = BUTTON_TIME;
|
||||||
static uint32_t lastCalled = 0;
|
static uint32_t lastCalled = 0;
|
||||||
|
@ -853,7 +853,6 @@ void cmsHandler(uint32_t currentTime)
|
||||||
|
|
||||||
void cmsInit(void)
|
void cmsInit(void)
|
||||||
{
|
{
|
||||||
//cmsx_InfoInit();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
|
@ -867,7 +866,7 @@ static char infoTargetName[] = __TARGET__;
|
||||||
|
|
||||||
#include "msp/msp_protocol.h" // XXX for FC identification... not available elsewhere
|
#include "msp/msp_protocol.h" // XXX for FC identification... not available elsewhere
|
||||||
|
|
||||||
OSD_Entry menuInfoEntries[] = {
|
static OSD_Entry menuInfoEntries[] = {
|
||||||
{ "--- INFO ---", OME_Label, NULL, NULL, 0 },
|
{ "--- INFO ---", OME_Label, NULL, NULL, 0 },
|
||||||
{ "FWID", OME_String, NULL, BETAFLIGHT_IDENTIFIER, 0 },
|
{ "FWID", OME_String, NULL, BETAFLIGHT_IDENTIFIER, 0 },
|
||||||
{ "FWVER", OME_String, NULL, FC_VERSION_STRING, 0 },
|
{ "FWVER", OME_String, NULL, FC_VERSION_STRING, 0 },
|
||||||
|
@ -877,7 +876,7 @@ OSD_Entry menuInfoEntries[] = {
|
||||||
{ NULL, OME_END, NULL, NULL, 0 }
|
{ NULL, OME_END, NULL, NULL, 0 }
|
||||||
};
|
};
|
||||||
|
|
||||||
CMS_Menu menuInfo = {
|
static CMS_Menu menuInfo = {
|
||||||
"MENUINFO",
|
"MENUINFO",
|
||||||
OME_MENU,
|
OME_MENU,
|
||||||
cmsx_InfoInit,
|
cmsx_InfoInit,
|
||||||
|
@ -886,7 +885,7 @@ CMS_Menu menuInfo = {
|
||||||
menuInfoEntries,
|
menuInfoEntries,
|
||||||
};
|
};
|
||||||
|
|
||||||
long cmsx_InfoInit(void)
|
static long cmsx_InfoInit(void)
|
||||||
{
|
{
|
||||||
for (int i = 0 ; i < GIT_SHORT_REVISION_LENGTH ; i++) {
|
for (int i = 0 ; i < GIT_SHORT_REVISION_LENGTH ; i++) {
|
||||||
if (shortGitRevision[i] >= 'a' && shortGitRevision[i] <= 'f')
|
if (shortGitRevision[i] >= 'a' && shortGitRevision[i] <= 'f')
|
||||||
|
@ -900,7 +899,7 @@ long cmsx_InfoInit(void)
|
||||||
|
|
||||||
// Features
|
// Features
|
||||||
|
|
||||||
OSD_Entry menuFeaturesEntries[] =
|
static OSD_Entry menuFeaturesEntries[] =
|
||||||
{
|
{
|
||||||
{"--- FEATURES ---", OME_Label, NULL, NULL, 0},
|
{"--- FEATURES ---", OME_Label, NULL, NULL, 0},
|
||||||
{"BLACKBOX", OME_Submenu, cmsMenuChange, &cmsx_menuBlackbox, 0},
|
{"BLACKBOX", OME_Submenu, cmsMenuChange, &cmsx_menuBlackbox, 0},
|
||||||
|
@ -914,7 +913,7 @@ OSD_Entry menuFeaturesEntries[] =
|
||||||
{NULL, OME_END, NULL, NULL, 0}
|
{NULL, OME_END, NULL, NULL, 0}
|
||||||
};
|
};
|
||||||
|
|
||||||
CMS_Menu menuFeatures = {
|
static CMS_Menu menuFeatures = {
|
||||||
"MENUFEATURES",
|
"MENUFEATURES",
|
||||||
OME_MENU,
|
OME_MENU,
|
||||||
NULL,
|
NULL,
|
||||||
|
@ -925,7 +924,7 @@ CMS_Menu menuFeatures = {
|
||||||
|
|
||||||
// Main
|
// Main
|
||||||
|
|
||||||
OSD_Entry menuMainEntries[] =
|
static OSD_Entry menuMainEntries[] =
|
||||||
{
|
{
|
||||||
{"--- MAIN MENU ---", OME_Label, NULL, NULL, 0},
|
{"--- MAIN MENU ---", OME_Label, NULL, NULL, 0},
|
||||||
{"CFG&IMU", OME_Submenu, cmsMenuChange, &cmsx_menuImu, 0},
|
{"CFG&IMU", OME_Submenu, cmsMenuChange, &cmsx_menuImu, 0},
|
||||||
|
@ -942,7 +941,7 @@ OSD_Entry menuMainEntries[] =
|
||||||
{NULL,OME_END, NULL, NULL, 0}
|
{NULL,OME_END, NULL, NULL, 0}
|
||||||
};
|
};
|
||||||
|
|
||||||
CMS_Menu menuMain = {
|
static CMS_Menu menuMain = {
|
||||||
"MENUMAIN",
|
"MENUMAIN",
|
||||||
OME_MENU,
|
OME_MENU,
|
||||||
NULL,
|
NULL,
|
||||||
|
@ -950,42 +949,4 @@ CMS_Menu menuMain = {
|
||||||
NULL,
|
NULL,
|
||||||
menuMainEntries,
|
menuMainEntries,
|
||||||
};
|
};
|
||||||
|
|
||||||
#if 0
|
|
||||||
long cmsx_FeatureRead(void)
|
|
||||||
{
|
|
||||||
cmsx_Blackbox_FeatureRead();
|
|
||||||
|
|
||||||
#ifdef LED_STRIP
|
|
||||||
cmsx_Ledstrip_FeatureRead();
|
|
||||||
cmsx_Ledstrip_ConfigRead();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(VTX) || defined(USE_RTC6705)
|
|
||||||
cmsx_Vtx_FeatureRead();
|
|
||||||
cmsx_Vtx_ConfigRead();
|
|
||||||
#endif // VTX || USE_RTC6705
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
long cmsx_FeatureWriteback(void)
|
|
||||||
{
|
|
||||||
cmsx_Blackbox_FeatureWriteback();
|
|
||||||
|
|
||||||
#ifdef LED_STRIP
|
|
||||||
cmsx_Ledstrip_FeatureWriteback();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(VTX) || defined(USE_RTC6705)
|
|
||||||
cmsx_Vtx_FeatureWriteback();
|
|
||||||
cmsx_Vtx_ConfigWriteback();
|
|
||||||
#endif // VTX || USE_RTC6705
|
|
||||||
|
|
||||||
saveConfigAndNotify();
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif // CMS
|
#endif // CMS
|
||||||
|
|
|
@ -11,7 +11,7 @@ void cmsInit(void);
|
||||||
void cmsHandler(uint32_t currentTime);
|
void cmsHandler(uint32_t currentTime);
|
||||||
|
|
||||||
long cmsMenuChange(displayPort_t *pPort, void *ptr);
|
long cmsMenuChange(displayPort_t *pPort, void *ptr);
|
||||||
long cmsMenuExit(displayPort_t *pPort, void *ptr);
|
//long cmsMenuExit(displayPort_t *pPort, void *ptr);
|
||||||
|
|
||||||
#define CMS_STARTUP_HELP_TEXT1 "MENU: THR MID"
|
#define CMS_STARTUP_HELP_TEXT1 "MENU: THR MID"
|
||||||
#define CMS_STARTUP_HELP_TEXT2 "+ YAW LEFT"
|
#define CMS_STARTUP_HELP_TEXT2 "+ YAW LEFT"
|
||||||
|
|
|
@ -31,6 +31,7 @@
|
||||||
#include "build/build_config.h"
|
#include "build/build_config.h"
|
||||||
|
|
||||||
#include "drivers/system.h"
|
#include "drivers/system.h"
|
||||||
|
#include "drivers/display.h"
|
||||||
#include "drivers/display_ug2864hsweg01.h"
|
#include "drivers/display_ug2864hsweg01.h"
|
||||||
|
|
||||||
#include "common/printf.h"
|
#include "common/printf.h"
|
||||||
|
@ -53,10 +54,10 @@
|
||||||
#include "flight/failsafe.h"
|
#include "flight/failsafe.h"
|
||||||
|
|
||||||
#include "io/cms.h"
|
#include "io/cms.h"
|
||||||
|
#include "io/displayport_oled.h"
|
||||||
|
|
||||||
#ifdef CMS
|
displayPort_t *displayPort;
|
||||||
void dashboardCmsInit(displayPort_t *pPort); // Forward
|
bool dashboardInCMS = false; // temporary
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef GPS
|
#ifdef GPS
|
||||||
#include "io/gps.h"
|
#include "io/gps.h"
|
||||||
|
@ -585,17 +586,15 @@ void showDebugPage(void)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef OLEDCMS
|
|
||||||
static bool dashboardInCMS = false;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void dashboardUpdate(uint32_t currentTime)
|
void dashboardUpdate(uint32_t currentTime)
|
||||||
{
|
{
|
||||||
static uint8_t previousArmedState = 0;
|
static uint8_t previousArmedState = 0;
|
||||||
|
|
||||||
#ifdef OLEDCMS
|
#ifdef OLEDCMS
|
||||||
if (dashboardInCMS)
|
if (dashboardInCMS) return;
|
||||||
|
if (displayPort && displayPort->inCMS) {
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
const bool updateNow = (int32_t)(currentTime - nextDisplayUpdateAt) >= 0L;
|
const bool updateNow = (int32_t)(currentTime - nextDisplayUpdateAt) >= 0L;
|
||||||
|
@ -703,6 +702,12 @@ void dashboardSetPage(pageId_e pageId)
|
||||||
pageState.pageFlags |= PAGE_STATE_FLAG_FORCE_PAGE_CHANGE;
|
pageState.pageFlags |= PAGE_STATE_FLAG_FORCE_PAGE_CHANGE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void dashboardCmsInit(displayPort_t *displayPortToUse)
|
||||||
|
{
|
||||||
|
displayPort = displayPortToUse;
|
||||||
|
displayPortOledInit(displayPort);
|
||||||
|
}
|
||||||
|
|
||||||
void dashboardInit(rxConfig_t *rxConfigToUse)
|
void dashboardInit(rxConfig_t *rxConfigToUse)
|
||||||
{
|
{
|
||||||
delay(200);
|
delay(200);
|
||||||
|
@ -749,76 +754,4 @@ void dashboardDisablePageCycling(void)
|
||||||
{
|
{
|
||||||
pageState.pageFlags &= ~PAGE_STATE_FLAG_CYCLE_ENABLED;
|
pageState.pageFlags &= ~PAGE_STATE_FLAG_CYCLE_ENABLED;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef OLEDCMS
|
|
||||||
#include "drivers/display.h"
|
|
||||||
|
|
||||||
static int dashboardBegin(displayPort_t *displayPort)
|
|
||||||
{
|
|
||||||
UNUSED(displayPort);
|
|
||||||
dashboardInCMS = true;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int dashboardEnd(displayPort_t *displayPort)
|
|
||||||
{
|
|
||||||
UNUSED(displayPort);
|
|
||||||
dashboardInCMS = false;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int dashboardClear(displayPort_t *displayPort)
|
|
||||||
{
|
|
||||||
UNUSED(displayPort);
|
|
||||||
i2c_OLED_clear_display_quick();
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int dashboardWrite(displayPort_t *displayPort, uint8_t x, uint8_t y, char *s)
|
|
||||||
{
|
|
||||||
UNUSED(displayPort);
|
|
||||||
i2c_OLED_set_xy(x, y);
|
|
||||||
i2c_OLED_send_string(s);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int dashboardHeartbeat(displayPort_t *displayPort)
|
|
||||||
{
|
|
||||||
UNUSED(displayPort);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void dashboardResync(displayPort_t *displayPort)
|
|
||||||
{
|
|
||||||
UNUSED(displayPort);
|
|
||||||
}
|
|
||||||
|
|
||||||
static uint32_t dashboardTxBytesFree(displayPort_t *displayPort)
|
|
||||||
{
|
|
||||||
UNUSED(displayPort);
|
|
||||||
return UINT32_MAX;
|
|
||||||
}
|
|
||||||
|
|
||||||
static const displayPortVTable_t dashboardVTable = {
|
|
||||||
dashboardBegin,
|
|
||||||
dashboardEnd,
|
|
||||||
dashboardClear,
|
|
||||||
dashboardWrite,
|
|
||||||
dashboardHeartbeat,
|
|
||||||
dashboardResync,
|
|
||||||
dashboardTxBytesFree,
|
|
||||||
};
|
|
||||||
|
|
||||||
void dashboardCmsInit(displayPort_t *displayPort)
|
|
||||||
{
|
|
||||||
displayPort->rows = SCREEN_CHARACTER_ROW_COUNT;
|
|
||||||
displayPort->cols = SCREEN_CHARACTER_COLUMN_COUNT;
|
|
||||||
displayPort->vTable = &dashboardVTable;
|
|
||||||
}
|
|
||||||
#endif // OLEDCMS
|
|
||||||
|
|
||||||
#endif // USE_DASHBOARD
|
#endif // USE_DASHBOARD
|
||||||
|
|
|
@ -45,11 +45,3 @@ void dashboardEnablePageCycling(void);
|
||||||
void dashboardDisablePageCycling(void);
|
void dashboardDisablePageCycling(void);
|
||||||
void dashboardResetPageCycling(void);
|
void dashboardResetPageCycling(void);
|
||||||
void dashboardSetNextPageChangeAt(uint32_t futureMicros);
|
void dashboardSetNextPageChangeAt(uint32_t futureMicros);
|
||||||
void displayEnablePageCycling(void);
|
|
||||||
void displayDisablePageCycling(void);
|
|
||||||
void displayResetPageCycling(void);
|
|
||||||
void displaySetNextPageChangeAt(uint32_t futureMicros);
|
|
||||||
|
|
||||||
#ifdef CMS
|
|
||||||
//void dashboardCmsInit(displayPort_t *pPort);
|
|
||||||
#endif
|
|
||||||
|
|
96
src/main/io/displayport_oled.c
Normal file
96
src/main/io/displayport_oled.c
Normal file
|
@ -0,0 +1,96 @@
|
||||||
|
/*
|
||||||
|
* This file is part of Cleanflight.
|
||||||
|
*
|
||||||
|
* Cleanflight is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Cleanflight is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with Cleanflight. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdbool.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
#include "platform.h"
|
||||||
|
|
||||||
|
#ifdef OLEDCMS
|
||||||
|
|
||||||
|
#include "common/utils.h"
|
||||||
|
|
||||||
|
#include "drivers/display.h"
|
||||||
|
#include "drivers/display_ug2864hsweg01.h"
|
||||||
|
|
||||||
|
#include "io/displayport_oled.h"
|
||||||
|
|
||||||
|
extern bool dashboardInCMS; // temporary
|
||||||
|
|
||||||
|
static int oledOpen(displayPort_t *displayPort)
|
||||||
|
{
|
||||||
|
dashboardInCMS = true;
|
||||||
|
displayPort->inCMS = true;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int oledClose(displayPort_t *displayPort)
|
||||||
|
{
|
||||||
|
dashboardInCMS = false;
|
||||||
|
displayPort->inCMS = false;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int oledClear(displayPort_t *displayPort)
|
||||||
|
{
|
||||||
|
UNUSED(displayPort);
|
||||||
|
i2c_OLED_clear_display_quick();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int oledWrite(displayPort_t *displayPort, uint8_t x, uint8_t y, char *s)
|
||||||
|
{
|
||||||
|
UNUSED(displayPort);
|
||||||
|
i2c_OLED_set_xy(x, y);
|
||||||
|
i2c_OLED_send_string(s);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int oledHeartbeat(displayPort_t *displayPort)
|
||||||
|
{
|
||||||
|
UNUSED(displayPort);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void oledResync(displayPort_t *displayPort)
|
||||||
|
{
|
||||||
|
UNUSED(displayPort);
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint32_t oledTxBytesFree(displayPort_t *displayPort)
|
||||||
|
{
|
||||||
|
UNUSED(displayPort);
|
||||||
|
return UINT32_MAX;
|
||||||
|
}
|
||||||
|
|
||||||
|
static const displayPortVTable_t oledVTable = {
|
||||||
|
.open = oledOpen,
|
||||||
|
.close = oledClose,
|
||||||
|
.clear = oledClear,
|
||||||
|
.write = oledWrite,
|
||||||
|
.heartbeat = oledHeartbeat,
|
||||||
|
.resync = oledResync,
|
||||||
|
.txBytesFree = oledTxBytesFree
|
||||||
|
};
|
||||||
|
|
||||||
|
void displayPortOledInit(displayPort_t *displayPort)
|
||||||
|
{
|
||||||
|
displayPort->vTable = &oledVTable;
|
||||||
|
displayPort->rows = SCREEN_CHARACTER_ROW_COUNT;
|
||||||
|
displayPort->cols = SCREEN_CHARACTER_COLUMN_COUNT;
|
||||||
|
}
|
||||||
|
#endif // OLEDCMS
|
21
src/main/io/displayport_oled.h
Normal file
21
src/main/io/displayport_oled.h
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
/*
|
||||||
|
* This file is part of Cleanflight.
|
||||||
|
*
|
||||||
|
* Cleanflight is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Cleanflight is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with Cleanflight. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
struct displayPort_s;
|
||||||
|
void displayPortOledInit(struct displayPort_s *displayPort);
|
|
@ -29,10 +29,10 @@
|
||||||
|
|
||||||
#include "platform.h"
|
#include "platform.h"
|
||||||
|
|
||||||
#include "build/version.h"
|
|
||||||
|
|
||||||
#ifdef OSD
|
#ifdef OSD
|
||||||
|
|
||||||
|
#include "build/version.h"
|
||||||
|
|
||||||
#include "common/utils.h"
|
#include "common/utils.h"
|
||||||
|
|
||||||
#include "drivers/system.h"
|
#include "drivers/system.h"
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue