mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2025-01-12 10:20:32 +00:00
rogueviz:: improved edge placement
This commit is contained in:
parent
a2018c6f55
commit
bf0956966a
@ -585,8 +585,13 @@ bool drawVertex(const shiftmatrix &V, cell *c, shmup::monster *m) {
|
|||||||
|
|
||||||
int lid = shmup::lmousetarget ? shmup::lmousetarget->pid : -2;
|
int lid = shmup::lmousetarget ? shmup::lmousetarget->pid : -2;
|
||||||
|
|
||||||
|
bool multidraw = quotient;
|
||||||
|
|
||||||
|
bool use_brm = bounded && isize(currentmap->allcells()) <= 1000;
|
||||||
|
|
||||||
if(!lshiftclick) for(int j=0; j<isize(vd.edges); j++) {
|
if(!lshiftclick) for(int j=0; j<isize(vd.edges); j++) {
|
||||||
edgeinfo *ei = vd.edges[j].second;
|
edgeinfo *ei = vd.edges[j].second;
|
||||||
|
if(multidraw && ei->i != i) continue;
|
||||||
vertexdata& vd1 = vdata[ei->i];
|
vertexdata& vd1 = vdata[ei->i];
|
||||||
vertexdata& vd2 = vdata[ei->j];
|
vertexdata& vd2 = vdata[ei->j];
|
||||||
|
|
||||||
@ -602,8 +607,6 @@ bool drawVertex(const shiftmatrix &V, cell *c, shmup::monster *m) {
|
|||||||
|
|
||||||
// if(hilite) ghilite = true;
|
// if(hilite) ghilite = true;
|
||||||
|
|
||||||
bool multidraw = quotient;
|
|
||||||
|
|
||||||
if(ei->lastdraw < frameid || multidraw) {
|
if(ei->lastdraw < frameid || multidraw) {
|
||||||
ei->lastdraw = frameid;
|
ei->lastdraw = frameid;
|
||||||
|
|
||||||
@ -627,12 +630,20 @@ bool drawVertex(const shiftmatrix &V, cell *c, shmup::monster *m) {
|
|||||||
|
|
||||||
alpha >>= darken;
|
alpha >>= darken;
|
||||||
|
|
||||||
shiftmatrix gm1 =
|
shiftmatrix gm1, gm2;
|
||||||
(multidraw || elliptic) ? V * memo_relative_matrix(vd1.m->base, c) :
|
|
||||||
ggmatrix(vd1.m->base);
|
if(use_brm) {
|
||||||
shiftmatrix gm2 =
|
gm1 = V * memo_relative_matrix(vd1.m->base, c);
|
||||||
(multidraw || elliptic) ? V * memo_relative_matrix(vd2.m->base, c) :
|
gm2 = gm1 * brm_get(vd1.m->base, tC0(vd1.m->at), vd2.m->base, tC0(vd2.m->at));
|
||||||
ggmatrix(vd2.m->base);
|
}
|
||||||
|
else if(multidraw || elliptic) {
|
||||||
|
gm1 = V * memo_relative_matrix(vd1.m->base, c);
|
||||||
|
gm2 = V * memo_relative_matrix(vd2.m->base, c);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
gm1 = ggmatrix(vd1.m->base);
|
||||||
|
gm2 = ggmatrix(vd2.m->base);
|
||||||
|
}
|
||||||
|
|
||||||
shiftpoint h1 = gm1 * vd1.m->at * C0;
|
shiftpoint h1 = gm1 * vd1.m->at * C0;
|
||||||
shiftpoint h2 = gm2 * vd2.m->at * C0;
|
shiftpoint h2 = gm2 * vd2.m->at * C0;
|
||||||
@ -677,7 +688,7 @@ bool drawVertex(const shiftmatrix &V, cell *c, shmup::monster *m) {
|
|||||||
ei->orig = center; // cwt.at;
|
ei->orig = center; // cwt.at;
|
||||||
ei->prec.clear();
|
ei->prec.clear();
|
||||||
|
|
||||||
shiftmatrix T = ggmatrix(ei->orig);
|
const shiftmatrix& T = multidraw ? V : ggmatrix(ei->orig);
|
||||||
|
|
||||||
if(callhandlers(false, hooks_alt_edges, ei, true)) ;
|
if(callhandlers(false, hooks_alt_edges, ei, true)) ;
|
||||||
else if(fat_edges) {
|
else if(fat_edges) {
|
||||||
@ -702,7 +713,10 @@ bool drawVertex(const shiftmatrix &V, cell *c, shmup::monster *m) {
|
|||||||
else
|
else
|
||||||
storeline(ei->prec, inverse_shift(T, h1), inverse_shift(T, h2));
|
storeline(ei->prec, inverse_shift(T, h1), inverse_shift(T, h2));
|
||||||
}
|
}
|
||||||
queue_prec(multidraw ? V : ggmatrix(ei->orig), ei, col);
|
|
||||||
|
const shiftmatrix& T = multidraw ? V : ggmatrix(ei->orig);
|
||||||
|
|
||||||
|
queue_prec(T, ei, col);
|
||||||
if(elliptic) queue_prec(ggmatrix(ei->orig) * centralsym, ei, col);
|
if(elliptic) queue_prec(ggmatrix(ei->orig) * centralsym, ei, col);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user