Add slightly better scrolling + title counter.

This commit is contained in:
Pablo Curiel 2020-08-03 17:41:00 -04:00
parent 3105540c99
commit e26637125b
3 changed files with 44 additions and 41 deletions

View file

@ -241,8 +241,8 @@ int main(int argc, char *argv[])
TitleApplicationMetadata **app_metadata = NULL; TitleApplicationMetadata **app_metadata = NULL;
TitleInfo *cur_title_info = NULL; TitleInfo *cur_title_info = NULL;
u32 selected_idx = 0, menu = 0, page_size = 30, cur_page = 0; u32 selected_idx = 0, menu = 0, page_size = 30, scroll = 0;
u32 title_idx = 0, nca_idx = 0; u32 title_idx = 0, title_scroll = 0, nca_idx = 0;
char nca_id_str[0x21] = {0}; char nca_id_str[0x21] = {0};
NcaContext *nca_ctx = NULL; NcaContext *nca_ctx = NULL;
@ -284,14 +284,14 @@ int main(int argc, char *argv[])
printf("select a %s.", menu == 0 ? "system title to view its contents" : (menu == 1 ? "content" : "fs section")); printf("select a %s.", menu == 0 ? "system title to view its contents" : (menu == 1 ? "content" : "fs section"));
printf("\npress b to %s.\n\n", menu == 0 ? "exit" : "go back"); printf("\npress b to %s.\n\n", menu == 0 ? "exit" : "go back");
if (menu >= 1) printf("selected title: %016lX - %s\n", app_metadata[title_idx]->title_id, app_metadata[title_idx]->lang_entry.name); if (menu == 0) printf("title: %u / %u\n\n", selected_idx + 1, app_count);
if (menu == 2) printf("selected content: %s\n", nca_id_str); if (menu >= 1) printf("selected title: %016lX - %s\n\n", app_metadata[title_idx]->title_id, app_metadata[title_idx]->lang_entry.name);
if (menu >= 1) printf("\n"); if (menu == 2) printf("selected content: %s (%s)\n\n", nca_id_str, titleGetNcmContentTypeName(cur_title_info->content_infos[nca_idx].content_type));
u32 max_val = (menu == 0 ? app_count : (menu == 1 ? cur_title_info->content_count : NCA_FS_HEADER_COUNT)); u32 max_val = (menu == 0 ? app_count : (menu == 1 ? cur_title_info->content_count : NCA_FS_HEADER_COUNT));
for(u32 i = cur_page; i < max_val; i++) for(u32 i = scroll; i < max_val; i++)
{ {
if (i >= (cur_page + page_size)) break; if (i >= (scroll + page_size)) break;
printf("%s", i == selected_idx ? " -> " : " "); printf("%s", i == selected_idx ? " -> " : " ");
@ -329,6 +329,7 @@ int main(int argc, char *argv[])
if (menu == 0) if (menu == 0)
{ {
title_idx = selected_idx; title_idx = selected_idx;
title_scroll = scroll;
} else } else
if (menu == 1) if (menu == 1)
{ {
@ -368,7 +369,7 @@ int main(int argc, char *argv[])
utilsSleep(3); utilsSleep(3);
menu--; menu--;
} else { } else {
selected_idx = cur_page = 0; selected_idx = scroll = 0;
} }
} else } else
if ((btn_down & KEY_DDOWN) || (btn_held & (KEY_LSTICK_DOWN | KEY_RSTICK_DOWN))) if ((btn_down & KEY_DDOWN) || (btn_held & (KEY_LSTICK_DOWN | KEY_RSTICK_DOWN)))
@ -379,14 +380,14 @@ int main(int argc, char *argv[])
{ {
if (btn_down & KEY_DDOWN) if (btn_down & KEY_DDOWN)
{ {
selected_idx = cur_page = 0; selected_idx = scroll = 0;
} else { } else {
selected_idx = (max_val - 1); selected_idx = (max_val - 1);
} }
} else } else
if (selected_idx >= (cur_page + page_size)) if (selected_idx >= (scroll + (page_size / 2)) && max_val > (scroll + page_size))
{ {
cur_page += page_size; scroll++;
} }
} else } else
if ((btn_down & KEY_DUP) || (btn_held & (KEY_LSTICK_UP | KEY_RSTICK_UP))) if ((btn_down & KEY_DUP) || (btn_held & (KEY_LSTICK_UP | KEY_RSTICK_UP)))
@ -398,14 +399,14 @@ int main(int argc, char *argv[])
if (btn_down & KEY_DUP) if (btn_down & KEY_DUP)
{ {
selected_idx = (max_val - 1); selected_idx = (max_val - 1);
cur_page = (max_val - (max_val % page_size)); scroll = (max_val >= page_size ? (max_val - page_size) : 0);
} else { } else {
selected_idx = 0; selected_idx = 0;
} }
} else } else
if (selected_idx < cur_page) if (selected_idx < (scroll + (page_size / 2)) && scroll > 0)
{ {
cur_page -= page_size; scroll--;
} }
} else } else
if (btn_down & KEY_B) if (btn_down & KEY_B)
@ -417,7 +418,7 @@ int main(int argc, char *argv[])
break; break;
} else { } else {
selected_idx = (menu == 0 ? title_idx : nca_idx); selected_idx = (menu == 0 ? title_idx : nca_idx);
cur_page = (selected_idx - (selected_idx % page_size)); scroll = (menu == 0 ? title_scroll : 0);
} }
} }

View file

@ -217,7 +217,7 @@ int main(int argc, char *argv[])
TitleApplicationMetadata **app_metadata = NULL; TitleApplicationMetadata **app_metadata = NULL;
TitleUserApplicationData user_app_data = {0}; TitleUserApplicationData user_app_data = {0};
u32 selected_idx = 0, page_size = 30, cur_page = 0; u32 selected_idx = 0, page_size = 30, scroll = 0;
bool exit_prompt = true; bool exit_prompt = true;
u8 *buf = NULL; u8 *buf = NULL;
@ -272,11 +272,12 @@ int main(int argc, char *argv[])
{ {
consoleClear(); consoleClear();
printf("select a base title with an available update.\nthe updated romfs will be dumped via usb.\npress b to exit.\n\n"); printf("select a base title with an available update.\nthe updated romfs will be dumped via usb.\npress b to exit.\n\n");
printf("title: %u / %u\n\n", selected_idx + 1, app_count);
for(u32 i = cur_page; i < app_count; i++) for(u32 i = scroll; i < app_count; i++)
{ {
if (i >= (cur_page + page_size)) break; if (i >= (scroll + page_size)) break;
printf("%s%s (%016lX)\n", i == selected_idx ? " -> " : " ", app_metadata[i]->lang_entry.name, app_metadata[i]->title_id); printf("%s%016lX - %s\n", i == selected_idx ? " -> " : " ", app_metadata[i]->title_id, app_metadata[i]->lang_entry.name);
} }
printf("\n"); printf("\n");
@ -302,7 +303,7 @@ int main(int argc, char *argv[])
goto out2; goto out2;
} }
selected_idx = cur_page = 0; selected_idx = scroll = 0;
break; break;
} }
} }
@ -326,14 +327,14 @@ int main(int argc, char *argv[])
{ {
if (btn_down & KEY_DDOWN) if (btn_down & KEY_DDOWN)
{ {
selected_idx = cur_page = 0; selected_idx = scroll = 0;
} else { } else {
selected_idx = (app_count - 1); selected_idx = (app_count - 1);
} }
} else } else
if (selected_idx >= (cur_page + page_size)) if (selected_idx >= (scroll + (page_size / 2)) && app_count > (scroll + page_size))
{ {
cur_page += page_size; scroll++;
} }
} else } else
if ((btn_down & KEY_DUP) || (btn_held & (KEY_LSTICK_UP | KEY_RSTICK_UP))) if ((btn_down & KEY_DUP) || (btn_held & (KEY_LSTICK_UP | KEY_RSTICK_UP)))
@ -345,14 +346,14 @@ int main(int argc, char *argv[])
if (btn_down & KEY_DUP) if (btn_down & KEY_DUP)
{ {
selected_idx = (app_count - 1); selected_idx = (app_count - 1);
cur_page = (app_count - (app_count % page_size)); scroll = (app_count >= page_size ? (app_count - page_size) : 0);
} else { } else {
selected_idx = 0; selected_idx = 0;
} }
} else } else
if (selected_idx < cur_page) if (selected_idx < (scroll + (page_size / 2)) && scroll > 0)
{ {
cur_page -= page_size; scroll--;
} }
} else } else
if (btn_down & KEY_B) if (btn_down & KEY_B)

View file

@ -241,8 +241,8 @@ int main(int argc, char *argv[])
TitleApplicationMetadata **app_metadata = NULL; TitleApplicationMetadata **app_metadata = NULL;
TitleInfo *cur_title_info = NULL; TitleInfo *cur_title_info = NULL;
u32 selected_idx = 0, menu = 0, page_size = 30, cur_page = 0; u32 selected_idx = 0, menu = 0, page_size = 30, scroll = 0;
u32 title_idx = 0, nca_idx = 0; u32 title_idx = 0, title_scroll = 0, nca_idx = 0;
char nca_id_str[0x21] = {0}; char nca_id_str[0x21] = {0};
NcaContext *nca_ctx = NULL; NcaContext *nca_ctx = NULL;
@ -284,14 +284,14 @@ int main(int argc, char *argv[])
printf("select a %s.", menu == 0 ? "system title to view its contents" : (menu == 1 ? "content" : "fs section")); printf("select a %s.", menu == 0 ? "system title to view its contents" : (menu == 1 ? "content" : "fs section"));
printf("\npress b to %s.\n\n", menu == 0 ? "exit" : "go back"); printf("\npress b to %s.\n\n", menu == 0 ? "exit" : "go back");
if (menu >= 1) printf("selected title: %016lX - %s\n", app_metadata[title_idx]->title_id, app_metadata[title_idx]->lang_entry.name); if (menu == 0) printf("title: %u / %u\n\n", selected_idx + 1, app_count);
if (menu == 2) printf("selected content: %s\n", nca_id_str); if (menu >= 1) printf("selected title: %016lX - %s\n\n", app_metadata[title_idx]->title_id, app_metadata[title_idx]->lang_entry.name);
if (menu >= 1) printf("\n"); if (menu == 2) printf("selected content: %s (%s)\n\n", nca_id_str, titleGetNcmContentTypeName(cur_title_info->content_infos[nca_idx].content_type));
u32 max_val = (menu == 0 ? app_count : (menu == 1 ? cur_title_info->content_count : NCA_FS_HEADER_COUNT)); u32 max_val = (menu == 0 ? app_count : (menu == 1 ? cur_title_info->content_count : NCA_FS_HEADER_COUNT));
for(u32 i = cur_page; i < max_val; i++) for(u32 i = scroll; i < max_val; i++)
{ {
if (i >= (cur_page + page_size)) break; if (i >= (scroll + page_size)) break;
printf("%s", i == selected_idx ? " -> " : " "); printf("%s", i == selected_idx ? " -> " : " ");
@ -329,6 +329,7 @@ int main(int argc, char *argv[])
if (menu == 0) if (menu == 0)
{ {
title_idx = selected_idx; title_idx = selected_idx;
title_scroll = scroll;
} else } else
if (menu == 1) if (menu == 1)
{ {
@ -368,7 +369,7 @@ int main(int argc, char *argv[])
utilsSleep(3); utilsSleep(3);
menu--; menu--;
} else { } else {
selected_idx = cur_page = 0; selected_idx = scroll = 0;
} }
} else } else
if ((btn_down & KEY_DDOWN) || (btn_held & (KEY_LSTICK_DOWN | KEY_RSTICK_DOWN))) if ((btn_down & KEY_DDOWN) || (btn_held & (KEY_LSTICK_DOWN | KEY_RSTICK_DOWN)))
@ -379,14 +380,14 @@ int main(int argc, char *argv[])
{ {
if (btn_down & KEY_DDOWN) if (btn_down & KEY_DDOWN)
{ {
selected_idx = cur_page = 0; selected_idx = scroll = 0;
} else { } else {
selected_idx = (max_val - 1); selected_idx = (max_val - 1);
} }
} else } else
if (selected_idx >= (cur_page + page_size)) if (selected_idx >= (scroll + (page_size / 2)) && max_val > (scroll + page_size))
{ {
cur_page += page_size; scroll++;
} }
} else } else
if ((btn_down & KEY_DUP) || (btn_held & (KEY_LSTICK_UP | KEY_RSTICK_UP))) if ((btn_down & KEY_DUP) || (btn_held & (KEY_LSTICK_UP | KEY_RSTICK_UP)))
@ -398,14 +399,14 @@ int main(int argc, char *argv[])
if (btn_down & KEY_DUP) if (btn_down & KEY_DUP)
{ {
selected_idx = (max_val - 1); selected_idx = (max_val - 1);
cur_page = (max_val - (max_val % page_size)); scroll = (max_val >= page_size ? (max_val - page_size) : 0);
} else { } else {
selected_idx = 0; selected_idx = 0;
} }
} else } else
if (selected_idx < cur_page) if (selected_idx < (scroll + (page_size / 2)) && scroll > 0)
{ {
cur_page -= page_size; scroll--;
} }
} else } else
if (btn_down & KEY_B) if (btn_down & KEY_B)
@ -417,7 +418,7 @@ int main(int argc, char *argv[])
break; break;
} else { } else {
selected_idx = (menu == 0 ? title_idx : nca_idx); selected_idx = (menu == 0 ? title_idx : nca_idx);
cur_page = (selected_idx - (selected_idx % page_size)); scroll = (menu == 0 ? title_scroll : 0);
} }
} }