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

linepatterns now can have widths set individually

This commit is contained in:
Zeno Rogue 2019-07-03 04:57:35 +02:00
parent 1d8c086169
commit 1a08948c32
2 changed files with 57 additions and 28 deletions

View File

@ -2536,6 +2536,7 @@ namespace linepatterns {
int id; int id;
const char *lpname; const char *lpname;
color_t color; color_t color;
ld multiplier;
}; };
extern vector<linepattern> patterns; extern vector<linepattern> patterns;

View File

@ -2117,34 +2117,34 @@ namespace linepatterns {
vector<linepattern> patterns = { vector<linepattern> patterns = {
{patDual, "dual grid", 0xFFFFFF00}, {patDual, "dual grid", 0xFFFFFF00, 1},
{patHepta, "heptagonal grid", 0x0000C000}, {patHepta, "heptagonal grid", 0x0000C000, 1},
{patRhomb, "rhombic tesselation", 0x0000C000}, {patRhomb, "rhombic tesselation", 0x0000C000, 1},
{patTrihepta, "triheptagonal tesselation", 0x0000C000}, {patTrihepta, "triheptagonal tesselation", 0x0000C000, 1},
{patNormal, "normal tesselation", 0x0000C000}, {patNormal, "normal tesselation", 0x0000C000, 1},
{patBigTriangles, "big triangular grid", 0x00606000}, {patBigTriangles, "big triangular grid", 0x00606000, 1},
{patBigRings, "big triangles: rings", 0x0000C000}, {patBigRings, "big triangles: rings", 0x0000C000, 1},
{patTree, "underlying tree", 0x00d0d000}, {patTree, "underlying tree", 0x00d0d000, 1},
{patAltTree, "circle/horocycle tree", 0xd000d000}, {patAltTree, "circle/horocycle tree", 0xd000d000, 1},
{patZebraTriangles, "zebra triangles", 0x40FF4000}, {patZebraTriangles, "zebra triangles", 0x40FF4000, 1},
{patZebraLines, "zebra lines", 0xFF000000}, {patZebraLines, "zebra lines", 0xFF000000, 1},
{patVine, "vineyard pattern", 0x8438A400}, {patVine, "vineyard pattern", 0x8438A400, 1},
{patPalacelike, "firewall lines", 0xFF400000}, {patPalacelike, "firewall lines", 0xFF400000, 1},
{patPalace, "firewall lines: Palace", 0xFFD50000}, {patPalace, "firewall lines: Palace", 0xFFD50000, 1},
{patPower, "firewall lines: Power", 0xFFFF0000}, {patPower, "firewall lines: Power", 0xFFFF0000, 1},
{patHorocycles, "horocycles", 0xd060d000}, {patHorocycles, "horocycles", 0xd060d000, 1},
{patTriRings, "triangle grid: rings", 0xFFFFFF00}, {patTriRings, "triangle grid: rings", 0xFFFFFF00, 1},
{patTriTree, "triangle grid: tree edges", 0xFFFFFF00}, {patTriTree, "triangle grid: tree edges", 0xFFFFFF00, 1},
{patTriOther, "triangle grid: other edges", 0xFFFFFF00}, {patTriOther, "triangle grid: other edges", 0xFFFFFF00, 1},
{patCircles, "circles", 0xFFFFFF00}, {patCircles, "circles", 0xFFFFFF00, 1},
{patRadii, "radii", 0xFFFFFF00}, {patRadii, "radii", 0xFFFFFF00, 1},
{patMeridians, "meridians", 0xFFFFFF00}, {patMeridians, "meridians", 0xFFFFFF00, 1},
{patParallels, "parallels", 0xFFFFFF00}, {patParallels, "parallels", 0xFFFFFF00, 1},
}; };
void clearAll() { void clearAll() {
@ -2414,14 +2414,17 @@ namespace linepatterns {
for(auto& lp: patterns) { for(auto& lp: patterns) {
color_t col = lp.color; color_t col = lp.color;
vid.linewidth *= lp.multiplier;
if(!(col & 255)) continue; if(!(col & 255)) continue;
drawPattern(lp.id, col, c, V); drawPattern(lp.id, col, c, V);
vid.linewidth /= lp.multiplier;
} }
} }
transmatrix V = gmatrix[cwt.at]; transmatrix V = gmatrix[cwt.at];
for(auto& lp: patterns) { for(auto& lp: patterns) {
color_t col = lp.color; color_t col = lp.color;
vid.linewidth *= lp.multiplier;
if(!(col & 255)) continue; if(!(col & 255)) continue;
if(lp.id == patCircles) if(lp.id == patCircles)
for(int i=15; i<=180; i+=15) { for(int i=15; i<=180; i+=15) {
@ -2457,6 +2460,7 @@ namespace linepatterns {
} }
} }
} }
vid.linewidth /= lp.multiplier;
} }
vid.linewidth /= width; vid.linewidth /= width;
@ -2464,6 +2468,8 @@ namespace linepatterns {
int numpat = 0; int numpat = 0;
bool indiv;
void showMenu() { void showMenu() {
cmode = sm::SIDE | sm::MAYDARK; cmode = sm::SIDE | sm::MAYDARK;
gamescreen(0); gamescreen(0);
@ -2474,12 +2480,18 @@ namespace linepatterns {
for(auto& lp: patterns) { for(auto& lp: patterns) {
string name = XLAT(lp.lpname); string name = XLAT(lp.lpname);
if(GOLDBERG && among(lp.id, patVine, patPower)) name = XLAT("Goldberg"); if(GOLDBERG && among(lp.id, patVine, patPower)) name = XLAT("Goldberg");
if(indiv) {
dialog::addColorItem(name, lp.color, 'a'+(id++)); dialog::addColorItem(name, lp.color, 'a'+(id++));
dialog::add_action([&lp] () { dialog::add_action([&lp] () {
dialog::openColorDialog(lp.color, NULL); dialog::openColorDialog(lp.color, NULL);
dialog::dialogflags |= sm::MAYDARK | sm::SIDE; dialog::dialogflags |= sm::MAYDARK | sm::SIDE;
}); });
} }
else {
dialog::addSelItem(name, fts(lp.multiplier), 'a'+(id++));
dialog::add_action([&lp] () { dialog::editNumber(lp.multiplier, 0, 10, 0.1, 1, XLAT("line width"), ""), dialog::scaleLog(); });
}
}
dialog::addBreak(50); dialog::addBreak(50);
dialog::addBack(); dialog::addBack();
@ -2489,6 +2501,8 @@ namespace linepatterns {
dialog::editNumber(width, 0, 10, 1, 1, XLAT("line width"), ""); dialog::editNumber(width, 0, 10, 1, 1, XLAT("line width"), "");
}); });
dialog::addBoolItem_action("edit widths individually", indiv, 'I');
dialog::addBreak(50); dialog::addBreak(50);
dialog::addInfo("change the alpha parameter to show the lines"); dialog::addInfo("change the alpha parameter to show the lines");
@ -2543,6 +2557,20 @@ int read_pattern_args() {
lp.color = arghex(); lp.color = arghex();
} }
else if(argis("-palw")) {
PHASEFROM(2);
shift(); string ss = args();
for(auto& lp: linepatterns::patterns)
if(appears(lp.lpname, ss)) {
shift_arg_formula(lp.multiplier);
return 0;
}
println(hlog, "linepattern not found in -palw: ", ss);
shift();
}
else if(argis("-palgw")) shift_arg_formula(linepatterns::width);
else if(argis("-noplayer")) mapeditor::drawplayer = !mapeditor::drawplayer; else if(argis("-noplayer")) mapeditor::drawplayer = !mapeditor::drawplayer;
else if(argis("-pcol")) { else if(argis("-pcol")) {
shift(); shift();