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

changed the way of marking the master triangles

This commit is contained in:
Zeno Rogue 2018-02-01 14:31:17 +01:00
parent 980d05a585
commit 33ebed2cf3

View File

@ -312,9 +312,9 @@ bool apply(cell *c, const transmatrix &V, int col) {
if(tstate == tsAdjusting) {
queuepolyat(V, shFullCross[ctof(c)], 0, PPR_LINE);
lastptd().u.poly.outline = models.count(c) ? master_color : slave_color;
lastptd().u.poly.outline = slave_color;
queuepolyat(V, shFullFloor[ctof(c)], 0, PPR_LINE);
lastptd().u.poly.outline = models.count(c) ? master_color : slave_color;
lastptd().u.poly.outline = slave_color;
return false;
}
try {
@ -373,6 +373,18 @@ bool apply(cell *c, const transmatrix &V, int col) {
}
}
void mark_triangles() {
if(tstate == tsAdjusting)
for(auto& mi: texture_map) {
for(auto& t: mi.second.triangles) {
vector<hyperpoint> t2;
for(int i=0; i<3; i++)
t2.push_back(mi.second.M * t[i]);
prettypoly(t2, master_color, master_color, gsplits);
}
}
}
typedef tuple<eGeometry, bool, char, int, eModel, ld, ld> texture_parameters;
static const auto current_texture_parameters = tie(geometry, nonbitrunc, patterns::whichPattern, patterns::subpattern_flags, pmodel, vid.scale, vid.alpha);
@ -427,6 +439,7 @@ void perform_mapping() {
texture::cgroup = patterns::cgroup;
texture_map_orig = texture_map;
orig_texture_parameters = current_texture_parameters;
printf("texture_map has %d elements (S%d)\n", size(texture_map), tstate);
}
void saveFullTexture() {
@ -774,8 +787,8 @@ bool load_textureconfig() {
if(!loadTextureGL()) return false;
calcparam();
drawthemap();
perform_mapping();
tstate = tstate_max = tsActive;
perform_mapping();
return true;
}
@ -869,6 +882,11 @@ string texturehelp =
void showMenu() {
cmode = sm::SIDE | sm::MAYDARK | sm::DIALOG_STRICT_X;
gamescreen(0);
if(tstate == tsAdjusting) {
ptds.clear();
texture::mark_triangles();
drawqueue();
}
if(tstate == tsOff) {
dialog::init(XLAT("texture mode (off)"));
@ -1011,10 +1029,8 @@ void showMenu() {
else if(uni == 'T' && tstate == tsAdjusting)
tstate = tsOff;
else if(uni == 'T' && tstate == tsActive) {
else if(uni == 'T' && tstate == tsActive)
tstate = tsAdjusting;
texture_map.clear();
}
else if(uni == 'g' && tstate == tsActive)
dialog::openColorDialog(grid_color, NULL);