1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-01-12 02:10:34 +00:00

options -pal and -palrgba now accept the pattern name

This commit is contained in:
Zeno Rogue 2018-09-21 21:31:11 +02:00
parent c1de923454
commit 0294c0acb1
3 changed files with 40 additions and 39 deletions

View File

@ -480,14 +480,13 @@ void viewdist_configure_dialog() {
dialog::editNumber(first_distance, 0, 3000, 0, 1, "display distances from", ""); dialog::editNumber(first_distance, 0, 3000, 0, 1, "display distances from", "");
}); });
auto& cp = linepatterns::patterns; for(auto& lp: linepatterns::patterns) {
using namespace linepatterns; using namespace linepatterns;
for(int numpat=0; cp[numpat].lpname; numpat++) { int id = 0;
auto &pn = cp[numpat]; if(among(lp.id, patTriTree, patTriRings, patTriOther)) {
if(among(pn.id, patTriTree, patTriRings, patTriOther)) { dialog::addColorItem(XLAT(lp.lpname), lp.color, '1'+(id++));
dialog::addColorItem(XLAT(pn.lpname), pn.color, '1'+numpat); dialog::add_action([&lp] () {
dialog::add_action([&pn] () { dialog::openColorDialog(lp.color, NULL);
dialog::openColorDialog(pn.color, NULL);
dialog::dialogflags |= sm::MAYDARK | sm::SIDE | sm::EXPANSION; dialog::dialogflags |= sm::MAYDARK | sm::SIDE | sm::EXPANSION;
}); });
} }

View File

@ -2199,7 +2199,7 @@ namespace linepatterns {
color_t color; color_t color;
}; };
extern linepattern patterns[]; extern vector<linepattern> patterns;
}; };
transmatrix ddspin(cell *c, int d, ld bonus = 0); transmatrix ddspin(cell *c, int d, ld bonus = 0);

View File

@ -1952,7 +1952,7 @@ namespace linepatterns {
return col; return col;
} }
linepattern patterns[] = { vector<linepattern> patterns = {
{patDual, "dual grid", 0xFFFFFF00}, {patDual, "dual grid", 0xFFFFFF00},
@ -1978,26 +1978,25 @@ namespace linepatterns {
{patTriTree, "triangle grid: tree edges", 0xFFFFFF00}, {patTriTree, "triangle grid: tree edges", 0xFFFFFF00},
{patTriOther, "triangle grid: other edges", 0xFFFFFF00}, {patTriOther, "triangle grid: other edges", 0xFFFFFF00},
{0, NULL, 0}
}; };
void clearAll() { void clearAll() {
for(int k=0; patterns[k].lpname; k++) patterns[k].color &= ~255; for(auto& lp: patterns) lp.color &= ~255;
} }
bool any() { bool any() {
for(int k=0; patterns[k].lpname; k++) if(patterns[k].color & 255) return true; for(auto& lp: patterns) if(lp.color & 255) return true;
return false; return false;
} }
void setColor(ePattern id, color_t col) { void setColor(ePattern id, color_t col) {
for(int k=0; patterns[k].lpname; k++) for(auto& lp: patterns)
if(patterns[k].id == id) patterns[k].color = col; if(lp.id == id) lp.color = col;
} }
void switchAlpha(ePattern id, color_t col) { void switchAlpha(ePattern id, color_t col) {
for(int k=0; patterns[k].lpname; k++) for(auto& lp: patterns)
if(patterns[k].id == id) patterns[k].color ^= col; if(lp.id == id) lp.color ^= col;
} }
void queuelinef(const hyperpoint& h1, const hyperpoint& h2, color_t col, int par) { void queuelinef(const hyperpoint& h1, const hyperpoint& h2, color_t col, int par) {
@ -2228,12 +2227,10 @@ namespace linepatterns {
cell *c = it->first; cell *c = it->first;
transmatrix& V = it->second; transmatrix& V = it->second;
for(int k=0; patterns[k].lpname; k++) { for(auto& lp: patterns) {
color_t col = patterns[k].color; color_t col = lp.color;
if(!(col & 255)) continue; if(!(col & 255)) continue;
int id = patterns[k].id; drawPattern(lp.id, col, c, V);
drawPattern(id, col, c, V);
} }
} }
} }
@ -2246,8 +2243,16 @@ namespace linepatterns {
dialog::init(XLAT("line patterns")); dialog::init(XLAT("line patterns"));
for(numpat=0; patterns[numpat].lpname; numpat++) int id = 0;
dialog::addColorItem(among(patterns[numpat].id, patVine, patPower) && GOLDBERG ? XLAT("Goldberg") + (patterns[numpat].id == patVine ? " " : ""): XLAT(patterns[numpat].lpname), patterns[numpat].color, 'a'+numpat); for(auto& lp: patterns) {
string name = XLAT(lp.lpname);
if(GOLDBERG && among(lp.id, patVine, patPower)) name = XLAT("Goldberg");
dialog::addColorItem(name, lp.color, 'a'+(id++));
dialog::add_action([&lp] () {
dialog::openColorDialog(lp.color, NULL);
dialog::dialogflags |= sm::MAYDARK | sm::SIDE;
});
}
dialog::addBreak(50); dialog::addBreak(50);
dialog::addBack(); dialog::addBack();
@ -2256,15 +2261,6 @@ namespace linepatterns {
dialog::addInfo("change the alpha parameter to show the lines"); dialog::addInfo("change the alpha parameter to show the lines");
dialog::display(); dialog::display();
keyhandler = [] (int sym, int uni) {
dialog::handleNavigation(sym, uni);
if(uni >= 'a' && uni < 'a' + numpat) {
dialog::openColorDialog(patterns[uni - 'a'].color, NULL);
dialog::dialogflags |= sm::MAYDARK | sm::SIDE;
}
else if(doexiton(sym,uni)) popScreen();
};
} }
}; };
@ -2300,13 +2296,19 @@ int read_pattern_args() {
else if(argis("-pal")) { else if(argis("-pal")) {
PHASEFROM(2); cheat(); PHASEFROM(2); cheat();
shift(); int id = argi(); shift(); string ss = args();
shift(); linepatterns::patterns[id].color |= argi(); shift();
for(auto& lp: linepatterns::patterns)
if(appears(lp.lpname, ss))
lp.color |= argi();
} }
else if(argis("-palrgba")) { else if(argis("-palrgba")) {
PHASEFROM(2); cheat(); PHASEFROM(2); cheat();
shift(); int id = argi(); shift(); string ss = args();
shift(); linepatterns::patterns[id].color = arghex(); shift();
for(auto& lp: linepatterns::patterns)
if(appears(lp.lpname, ss))
lp.color = arghex();
} }
else if(argis("-noplayer")) mapeditor::drawplayer = !mapeditor::drawplayer; else if(argis("-noplayer")) mapeditor::drawplayer = !mapeditor::drawplayer;