From: Jan Engelhardt Date: 2013-05-01 14:27:39.000000000 +0200 Category: improvement Status: sent Wed, 1 May 2013 14:28:44 +0200 This makes the health bar above shootables use gradiented color. --- src/gl_drawinfo.c | 4 ++-- src/gl_intern.h | 2 +- src/gl_main.c | 44 +++++++++++++++++--------------------------- 3 files changed, 20 insertions(+), 30 deletions(-) Index: prboom2/src/gl_drawinfo.c =================================================================== --- prboom2.orig/src/gl_drawinfo.c +++ prboom2/src/gl_drawinfo.c @@ -111,10 +111,10 @@ static void gld_AddDrawRange(int size) #define NEWSIZE (MAX(64 * 1024, itemsize)) void gld_AddDrawItem(GLDrawItemType itemtype, void *itemdata) { - int itemsize = 0; + unsigned int itemsize = 0; byte *item_p = NULL; - static int itemsizes[GLDIT_TYPES] = { + static const unsigned int itemsizes[GLDIT_TYPES] = { 0, sizeof(GLWall), sizeof(GLWall), sizeof(GLWall), sizeof(GLWall), sizeof(GLWall), sizeof(GLWall), sizeof(GLWall), Index: prboom2/src/gl_intern.h =================================================================== --- prboom2.orig/src/gl_intern.h +++ prboom2/src/gl_intern.h @@ -220,7 +220,7 @@ typedef struct typedef struct { - int cm; + float r,g; float x1, x2, x3; float z1, z2, z3; Index: prboom2/src/gl_main.c =================================================================== --- prboom2.orig/src/gl_main.c +++ prboom2/src/gl_main.c @@ -2405,15 +2405,20 @@ static void gld_AddHealthBar(mobj_t* thi GLHealthBar hbar; int health_percent = thing->health * 100 / thing->info->spawnhealth; - hbar.cm = -1; - if (health_percent <= health_bar_red) - hbar.cm = CR_RED; - else if (health_percent <= health_bar_yellow) - hbar.cm = CR_YELLOW; - else if (health_percent <= health_bar_green) - hbar.cm = CR_GREEN; + if (health_percent <= health_bar_red) { + hbar.r = 1; + hbar.g = 0; + } else if (health_percent <= health_bar_yellow) { + hbar.r = 1; + hbar.g = (double)(health_percent - health_bar_red) / + (health_bar_yellow - health_bar_red); + } else if (health_percent <= health_bar_green) { + /* FullSimplify[1-((percent-yellow)/(green-yellow))] */ + hbar.r = (double)(health_bar_green - health_percent) / + (health_bar_green - health_bar_yellow); + hbar.g = 1; + } - if (hbar.cm >= 0) { float sx2 = (float)thing->radius / 2.0f / MAP_SCALE; float sx1 = sx2 - (float)health_percent * (float)thing->radius / 100.0f / MAP_SCALE; @@ -2437,7 +2442,6 @@ static void gld_AddHealthBar(mobj_t* thi static void gld_DrawHealthBars(void) { int i, count; - int cm = -1; count = gld_drawinfo.num_items[GLDIT_HBAR]; if (count > 0) @@ -2448,31 +2452,17 @@ static void gld_DrawHealthBars(void) for (i = count - 1; i >= 0; i--) { GLHealthBar *hbar = gld_drawinfo.items[GLDIT_HBAR][i].item.hbar; - if (hbar->cm != cm) - { - cm = hbar->cm; - glColor4f(cm2RGB[cm][0], cm2RGB[cm][1], cm2RGB[cm][2], 1.0f); - } + glColor4f(hbar->r, hbar->g, 0, 1); glVertex3f(hbar->x1, hbar->y, hbar->z1); glVertex3f(hbar->x2, hbar->y, hbar->z2); - } - glEnd(); - - if (health_bar_full_length) - { - glColor4f(0.5f, 0.5f, 0.5f, 1.0f); - glBegin(GL_LINES); - for (i = count - 1; i >= 0; i--) - { - GLHealthBar *hbar = gld_drawinfo.items[GLDIT_HBAR][i].item.hbar; - + if (health_bar_full_length) { + glColor4f(0.5f, 0.5f, 0.5f, 1.0f); glVertex3f(hbar->x1, hbar->y, hbar->z1); glVertex3f(hbar->x3, hbar->y, hbar->z3); } - glEnd(); } - + glEnd(); gld_EnableTexture2D(GL_TEXTURE0_ARB, true); } }