Merge branch 'master' into secperiments
This commit is contained in:
commit
4aaf35be4c
1 changed files with 140 additions and 0 deletions
140
modules/menutest.c
Normal file
140
modules/menutest.c
Normal file
|
@ -0,0 +1,140 @@
|
||||||
|
#include <sysinit.h>
|
||||||
|
|
||||||
|
#include "basic/basic.h"
|
||||||
|
|
||||||
|
#include "lcd/render.h"
|
||||||
|
#include "lcd/backlight.h"
|
||||||
|
#include "lcd/allfonts.h"
|
||||||
|
|
||||||
|
void ReinvokeISP(void);
|
||||||
|
|
||||||
|
void incBacklight(void);
|
||||||
|
void decBacklight(void);
|
||||||
|
void gotoISP(void);
|
||||||
|
|
||||||
|
void handleMenu(void);
|
||||||
|
|
||||||
|
/**************************************************************************/
|
||||||
|
|
||||||
|
struct MENU_DEF {
|
||||||
|
char *text;
|
||||||
|
void (*callback)(void);
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef const struct MENU_DEF * menuentry;
|
||||||
|
|
||||||
|
const struct MENU_DEF menu_incBL = {"Backlight++", &incBacklight};
|
||||||
|
const struct MENU_DEF menu_decBL = {"Backlight--", &decBacklight};
|
||||||
|
const struct MENU_DEF menu_ISP = {"Invoke ISP", &gotoISP};
|
||||||
|
|
||||||
|
static menuentry menu[] = {
|
||||||
|
&menu_incBL,
|
||||||
|
&menu_decBL,
|
||||||
|
&menu_ISP,
|
||||||
|
};
|
||||||
|
|
||||||
|
void module_menutest(void) {
|
||||||
|
|
||||||
|
backlightInit();
|
||||||
|
|
||||||
|
font_direction = FONT_DIR_LTR; // LeftToRight is the default
|
||||||
|
|
||||||
|
while (1) {
|
||||||
|
lcdDisplay(0);
|
||||||
|
delayms(10);
|
||||||
|
|
||||||
|
lcdFill(0); // clear display buffer
|
||||||
|
|
||||||
|
font = &Font_Orbitron14pt;
|
||||||
|
|
||||||
|
DoString(0, 0, "Menü");
|
||||||
|
|
||||||
|
if (gpioGetValue(RB_BTN4)==0) {
|
||||||
|
while(gpioGetValue(RB_BTN4)==0);
|
||||||
|
handleMenu();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
void handleMenu(void) {
|
||||||
|
uint8_t back = 0;
|
||||||
|
uint8_t menuselection = 0;
|
||||||
|
|
||||||
|
font = &Font_7x8;
|
||||||
|
|
||||||
|
while (!back) {
|
||||||
|
uint8_t line = 0;
|
||||||
|
uint8_t col = 0;
|
||||||
|
|
||||||
|
lcdDisplay(0);
|
||||||
|
delayms(10);
|
||||||
|
|
||||||
|
lcdFill(0); // clear display buffer
|
||||||
|
|
||||||
|
DoString(0, line, "Menu");
|
||||||
|
line += font->u8Height;
|
||||||
|
|
||||||
|
if (gpioGetValue(RB_BTN1)==0) {
|
||||||
|
while(gpioGetValue(RB_BTN1)==0);
|
||||||
|
if (menuselection != 0) menuselection--;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gpioGetValue(RB_BTN0)==0) {
|
||||||
|
while(gpioGetValue(RB_BTN0)==0);
|
||||||
|
if (menuselection != 2)
|
||||||
|
menuselection++;
|
||||||
|
else
|
||||||
|
menuselection = 0; // wrap around
|
||||||
|
}
|
||||||
|
|
||||||
|
for (uint8_t i = 0; i < 3; i++) {
|
||||||
|
DoString(14, line + i*8, menu[i]->text);
|
||||||
|
if (i == menuselection) {
|
||||||
|
DoString(0, line + i*8, "* ");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gpioGetValue(RB_BTN4)==0) {
|
||||||
|
while(gpioGetValue(RB_BTN4)==0);
|
||||||
|
menu[menuselection]->callback();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gpioGetValue(RB_BTN2)==0) {
|
||||||
|
while(gpioGetValue(RB_BTN2)==0);
|
||||||
|
back = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// fallback ISP via BTN3 ;)
|
||||||
|
|
||||||
|
if (gpioGetValue(RB_BTN3)==0) {
|
||||||
|
while(gpioGetValue(RB_BTN3)==0);
|
||||||
|
gotoISP();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
void incBacklight(void) {
|
||||||
|
uint32_t brightness = backlightGetBrightness();
|
||||||
|
if (brightness < 100) {
|
||||||
|
backlightSetBrightness(brightness + 10);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void decBacklight(void) {
|
||||||
|
uint32_t brightness = backlightGetBrightness();
|
||||||
|
if (brightness > 0) {
|
||||||
|
backlightSetBrightness(brightness - 10);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void gotoISP(void) {
|
||||||
|
DoString(0,58,"Enter ISP!");
|
||||||
|
lcdDisplay(0);
|
||||||
|
EnableWatchdog(5000);
|
||||||
|
ReinvokeISP();
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue