mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2025-01-13 19:00:35 +00:00
crossbow:: crossbow icon works
This commit is contained in:
parent
f3398e70c3
commit
33d48a76b3
@ -554,9 +554,11 @@ EX void handleKeyNormal(int sym, int uni) {
|
|||||||
cell *c = whirlwind::jumpDestination(cwt.at);
|
cell *c = whirlwind::jumpDestination(cwt.at);
|
||||||
if(c) target = c;
|
if(c) target = c;
|
||||||
}
|
}
|
||||||
targetRangedOrb(target, roKeyboard);
|
if(bow::fire_mode) bow::add_fire(target);
|
||||||
|
else targetRangedOrb(target, roKeyboard);
|
||||||
sym = 0; uni = 0;
|
sym = 0; uni = 0;
|
||||||
}
|
}
|
||||||
|
if(sym == 'f') bow::switch_fire_mode();
|
||||||
}
|
}
|
||||||
|
|
||||||
if(sym == SDLK_KP5 && DEFAULTCONTROL && !game_keys_scroll) movepcto(-1, 1);
|
if(sym == SDLK_KP5 && DEFAULTCONTROL && !game_keys_scroll) movepcto(-1, 1);
|
||||||
@ -613,7 +615,10 @@ EX void handleKeyNormal(int sym, int uni) {
|
|||||||
actonrelease = false;
|
actonrelease = false;
|
||||||
|
|
||||||
multi::cpid = 0;
|
multi::cpid = 0;
|
||||||
if(mouseover &&
|
if(bow::fire_mode) {
|
||||||
|
if(mouseover) bow::add_fire(mouseover);
|
||||||
|
}
|
||||||
|
else if(mouseover &&
|
||||||
targetclick && (shmup::on ? numplayers() == 1 && !shmup::pc[0]->dead : true) && targetRangedOrb(mouseover, forcetarget ? roMouseForce : roMouse)) {
|
targetclick && (shmup::on ? numplayers() == 1 && !shmup::pc[0]->dead : true) && targetRangedOrb(mouseover, forcetarget ? roMouseForce : roMouse)) {
|
||||||
}
|
}
|
||||||
else if(forcetarget)
|
else if(forcetarget)
|
||||||
|
@ -933,6 +933,11 @@ EX bool drawItemType(eItem it, cell *c, const shiftmatrix& V, color_t icol, int
|
|||||||
queuepoly(Vit * spinptick(750, 0), cgi.shTriangle, darkena(icol, 0, 255));
|
queuepoly(Vit * spinptick(750, 0), cgi.shTriangle, darkena(icol, 0, 255));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
else if(it == itCrossbow) {
|
||||||
|
queuepoly(Vit, cgi.shCrossbowIcon, getcs().bowcolor);
|
||||||
|
queuepoly(Vit, cgi.shCrossbowstringIcon, getcs().bowcolor2);
|
||||||
|
}
|
||||||
|
|
||||||
else if(it == itBabyTortoise) {
|
else if(it == itBabyTortoise) {
|
||||||
int bits = c ? tortoise::babymap[c] : tortoise::last;
|
int bits = c ? tortoise::babymap[c] : tortoise::last;
|
||||||
int over = c && c->monst == moTortoise;
|
int over = c && c->monst == moTortoise;
|
||||||
|
14
hud.cpp
14
hud.cpp
@ -46,6 +46,7 @@ EX int subclass(int i) {
|
|||||||
#define GLYPH_TARGET 512
|
#define GLYPH_TARGET 512
|
||||||
#define GLYPH_INSQUARE 1024
|
#define GLYPH_INSQUARE 1024
|
||||||
#define GLYPH_INLANDSCAPE 2048
|
#define GLYPH_INLANDSCAPE 2048
|
||||||
|
#define GLYPH_ACTIVE 4096
|
||||||
|
|
||||||
#if HDR
|
#if HDR
|
||||||
enum eGlyphsortorder {
|
enum eGlyphsortorder {
|
||||||
@ -68,6 +69,7 @@ int& ikmerge(int i) {
|
|||||||
|
|
||||||
bool ikappear(int i) {
|
bool ikappear(int i) {
|
||||||
if(i == itInventory && inv::on) return true;
|
if(i == itInventory && inv::on) return true;
|
||||||
|
if(i == itCrossbow && bow::crossbow_mode()) return true;
|
||||||
return ikmerge(i);
|
return ikmerge(i);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -142,7 +144,11 @@ int glyphflags(int gid) {
|
|||||||
int f = 0;
|
int f = 0;
|
||||||
if(gid < ittypes) {
|
if(gid < ittypes) {
|
||||||
eItem i = eItem(gid);
|
eItem i = eItem(gid);
|
||||||
if(itemclass(i) == IC_NAI && i != itFatigue) f |= GLYPH_NONUMBER;
|
if(itemclass(i) == IC_NAI && i != itFatigue && i != itCrossbow) f |= GLYPH_NONUMBER;
|
||||||
|
if(i == itCrossbow && items[i] == 0) {
|
||||||
|
if(bow::fire_mode) f |= GLYPH_ACTIVE;
|
||||||
|
f |= GLYPH_NONUMBER;
|
||||||
|
}
|
||||||
if(isElementalShard(i)) {
|
if(isElementalShard(i)) {
|
||||||
f |= GLYPH_LOCAL | GLYPH_INSQUARE;
|
f |= GLYPH_LOCAL | GLYPH_INSQUARE;
|
||||||
if(i == localshardof(cwt.at->land)) f |= GLYPH_LOCAL2;
|
if(i == localshardof(cwt.at->land)) f |= GLYPH_LOCAL2;
|
||||||
@ -229,6 +235,7 @@ bool displayglyph(int cx, int cy, int buttonsize, char glyph, color_t color, int
|
|||||||
if(glyph == ']') bsize = bsize*1.5;
|
if(glyph == ']') bsize = bsize*1.5;
|
||||||
if(glyph == 'x') bsize = bsize*1.5;
|
if(glyph == 'x') bsize = bsize*1.5;
|
||||||
if(it == itWarning) bsize *= 2;
|
if(it == itWarning) bsize *= 2;
|
||||||
|
if(it == itCrossbow) bsize *= 2;
|
||||||
if(it == itBombEgg || it == itTrollEgg || it == itDodeca) bsize = bsize*3/2;
|
if(it == itBombEgg || it == itTrollEgg || it == itDodeca) bsize = bsize*3/2;
|
||||||
int icol = color;
|
int icol = color;
|
||||||
icol -= (color & 0xFCFCFC) >> 2;
|
icol -= (color & 0xFCFCFC) >> 2;
|
||||||
@ -266,6 +273,7 @@ bool displayglyph(int cx, int cy, int buttonsize, char glyph, color_t color, int
|
|||||||
if(flags & GLYPH_LOCAL2) fl += "+";
|
if(flags & GLYPH_LOCAL2) fl += "+";
|
||||||
else if(flags & GLYPH_LOCAL) fl += "-";
|
else if(flags & GLYPH_LOCAL) fl += "-";
|
||||||
if(flags & GLYPH_DEMON) fl += "X";
|
if(flags & GLYPH_DEMON) fl += "X";
|
||||||
|
if(flags & GLYPH_ACTIVE) fl += "A";
|
||||||
if(flags & GLYPH_MARKOVER) str += "!";
|
if(flags & GLYPH_MARKOVER) str += "!";
|
||||||
|
|
||||||
if(fl != "")
|
if(fl != "")
|
||||||
@ -326,6 +334,10 @@ void displayglyph2(int cx, int cy, int buttonsize, int i) {
|
|||||||
mouseovers += XLAT(" (click to use)");
|
mouseovers += XLAT(" (click to use)");
|
||||||
getcstat = 'i';
|
getcstat = 'i';
|
||||||
}
|
}
|
||||||
|
if(it == itCrossbow) {
|
||||||
|
mouseovers += XLAT(" (click to use)");
|
||||||
|
getcstat = 'f';
|
||||||
|
}
|
||||||
if(imp & GLYPH_LOCAL) mouseovers += XLAT(" (local treasure)");
|
if(imp & GLYPH_LOCAL) mouseovers += XLAT(" (local treasure)");
|
||||||
help = generateHelpForItem(it);
|
help = generateHelpForItem(it);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user