1
0
Fork 0
mirror of https://github.com/suchmememanyskill/TegraExplorer.git synced 2024-11-30 07:42:06 +00:00
TegraExplorer/source/tegraexplorer/gfx.c

252 lines
6.4 KiB
C
Raw Normal View History

#include <string.h>
#include <stdlib.h>
#include <stdio.h>
#include "../gfx/gfx.h"
#include "te.h"
#include "../utils/btn.h"
2019-12-01 00:49:36 +00:00
#include "../utils/util.h"
#include "gfx.h"
2019-12-01 00:49:36 +00:00
#include "fs.h"
#include "../mem/minerva.h"
2020-03-03 14:19:42 +00:00
#include "../power/max17050.h"
#include <stdarg.h>
2019-12-01 00:49:36 +00:00
const char fixedoptions[3][50] = {
2019-12-01 19:31:17 +00:00
"Folder -> previous folder ",
"Clipboard -> Current folder ",
"Current folder menu "
2019-12-01 00:49:36 +00:00
};
const char sizevalues[4][3] = {
2019-12-03 09:06:11 +00:00
"B ",
2019-12-01 00:49:36 +00:00
"KB",
"MB",
"GB"
};
void clearscreen(){
2020-03-03 14:19:42 +00:00
int battery = 0;
max17050_get_property(MAX17050_RepSOC, &battery);
gfx_clear_grey(0x1B);
2020-03-03 14:19:42 +00:00
SWAPCOLOR(COLOR_DEFAULT);
SWAPBGCOLOR(COLOR_WHITE);
gfx_box(0, 1263, 719, 1279, COLOR_WHITE);
gfx_con_setpos(0, 1263);
gfx_printf("Move: Vol+/- | Select: Pow | Battery: %3d%%", battery >> 8);
gfx_box(0, 0, 719, 15, COLOR_WHITE);
gfx_con_setpos(0, 0);
2020-03-06 11:26:54 +00:00
gfx_printf("Tegraexplorer v1.3.2\n");
2020-03-03 14:19:42 +00:00
RESETCOLOR;
}
int message(u32 color, const char* message, ...){
va_list ap;
va_start(ap, message);
clearscreen();
SWAPCOLOR(color);
gfx_vprintf(message, ap);
va_end(ap);
return btn_wait();
}
int makemenu(menu_item menu[], int menuamount){
int currentpos = 1, i, res;
clearscreen();
while (1){
gfx_con_setpos(0, 31);
if (currentpos == 1){
while (currentpos < menuamount && menu[currentpos - 1].property < 1)
currentpos++;
}
if (currentpos == menuamount){
while (currentpos > 1 && menu[currentpos - 1].property < 1)
currentpos--;
}
for (i = 0; i < menuamount; i++){
if (menu[i].property < 0)
continue;
if (i == currentpos - 1)
gfx_printf("%k%K%s%K\n", COLOR_DEFAULT, COLOR_WHITE, menu[i].name, COLOR_DEFAULT);
else
gfx_printf("%k%s\n", menu[i].color, menu[i].name);
}
gfx_printf("\n%k%s", COLOR_WHITE, menuamount);
res = btn_wait();
if (res & BTN_VOL_UP && currentpos > 1){
currentpos--;
while(menu[currentpos - 1].property < 1 && currentpos > 1)
currentpos--;
}
else if (res & BTN_VOL_DOWN && currentpos < menuamount){
currentpos++;
while(menu[currentpos - 1].property < 1 && currentpos < menuamount)
currentpos++;
}
else if (res & BTN_POWER)
return menu[currentpos - 1].internal_function;
}
2019-12-01 00:49:36 +00:00
}
2019-12-07 20:49:58 +00:00
void printbytes(u8 print[], u32 size, u32 offset){
gfx_con_setpos(0, 31);
gfx_hexdump(offset, print, size * sizeof(u8));
}
2019-12-11 12:18:57 +00:00
int makewaitmenu(char *initialmessage, char *hiddenmessage, int timer){
clearscreen();
int res;
u32 start = get_tmr_s();
gfx_printf(initialmessage);
while(1){
res = btn_read();
if (res & BTN_VOL_DOWN || res & BTN_VOL_UP)
return 0;
if (start + timer > get_tmr_s())
gfx_printf("\r<Wait %d seconds> ", timer + start - get_tmr_s());
2019-12-11 12:18:57 +00:00
else if (res & BTN_POWER)
return 1;
else
gfx_printf("\r%k%s%k", COLOR_RED, hiddenmessage, COLOR_WHITE);
}
}
void gfx_print_length(int size, char *toprint){
char *temp;
temp = (char*) malloc (size + 1);
if (strlen(toprint) > size){
strlcpy(temp, toprint, size);
memset(temp + size - 3, '.', 3);
memset(temp + size, '\0', 1);
}
else
strcpy(temp, toprint);
gfx_printf("%s", temp);
free(temp);
}
2019-12-01 19:31:17 +00:00
void printfsentry(fs_entry file, bool highlight, bool refresh){
2019-12-01 00:49:36 +00:00
int size = 0;
char *display;
2019-12-01 19:31:17 +00:00
int length;
display = (char*) malloc (38);
memset(display + 37, '\0', 1);
if (strlen(file.name) > 37){
strlcpy(display, file.name, 37);
memset(display + 34, '.', 3);
}
2019-12-01 19:31:17 +00:00
else
strcpy(display, file.name);
2019-12-01 00:49:36 +00:00
if (highlight)
gfx_printf("%K%k", COLOR_WHITE, COLOR_DEFAULT);
else
2019-12-18 15:02:45 +00:00
RESETCOLOR;
2019-12-01 00:49:36 +00:00
if (file.property & ISDIR)
2019-12-18 15:02:45 +00:00
gfx_printf("%s", display);
2019-12-01 00:49:36 +00:00
else {
for (size = 4; size < 8; size++)
if ((file.property & (1 << size)))
break;
2019-12-18 15:02:45 +00:00
SWAPCOLOR(COLOR_VIOLET);
gfx_printf("%s", display);
2019-12-01 19:31:17 +00:00
}
2019-12-18 15:02:45 +00:00
RESETCOLOR;
2019-12-01 19:31:17 +00:00
if (refresh){
length = strlen(display);
for (int i = 0; i < (42 - length); i++)
gfx_printf(" ");
2019-12-01 00:49:36 +00:00
}
2019-12-01 19:31:17 +00:00
2019-12-18 15:02:45 +00:00
if (file.property & ISDIR)
gfx_printf("\n");
else {
SWAPCOLOR(COLOR_BLUE);
2019-12-01 19:31:17 +00:00
gfx_printf("\a%d\e%s", file.size, sizevalues[size - 4]);
2019-12-18 15:02:45 +00:00
}
2019-12-01 19:31:17 +00:00
free(display);
2019-12-01 00:49:36 +00:00
}
int makefilemenu(fs_entry *files, int amount, char *path){
2019-12-01 19:31:17 +00:00
int currentpos = -2, i, res = 0, offset = 0, quickoffset = 300;
u32 timer;
2019-12-01 19:31:17 +00:00
bool refresh = false;
2019-12-01 00:49:36 +00:00
clearscreen();
gfx_con_setpos(544, 0);
gfx_printf("%K%k%d files\n%K%k%s%k\n\n", COLOR_WHITE, COLOR_DEFAULT, amount, COLOR_DEFAULT, COLOR_GREEN, path, COLOR_DEFAULT);
2019-12-01 00:49:36 +00:00
while (1){
gfx_con_setpos(0, 47);
timer = get_tmr_ms();
2019-12-01 19:31:17 +00:00
for (i = -3 + offset; i < amount && i < 60 + offset; i++){
2019-12-01 00:49:36 +00:00
if (i < 0){
if (i == currentpos - 1)
gfx_printf("%k%K%s%K\n", COLOR_ORANGE, COLOR_WHITE, fixedoptions[i + 3], COLOR_DEFAULT);
else
gfx_printf("%k%K%s\n", COLOR_ORANGE, COLOR_DEFAULT, fixedoptions[i + 3]);
2019-12-01 00:49:36 +00:00
}
else
2019-12-01 19:31:17 +00:00
printfsentry(files[i], (i == currentpos - 1), refresh);
2019-12-01 00:49:36 +00:00
}
2019-12-01 19:31:17 +00:00
refresh = false;
gfx_printf("\n%k%K %s %s\n\nTime taken for screen draw: %dms ", COLOR_BLUE, COLOR_DEFAULT, (offset + 60 < amount) ? "v" : " ", (offset > 0) ? "^" : " ", get_tmr_ms() - timer);
2019-12-01 00:49:36 +00:00
if (quickoffset == 300)
res = btn_wait();
else {
msleep(quickoffset);
res = btn_read();
}
if (res == 0)
quickoffset = 300;
else if (quickoffset > 46)
quickoffset -= 45;
2019-12-01 00:49:36 +00:00
if ((res & BTN_VOL_UP) && currentpos > -2){
2019-12-01 00:49:36 +00:00
currentpos--;
if (offset != 0 && currentpos < offset - 2){
offset--;
2019-12-01 19:31:17 +00:00
refresh = true;
}
}
if ((res & BTN_VOL_DOWN) && currentpos < amount){
2019-12-01 00:49:36 +00:00
currentpos++;
2019-12-01 19:31:17 +00:00
if (currentpos - offset > 60){
offset++;
2019-12-01 19:31:17 +00:00
refresh = true;
}
}
2019-12-01 00:49:36 +00:00
if (res & BTN_POWER)
return currentpos;
}
minerva_periodic_training();
}