mirror of
				https://github.com/zenorogue/hyperrogue.git
				synced 2025-10-25 02:47:40 +00:00 
			
		
		
		
	crossbow:: crossbow icon works
This commit is contained in:
		| @@ -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); | ||||||
|       } |       } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Zeno Rogue
					Zeno Rogue