mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2025-01-04 06:20:34 +00:00
multi:: split_screen for standard shmup, not racing
This commit is contained in:
parent
9a25da1989
commit
fbb75309d0
@ -5032,7 +5032,9 @@ EX void drawthemap() {
|
|||||||
mapeditor::draw_dtshapes();
|
mapeditor::draw_dtshapes();
|
||||||
|
|
||||||
if(multi::players > 1 && !shmup::on) {
|
if(multi::players > 1 && !shmup::on) {
|
||||||
if(multi::centerplayer != -1)
|
if(multi::split_screen)
|
||||||
|
cwtV = multi::whereis[subscreens::current_player];
|
||||||
|
else if(multi::centerplayer != -1)
|
||||||
cwtV = multi::whereis[multi::centerplayer];
|
cwtV = multi::whereis[multi::centerplayer];
|
||||||
else {
|
else {
|
||||||
hyperpoint h = Hypc;
|
hyperpoint h = Hypc;
|
||||||
@ -5046,7 +5048,9 @@ EX void drawthemap() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if(shmup::on) {
|
if(shmup::on) {
|
||||||
if(multi::players == 1)
|
if(multi::split_screen)
|
||||||
|
cwtV = shmup::pc[subscreens::current_player]->pat;
|
||||||
|
else if(multi::players == 1)
|
||||||
cwtV = shmup::pc[0]->pat;
|
cwtV = shmup::pc[0]->pat;
|
||||||
else if(multi::centerplayer != -1)
|
else if(multi::centerplayer != -1)
|
||||||
cwtV = shmup::pc[multi::centerplayer]->pat;
|
cwtV = shmup::pc[multi::centerplayer]->pat;
|
||||||
|
@ -443,11 +443,13 @@ monster *playerCrash(monster *who, shiftpoint where) {
|
|||||||
if(who->isVirtual) return NULL;
|
if(who->isVirtual) return NULL;
|
||||||
for(int j=0; j<players; j++) if(pc[j] && pc[j]!=who) {
|
for(int j=0; j<players; j++) if(pc[j] && pc[j]!=who) {
|
||||||
if(pc[j]->isVirtual) continue;
|
if(pc[j]->isVirtual) continue;
|
||||||
|
if(!gmatrix.count(pc[j]->base)) continue;
|
||||||
double d = sqdist(pc[j]->pat*C0, where);
|
double d = sqdist(pc[j]->pat*C0, where);
|
||||||
/* crash into another player -- not taken into account in racing */
|
/* crash into another player -- not taken into account in racing */
|
||||||
if(d < 0.1 * SCALE2 && !racing::on) return pc[j];
|
if(d < 0.1 * SCALE2 && !racing::on) return pc[j];
|
||||||
/* too far away -- irrelevant in split_screen */
|
/* too far away -- irrelevant in split_screen */
|
||||||
if(!split_screen && (d > 100 || (WDIM == 3 && hdist(tC0(pc[j]->pat), where) > sightranges[geometry]/2))) return pc[j];
|
if(!split_screen && (d > 100 || (WDIM == 3 && hdist(tC0(pc[j]->pat), where) > sightranges[geometry]/2)))
|
||||||
|
return pc[j];
|
||||||
}
|
}
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
@ -1447,6 +1449,7 @@ EX int reflect(cell*& c2, cell*& mbase, shiftmatrix& nat) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void moveMimic(monster *m) {
|
void moveMimic(monster *m) {
|
||||||
|
if(multi::players > 1 && multi::split_screen && cpid != subscreens::current_player) return;
|
||||||
virtualize(m);
|
virtualize(m);
|
||||||
shiftmatrix nat = m->pat;
|
shiftmatrix nat = m->pat;
|
||||||
cpid = m->pid;
|
cpid = m->pid;
|
||||||
@ -2515,7 +2518,7 @@ EX hookset<bool(int)> hooks_turn;
|
|||||||
|
|
||||||
EX void turn(int delta) {
|
EX void turn(int delta) {
|
||||||
|
|
||||||
if(racing::on && subscreens::split( [delta] () { turn(delta); })) return;
|
if(split_screen && subscreens::split( [delta] () { turn(delta); })) return;
|
||||||
|
|
||||||
int id = 0;
|
int id = 0;
|
||||||
#if CAP_MOUSEGRAB
|
#if CAP_MOUSEGRAB
|
||||||
|
Loading…
Reference in New Issue
Block a user