1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-11-27 10:35:16 +00:00

added dialog_font_scale and lands_per_page options

This commit is contained in:
Zeno Rogue
2025-11-11 18:46:16 +01:00
parent 2f2bc74cc5
commit bb2c794a40
5 changed files with 59 additions and 23 deletions

View File

@@ -1292,6 +1292,14 @@ EX void initConfig() {
-> set_sets([] { dialog::bound_low(0); dialog::bound_up(8); dialog::get_di().dialogflags |= sm::DARKEN; });
param_b(centered_menus, "centered_menus", false)
-> editable("centered menus in widescreen", 'c');
param_f(dialog::dialog_font_scale, "dialog_font_scale")
-> editable(1, 5, 0.25, "dialog font scale",
"allow larger font in dialogs",
'D');
param_i(lands_per_page, "lands_per_page")
-> editable(10, 60, 5, "lands per page",
"lands per page shown in the World Overview",
'L');
param_b(startanims::enabled, "startanim", true)
-> editable("start animations", 's');
@@ -2619,6 +2627,8 @@ EX void configureInterface() {
add_edit(menu_format);
add_edit(menu_darkening);
add_edit(centered_menus);
add_edit(dialog::dialog_font_scale);
add_edit(lands_per_page);
add_edit(startanims::enabled);
add_edit(use_bool_dialog);

View File

@@ -711,12 +711,14 @@ EX namespace dialog {
EX string keyboard_what;
EX ld dialog_font_scale = 3;
EX void display() {
callhooks(hooks_display_dialog);
if(just_refreshing) return;
int N = items.size();
dfsize = vid.fsize;
dfsize = vid.fsize * dialog_font_scale;
#if ISMOBILE || ISPANDORA
dfsize *= 3;
#endif
@@ -1602,13 +1604,14 @@ EX namespace dialog {
int nlpage = 1;
int wheelshift = 0;
EX int handlePage(int& nl, int& nlm, int perpage) {
EX int handlePage(int& nl, int& nlm, int perpage, int maxpage IS(2)) {
nlm = nl;
int onl = nl;
int ret = 0;
if(nlpage) {
nl = nlm = perpage;
if(nlpage == 2) ret = nlm;
if(nlpage > maxpage) nlpage = maxpage;
if(nlpage > 1) ret = nlm * (nlpage - 1);
int w = wheelshift;
int realw = 0;
while(w<0 && ret) {
@@ -1623,15 +1626,24 @@ EX namespace dialog {
return ret;
}
EX void displayPageButtons(int i, bool pages) {
EX void displayPageButtons(int i, bool pages, int numpages) {
int i0 = vid.yres - vid.fsize;
int xr = vid.xres / 80;
if(pages) if(displayfrZH(xr*8, i0, 1, vid.fsize, IFM("1 - ") + XLAT("page") + " 1", nlpage == 1 ? 0xD8D8C0 : dialogcolor, 8))
if(numpages == 2) if(displayfrZH(xr*8, i0, 1, vid.fsize, IFM("1 - ") + XLAT("page") + " 1", nlpage == 1 ? 0xD8D8C0 : dialogcolor, 8))
getcstat = '1';
if(pages) if(displayfrZH(xr*24, i0, 1, vid.fsize, IFM("2 - ") + XLAT("page") + " 2", nlpage == 1 ? 0xD8D8C0 : dialogcolor, 8))
if(numpages == 2) if(displayfrZH(xr*24, i0, 1, vid.fsize, IFM("2 - ") + XLAT("page") + " 2", nlpage == 1 ? 0xD8D8C0 : dialogcolor, 8))
getcstat = '2';
if(pages) if(displayfrZH(xr*40, i0, 1, vid.fsize, IFM("3 - ") + XLAT("all"), nlpage == 1 ? 0xD8D8C0 : dialogcolor, 8))
if(numpages == 2) if(displayfrZH(xr*40, i0, 1, vid.fsize, IFM("3 - ") + XLAT("all"), nlpage == 0 ? 0xD8D8C0 : dialogcolor, 8))
getcstat = '3';
if(numpages > 2) if(displayfrZH(xr*8, i0, 1, vid.fsize, IFM("1 - ") + XLAT("last page"), nlpage == 1 ? 0xD8D8C0 : dialogcolor, 8))
getcstat = '1';
if(numpages > 2) if(displayfrZH(xr*24, i0, 1, vid.fsize, IFM("2 - ") + XLAT("next page"), nlpage == numpages ? 0xD8D8C0 : dialogcolor, 8))
getcstat = '2';
if(numpages > 2) if(displayfrZH(xr*40, i0, 1, vid.fsize, nlpage ? its(nlpage) + "/" + its(numpages) : IFM("3 - ") + XLAT("all"), nlpage == 0 ? 0xD8D8C0 : dialogcolor, 8))
getcstat = '3';
if(i&1) if(displayfrZH(xr*56, i0, 1, vid.fsize, IFM(keyname(SDLK_ESCAPE) + " - ") + XLAT("go back"), dialogcolor, 8))
getcstat = '0';
if(i&2) if(displayfrZH(xr*72, i0, 1, vid.fsize, IFM("F1 - ") + XLAT("help"), dialogcolor, 8))
@@ -1640,12 +1652,14 @@ EX namespace dialog {
getcstat = '1';
}
EX bool handlePageButtons(int uni) {
if(uni == '1') nlpage = 1, wheelshift = 0;
else if(uni == '2') nlpage = 2, wheelshift = 0;
EX bool handlePageButtons(int sym, int uni, bool dkeys, int numpages) {
if(uni == '1') nlpage = max(nlpage-1, 1), wheelshift = 0;
else if(uni == '2') nlpage++, wheelshift = 0;
else if(uni == '3') nlpage = 0, wheelshift = 0;
else if(uni == PSEUDOKEY_WHEELUP) wheelshift--;
else if(uni == PSEUDOKEY_WHEELDOWN) wheelshift++;
else if(dkeys && DKEY == SDLK_UP && nlpage > 1) nlpage--;
else if(dkeys && DKEY == SDLK_DOWN) nlpage++;
else return false;
return true;
}

View File

@@ -632,7 +632,7 @@ EX namespace inv {
}
}
dialog::displayPageButtons(7, 0);
dialog::displayPageButtons(7, 0, 2);
mouseovers = "";
keyhandler = [] (int sym, int uni) {
if(plain) dialog::handleNavigation(sym, uni);

View File

@@ -21,6 +21,8 @@ int PREC(ld x) {
return int(shiftmul * x);
}
EX int lands_per_page = 24;
EX void showOverview() {
cmode = sm::ZOOMABLE | sm::OVERVIEW;
indenter_finish dif(debug_graph, "show overview");
@@ -76,9 +78,11 @@ EX void showOverview() {
int lstart = 0;
if(nl > 30) {
int numpages = (nl-1) / lands_per_page + 1;
if(numpages > 1) {
pages = true;
lstart += dialog::handlePage(nl, nlm, (nl+1)/2);
lstart += dialog::handlePage(nl, nlm, lands_per_page, numpages);
}
else nlm = nl;
@@ -151,9 +155,9 @@ EX void showOverview() {
}
}
dialog::displayPageButtons(3, pages);
dialog::displayPageButtons(3, pages, numpages);
keyhandler = [] (int sym, int uni) {
keyhandler = [numpages] (int sym, int uni) {
int umod = uni % 1000;
int udiv = uni / 1000;
if(udiv == 1 && umod < landtypes) {
@@ -217,7 +221,7 @@ EX void showOverview() {
"Cheaters can click to move between lands, and use the "
"mousewheel to gain or lose treasures and orbs quickly (Ctrl = precise, Shift = reverse)."
);
else if(dialog::handlePageButtons(uni)) ;
else if(dialog::handlePageButtons(sym, uni, true, numpages)) ;
else if(dialog::editInfix(uni)) dialog::list_skip = 0;
else if(doexiton(sym, uni)) popScreen();
};

View File

@@ -850,9 +850,17 @@ EX namespace tactic {
}
int nl = isize(landlist);
int nlm = nl;
int ofs = dialog::infix != "" ? 0 : dialog::handlePage(nl, nlm, (nl+1)/2);
int ofs = 0;
int numpages = 1;
if(dialog::infix == "") {
numpages = (nl-1) / lands_per_page + 1;
if(numpages > 1)
ofs += dialog::handlePage(nl, nlm, lands_per_page, numpages);
}
int vf = nlm ? min((vid.yres-4*vid.fsize) / (nlm+1), vid.xres/40) : vid.xres/40;
@@ -909,7 +917,7 @@ EX namespace tactic {
}
}
dialog::displayPageButtons(3, dialog::infix == "");
dialog::displayPageButtons(3, dialog::infix == "", numpages);
uploadScore();
if(on) unrecord(specialland);
@@ -926,7 +934,7 @@ EX namespace tactic {
displayScore(scorehere, xr * 50);
}
keyhandler = [land_for] (int sym, int uni) {
keyhandler = [land_for, numpages] (int sym, int uni) {
if(land_for.count(uni)) {
eLand ll = landlist[land_for.at(uni)];
dialog::do_if_confirmed([ll] {
@@ -967,7 +975,7 @@ EX namespace tactic {
"Good luck, and have fun!"
);
else if(dialog::infix == "" && dialog::handlePageButtons(uni)) ;
else if(dialog::infix == "" && dialog::handlePageButtons(sym, uni, true, numpages)) ;
else if(dialog::editInfix(uni)) dialog::list_skip = 0;
else if(doexiton(sym, uni)) popScreen();
};