summaryrefslogtreecommitdiff
path: root/src/gui/status.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/gui/status.cpp')
-rw-r--r--src/gui/status.cpp103
1 files changed, 62 insertions, 41 deletions
diff --git a/src/gui/status.cpp b/src/gui/status.cpp
index 12312490..59e58d7c 100644
--- a/src/gui/status.cpp
+++ b/src/gui/status.cpp
@@ -33,13 +33,12 @@
#define CONTROLS_SEPARATOR 4
StatusWindow::StatusWindow():
- Window("%s Lvl: % 2i Job: % 2i")
+ Window("%s Lvl: % 2i Job: % 2i GP: % 2i")
{
hp = new gcn::Label("HP");
sp = new gcn::Label("SP");
hpValue = new gcn::Label();
spValue = new gcn::Label();
- gp = new gcn::Label("GP");
expLabel = new gcn::Label("Exp");
jobExpLabel = new gcn::Label("Job");
@@ -64,26 +63,51 @@ StatusWindow::StatusWindow():
equipmentButton->addActionListener(this);
hp->setPosition(WIN_BORDER, WIN_BORDER);
- sp->setPosition(WIN_BORDER, hp->getY() + hp->getHeight() + CONTROLS_SEPARATOR);
- healthBar = new ProgressBar(1.0f, WIN_BORDER + hp->getWidth() + CONTROLS_SEPARATOR, WIN_BORDER, 80, 15, 0, 255, 0);
- hpValue->setPosition(healthBar->getX() + healthBar->getWidth() + 2*CONTROLS_SEPARATOR, WIN_BORDER);
- manaBar = new ProgressBar(1.0f, WIN_BORDER + sp->getWidth() + CONTROLS_SEPARATOR,
- hp->getY() + hp->getHeight() + CONTROLS_SEPARATOR, 80, 15, 0, 0, 255);
- spValue->setPosition(manaBar->getX() + manaBar->getWidth() + 2*CONTROLS_SEPARATOR, hp->getY() + hp->getHeight() + CONTROLS_SEPARATOR);
- gp->setPosition(170, WIN_BORDER);
- expLabel->setPosition(WIN_BORDER, sp->getY() + sp->getHeight() + CONTROLS_SEPARATOR);
- jobExpLabel->setPosition(spValue->getX(), sp->getY() + sp->getHeight() + CONTROLS_SEPARATOR);
-
- xpBar = new ProgressBar(1.0f, WIN_BORDER, expLabel->getY() + expLabel->getHeight() + CONTROLS_SEPARATOR, 70, 15, 12, 194, 255);
- jobXpBar = new ProgressBar(1.0f, spValue->getX(), jobExpLabel->getY() + jobExpLabel->getHeight() + CONTROLS_SEPARATOR, 70, 15, 200, 0, 0);
-
- statsButton->setPosition(WIN_BORDER, xpBar->getY() + xpBar->getHeight() + 2*CONTROLS_SEPARATOR);
- skillsButton->setPosition(statsButton->getX() + statsButton->getWidth() + CONTROLS_SEPARATOR, statsButton->getY());
- inventoryButton->setPosition(skillsButton->getX() + skillsButton->getWidth() + CONTROLS_SEPARATOR, statsButton->getY());
- setupButton->setPosition(inventoryButton->getX() + inventoryButton->getWidth() + CONTROLS_SEPARATOR, statsButton->getY());
- equipmentButton->setPosition(setupButton->getX() + setupButton->getWidth() + CONTROLS_SEPARATOR, statsButton->getY());
-
- setContentSize(250, statsButton->getY() + statsButton->getHeight() + WIN_BORDER);
+ sp->setPosition(WIN_BORDER,
+ hp->getY() + hp->getHeight() + CONTROLS_SEPARATOR);
+ healthBar = new ProgressBar(1.0f,
+ WIN_BORDER + hp->getWidth() + CONTROLS_SEPARATOR, WIN_BORDER, 80,
+ 15, 0, 171, 34);
+ hpValue->setPosition(
+ healthBar->getX() + healthBar->getWidth() + 2 * CONTROLS_SEPARATOR,
+ WIN_BORDER);
+ manaBar = new ProgressBar(1.0f,
+ WIN_BORDER + sp->getWidth() + CONTROLS_SEPARATOR,
+ hp->getY() + hp->getHeight() + CONTROLS_SEPARATOR, 80, 15, 26, 102,
+ 230);
+ spValue->setPosition(
+ manaBar->getX() + manaBar->getWidth() + 2 * CONTROLS_SEPARATOR,
+ hp->getY() + hp->getHeight() + CONTROLS_SEPARATOR);
+ xpBar = new ProgressBar(1.0f,
+ manaBar->getX(), sp->getY() + sp->getHeight() + CONTROLS_SEPARATOR,
+ 70, 15, 143, 192, 211);
+ expLabel->setPosition(
+ xpBar->getX() + xpBar->getWidth() + CONTROLS_SEPARATOR,
+ xpBar->getY());
+ jobXpBar = new ProgressBar(1.0f, healthBar->getX(),
+ xpBar->getY() + xpBar->getHeight() + CONTROLS_SEPARATOR, 70, 15,
+ 220, 135, 203);
+ jobExpLabel->setPosition(
+ jobXpBar->getX() + jobXpBar->getWidth() + CONTROLS_SEPARATOR,
+ jobXpBar->getY());
+ statsButton->setPosition(WIN_BORDER,
+ jobXpBar->getY() + jobXpBar->getHeight() + 2 * CONTROLS_SEPARATOR);
+ skillsButton->setPosition(
+ statsButton->getX() + statsButton->getWidth() + CONTROLS_SEPARATOR,
+ statsButton->getY());
+ inventoryButton->setPosition(
+ skillsButton->getX() + skillsButton->getWidth() + CONTROLS_SEPARATOR,
+ statsButton->getY());
+ setupButton->setPosition(
+ inventoryButton->getX() + inventoryButton->getWidth() + CONTROLS_SEPARATOR,
+ statsButton->getY());
+ equipmentButton->setPosition(
+ setupButton->getX() + setupButton->getWidth() + CONTROLS_SEPARATOR,
+ statsButton->getY());
+
+ setContentSize(
+ equipmentButton->getX() + equipmentButton->getWidth() + WIN_BORDER,
+ statsButton->getY() + statsButton->getHeight() + WIN_BORDER);
add(hp);
add(sp);
@@ -91,7 +115,6 @@ StatusWindow::StatusWindow():
add(manaBar);
add(hpValue);
add(spValue);
- add(gp);
add(expLabel);
add(jobExpLabel);
add(xpBar);
@@ -107,7 +130,6 @@ StatusWindow::~StatusWindow()
{
delete hp;
delete sp;
- delete gp;
delete expLabel;
delete jobExpLabel;
delete healthBar;
@@ -125,28 +147,25 @@ void StatusWindow::update()
{
char *tempstr = new char[64];
- sprintf(tempstr, "%s Lvl: % 2i Job: % 2i",
- char_info->name, char_info->lv, char_info->job_lv);
+ sprintf(tempstr, "%s Lvl: % 2i Job: % 2i GP: % 2i",
+ char_info->name, char_info->lv, char_info->job_lv,
+ char_info->gp);
setCaption(tempstr);
- sprintf(tempstr, "%d / %d", char_info->hp, char_info->max_hp);
+ sprintf(tempstr, "%d/%d", char_info->hp, char_info->max_hp);
hpValue->setCaption(tempstr);
hpValue->adjustSize();
- sprintf(tempstr, "GP %6i", char_info->gp);
- gp->setCaption(tempstr);
- gp->adjustSize();
-
- sprintf(tempstr, "%d / %d", char_info->sp, char_info->max_sp);
+ sprintf(tempstr, "%d/%d", char_info->sp, char_info->max_sp);
spValue->setCaption(tempstr);
spValue->adjustSize();
- sprintf(tempstr, "Exp: %d / %d",
+ sprintf(tempstr, "Exp: %d/%d",
(int)char_info->xp, (int)char_info->xpForNextLevel);
expLabel->setCaption(tempstr);
expLabel->adjustSize();
- sprintf(tempstr, "Job Exp: %d / %d",
+ sprintf(tempstr, "Job: %d/%d",
(int)char_info->job_xp, (int)char_info->jobXpForNextLevel);
jobExpLabel->setCaption(tempstr);
jobExpLabel->adjustSize();
@@ -154,28 +173,30 @@ void StatusWindow::update()
// HP Bar coloration
if (char_info->hp < int(char_info->max_hp / 3))
{
- healthBar->setColor(255, 0, 0); // Red
+ healthBar->setColor(223, 32, 32); // Red
}
else
{
if (char_info->hp < int((char_info->max_hp / 3) * 2))
{
- healthBar->setColor(255, 181, 9); // orange
+ healthBar->setColor(230, 171, 34); // Orange
}
else
{
- healthBar->setColor(0, 255, 0); // Green
+ healthBar->setColor(0, 171, 34); // Green
}
}
// XP Bar dark blue to light blue Smooth fading
- unsigned char redXP = unsigned(char(((float)char_info->xp / (float)char_info->xpForNextLevel) * 12));
- unsigned char greenXP = unsigned(char(((float)char_info->xp / (float)char_info->xpForNextLevel) * 94));
- xpBar->setColor(redXP, 100 + greenXP, 255);
+ float redXP = (char_info->xp / char_info->xpForNextLevel) * 143;
+ float greenXP = (char_info->xp / char_info->xpForNextLevel) * 192;
+ xpBar->setColor((unsigned char)redXP,
+ (unsigned char)greenXP, 211);
healthBar->setProgress((float)char_info->hp / (float)char_info->max_hp);
- xpBar->setProgress((float)char_info->xp / (float)char_info->xpForNextLevel);
+ xpBar->setProgress(
+ (float)char_info->xp / (float)char_info->xpForNextLevel);
jobXpBar->setProgress(
(float)char_info->job_xp / (float)char_info->jobXpForNextLevel);