support repeat. Swap up&down. Also some cleanup
This commit is contained in:
parent
691fa7d09b
commit
e25e591287
1 changed files with 53 additions and 44 deletions
|
@ -1,8 +1,9 @@
|
|||
#include <string.h>
|
||||
|
||||
#include "basic/basic.h"
|
||||
#include "lcd/render.h"
|
||||
#include "lcd/display.h"
|
||||
#include "lcd/allfonts.h"
|
||||
#include "lcd/print.h"
|
||||
|
||||
#define CHARWIDTH 12
|
||||
#define CHARSPACE 0x20
|
||||
|
@ -23,56 +24,65 @@ void inputInit(char p[],char s[], uint8_t l, uint8_t as, uint8_t ae) {
|
|||
s_input.pos = 0;
|
||||
s_input.dcursor = 0;
|
||||
s_input.done = false;
|
||||
s[l-1]=0;
|
||||
for(int i=strlen(s);i<(l-1);i++)
|
||||
s[i]=0;
|
||||
}
|
||||
|
||||
|
||||
void inputMove() {
|
||||
char *cur = s_input.line+s_input.pos+s_input.dcursor;
|
||||
char key = getInput();
|
||||
if (key == BTN_LEFT) {
|
||||
if (s_input.dcursor >0) {
|
||||
s_input.dcursor --;
|
||||
} else if (s_input.pos > 0) {
|
||||
s_input.pos --;
|
||||
}
|
||||
} else if (key == BTN_RIGHT) {
|
||||
if (s_input.dcursor <RESX/CHARWIDTH-1 && s_input.pos + s_input.dcursor < s_input.maxlength) {
|
||||
if (*cur == 0) {
|
||||
*cur = CHARSPACE;
|
||||
}
|
||||
s_input.dcursor ++;
|
||||
} else if (s_input.pos + RESX/CHARWIDTH < s_input.maxlength) {
|
||||
s_input.pos++;
|
||||
if (*cur == 0) {
|
||||
*cur = CHARSPACE;
|
||||
}
|
||||
}
|
||||
} else if (key == BTN_DOWN) {
|
||||
if (*cur <= s_input.asciistart) {
|
||||
*cur = s_input.asciiend;
|
||||
} else if (*cur > s_input.asciiend) {
|
||||
*cur = s_input.asciiend;
|
||||
} else {
|
||||
*cur = *cur - 1;
|
||||
}
|
||||
} else if (key == BTN_UP) {
|
||||
if (*cur >= s_input.asciiend) {
|
||||
*cur = s_input.asciistart;
|
||||
} else if (*cur < s_input.asciistart) {
|
||||
*cur = s_input.asciistart;
|
||||
} else {
|
||||
*cur = *cur + 1;
|
||||
}
|
||||
} else if (key == (BTN_ENTER)) {
|
||||
s_input.done = true;
|
||||
}
|
||||
switch(getInputWaitRepeat()){
|
||||
case BTN_LEFT:
|
||||
if (s_input.dcursor >0) {
|
||||
s_input.dcursor --;
|
||||
} else if (s_input.pos > 0) {
|
||||
s_input.pos --;
|
||||
}
|
||||
break;
|
||||
case BTN_RIGHT:
|
||||
if (s_input.dcursor <RESX/CHARWIDTH-1 && s_input.pos + s_input.dcursor < s_input.maxlength) {
|
||||
if (*cur == 0) {
|
||||
*cur = CHARSPACE;
|
||||
}
|
||||
s_input.dcursor ++;
|
||||
} else if (s_input.pos + RESX/CHARWIDTH < s_input.maxlength) {
|
||||
s_input.pos++;
|
||||
if (*cur == 0) {
|
||||
*cur = CHARSPACE;
|
||||
}
|
||||
}
|
||||
break;
|
||||
case BTN_UP:
|
||||
if (*cur <= s_input.asciistart) {
|
||||
*cur = s_input.asciiend;
|
||||
} else if (*cur > s_input.asciiend) {
|
||||
*cur = s_input.asciiend;
|
||||
} else {
|
||||
*cur = *cur - 1;
|
||||
}
|
||||
break;
|
||||
case BTN_DOWN:
|
||||
if (*cur >= s_input.asciiend) {
|
||||
*cur = s_input.asciistart;
|
||||
} else if (*cur < s_input.asciistart) {
|
||||
*cur = s_input.asciistart;
|
||||
} else {
|
||||
*cur = *cur + 1;
|
||||
}
|
||||
break;
|
||||
case BTN_ENTER:
|
||||
s_input.done = true;
|
||||
// getInputWaitRelease();
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void inputDraw() {
|
||||
lcdFill(0);
|
||||
char tmp[2]= {0,0};
|
||||
lcdClear();
|
||||
DoString(0,0,s_input.prompt);
|
||||
for (int dx = 0; dx<= RESX/CHARWIDTH && s_input.pos+dx<s_input.maxlength; dx++){
|
||||
char tmp[1];
|
||||
tmp[0] = s_input.line[s_input.pos+dx];
|
||||
DoString(dx*CHARWIDTH, 30,tmp);
|
||||
}
|
||||
|
@ -93,13 +103,12 @@ void inputClean() {
|
|||
}
|
||||
|
||||
void input(char prompt[], char line[], uint8_t asciistart, uint8_t asciiend, uint8_t maxlength){
|
||||
font=&Font_7x8;
|
||||
setSystemFont();
|
||||
inputInit(prompt, line, maxlength, asciistart, asciiend);
|
||||
lcdFill(0);
|
||||
while (!s_input.done) {
|
||||
inputDraw();
|
||||
lcdDisplay();
|
||||
inputMove();
|
||||
inputDraw();
|
||||
}
|
||||
inputClean();
|
||||
return;
|
||||
|
|
Loading…
Reference in a new issue