From 882bcbe9f612b2bcc0daab095d73c7fb5e9723be Mon Sep 17 00:00:00 2001 From: Jan Engelhardt Date: Wed, 1 May 2013 09:53:49 +0200 Subject: [PATCH 1/2] Add option to show health bar for all destructible mobjs Origin: https://github.com/jengelh/dsda-doom The current health bar fails to show for Lost Souls. In addition, showing it for other destructible objects (such as barrels - or DEH modifications in that spirit) can be used to gauge the objects' remaining life. --- prboom2/src/dsda/configuration.c | 4 ++++ prboom2/src/dsda/configuration.h | 1 + prboom2/src/dsda/settings.c | 5 +++++ prboom2/src/dsda/settings.h | 1 + prboom2/src/gl_intern.h | 1 + prboom2/src/gl_main.c | 13 ++++++++++--- prboom2/src/m_menu.c | 1 + prboom2/src/m_misc.c | 1 + 8 files changed, 24 insertions(+), 3 deletions(-) Index: dsda-doom-0.28.0/prboom2/src/dsda/configuration.c =================================================================== --- dsda-doom-0.28.0.orig/prboom2/src/dsda/configuration.c +++ dsda-doom-0.28.0/prboom2/src/dsda/configuration.c @@ -604,6 +604,10 @@ dsda_config_t dsda_config[dsda_config_co "gl_health_bar", dsda_config_gl_health_bar, CONF_BOOL(0), NULL, STRICT_INT(0) }, + [dsda_config_gl_health_bar_shootables] = { + "gl_health_bar_shootables", dsda_config_gl_health_bar_shootables, + CONF_BOOL(0), NULL, NOT_STRICT + }, [dsda_config_gl_usevbo] = { "gl_usevbo", dsda_config_gl_usevbo, CONF_BOOL(1), NULL, NOT_STRICT Index: dsda-doom-0.28.0/prboom2/src/dsda/configuration.h =================================================================== --- dsda-doom-0.28.0.orig/prboom2/src/dsda/configuration.h +++ dsda-doom-0.28.0/prboom2/src/dsda/configuration.h @@ -121,6 +121,7 @@ typedef enum { dsda_config_gl_render_multisampling, dsda_config_gl_render_fov, dsda_config_gl_health_bar, + dsda_config_gl_health_bar_shootables, dsda_config_gl_usevbo, dsda_config_gl_fade_mode, dsda_config_use_mouse, Index: dsda-doom-0.28.0/prboom2/src/dsda/settings.c =================================================================== --- dsda-doom-0.28.0.orig/prboom2/src/dsda/settings.c +++ dsda-doom-0.28.0/prboom2/src/dsda/settings.c @@ -251,6 +251,11 @@ dboolean dsda_ShowHealthBars(void) { return dsda_IntConfig(dsda_config_gl_health_bar); } +dboolean dsda_ShowHealthBarsForShootables(void) +{ + return dsda_IntConfig(dsda_config_gl_health_bar_shootables); +} + dboolean dsda_WipeAtFullSpeed(void) { return dsda_IntConfig(dsda_config_wipe_at_full_speed); } Index: dsda-doom-0.28.0/prboom2/src/dsda/settings.h =================================================================== --- dsda-doom-0.28.0.orig/prboom2/src/dsda/settings.h +++ dsda-doom-0.28.0/prboom2/src/dsda/settings.h @@ -50,6 +50,7 @@ dboolean dsda_ShowMinimap(void); dboolean dsda_ShowLevelSplits(void); dboolean dsda_ShowDemoAttempts(void); dboolean dsda_ShowHealthBars(void); +dboolean dsda_ShowHealthBarsForShootables(void); dboolean dsda_MapCoordinates(void); dboolean dsda_MapTotals(void); dboolean dsda_MapTime(void); Index: dsda-doom-0.28.0/prboom2/src/gl_intern.h =================================================================== --- dsda-doom-0.28.0.orig/prboom2/src/gl_intern.h +++ dsda-doom-0.28.0/prboom2/src/gl_intern.h @@ -216,6 +216,7 @@ typedef enum health_bar_null, health_bar_red, health_bar_yellow, + health_bar_green, } health_bar_color_t; typedef struct Index: dsda-doom-0.28.0/prboom2/src/gl_main.c =================================================================== --- dsda-doom-0.28.0.orig/prboom2/src/gl_main.c +++ dsda-doom-0.28.0/prboom2/src/gl_main.c @@ -2031,12 +2031,18 @@ static void gld_DrawSprite(GLSprite *spr static void gld_AddHealthBar(mobj_t* thing, GLSprite *sprite) { - if (((thing->flags & (MF_COUNTKILL | MF_CORPSE)) == MF_COUNTKILL) && (thing->health > 0)) + bool all_shoot = dsda_ShowHealthBarsForShootables(); + int init_color = all_shoot ? health_bar_green : health_bar_null; + bool show_bar = all_shoot ? + thing->flags & MF_SHOOTABLE : + (thing->flags & (MF_COUNTKILL | MF_CORPSE)) == MF_COUNTKILL; + + if (thing->health > 0 && show_bar) { GLHealthBar hbar; int health_percent = thing->health * 100 / P_MobjSpawnHealth(thing); - hbar.color = health_bar_null; + hbar.color = init_color; if (health_percent <= 50) hbar.color = health_bar_red; else if (health_percent <= 99) @@ -2063,10 +2069,11 @@ static void gld_AddHealthBar(mobj_t* thi } } -static GLfloat health_bar_rgb[3][3] = { +static GLfloat health_bar_rgb[][3] = { [health_bar_null] = { 0.0f, 0.0f, 0.0f }, [health_bar_red] = { 1.0f, 0.0f, 0.0f }, [health_bar_yellow] = { 1.0f, 1.0f, 0.0f }, + [health_bar_green] = { 0.0f, 1.0f, 0.0f }, }; static void gld_DrawHealthBars(void) Index: dsda-doom-0.28.0/prboom2/src/m_menu.c =================================================================== --- dsda-doom-0.28.0.orig/prboom2/src/m_menu.c +++ dsda-doom-0.28.0/prboom2/src/m_menu.c @@ -3155,6 +3155,7 @@ setup_menu_t demo_settings[] = { { "Coop Spawns", S_YESNO, m_conf, G_X, dsda_config_coop_spawns }, { "Allow Jumping", S_YESNO, m_conf, G_X, dsda_config_allow_jumping }, { "OpenGL Show Health Bars", S_YESNO, m_conf, G_X, dsda_config_gl_health_bar }, + { "All Shootables have Health Bar", S_YESNO, m_conf, G_X, dsda_config_gl_health_bar_shootables }, PREV_PAGE(mapping_settings), NEXT_PAGE(tas_settings), Index: dsda-doom-0.28.0/prboom2/src/m_misc.c =================================================================== --- dsda-doom-0.28.0.orig/prboom2/src/m_misc.c +++ dsda-doom-0.28.0/prboom2/src/m_misc.c @@ -171,6 +171,7 @@ cfg_def_t cfg_defs[] = MIGRATED_SETTING(dsda_config_gl_render_fov), MIGRATED_SETTING(dsda_config_gl_skymode), MIGRATED_SETTING(dsda_config_gl_health_bar), + MIGRATED_SETTING(dsda_config_gl_health_bar_shootables), MIGRATED_SETTING(dsda_config_gl_usevbo), MIGRATED_SETTING(dsda_config_gl_fade_mode),