Display weapon name on GUI.

This commit is contained in:
Felix Ableitner 2013-07-06 13:38:15 +02:00
parent 203a34f0a0
commit 9d133392bc
7 changed files with 27 additions and 6 deletions

View File

@ -34,10 +34,9 @@ Game::Game(tgui::Window& window) :
mWorld.insertCharacter(mPlayer);
mAmmo = window.add<tgui::Label>();
setAmmoText();
mAmmo->setTextSize(20);
mAmmo->setPosition(mWindow.getSize().x - mAmmo->getSize().x,
mWindow.getSize().y - mAmmo->getSize().y);
mCurrentWeapon = window.add<tgui::Label>();
mCurrentWeapon->setTextSize(14);
}
/**
@ -63,7 +62,7 @@ Game::loop() {
mWorld.step(elapsed);
setAmmoText();
updateGui();
render();
@ -75,7 +74,7 @@ Game::loop() {
* Displays current player ammo in the ammo widget.
*/
void
Game::setAmmoText() {
Game::updateGui() {
int mag = mPlayer->getMagazineAmmo();
int total = mPlayer->getTotalAmmo();
@ -87,6 +86,12 @@ Game::setAmmoText() {
if (total < 10) totalString = "0" + totalString;
mAmmo->setText(magString + "/" + totalString);
mCurrentWeapon->setText(mPlayer->getWeaponName());
mAmmo->setPosition(mWindow.getSize().x - mAmmo->getSize().x,
mWindow.getSize().y - mAmmo->getSize().y);
mCurrentWeapon->setPosition(mWindow.getSize().x - mCurrentWeapon->getSize().x,
mAmmo->getPosition().y - mCurrentWeapon->getSize().y);
}
/**

View File

@ -37,7 +37,7 @@ private:
void mouseUp(const sf::Event& event);
sf::Vector2<float> convertCoordinates(int x, int y);
void setAmmoText();
void updateGui();
private:
static const int FPS_GOAL;
@ -46,6 +46,7 @@ private:
sf::Clock mClock;
sf::View mWorldView;
tgui::Label* mAmmo;
tgui::Label* mCurrentWeapon;
World mWorld;
Pathfinder mPathfinder;

View File

@ -182,6 +182,11 @@ Character::getTotalAmmo() const {
return mActiveWeapon->getTotalAmmo();
}
std::string
Character::getWeaponName() const {
return mActiveWeapon->getName();
}
void
Character::reload() {
mActiveWeapon->reload();

View File

@ -49,6 +49,7 @@ protected:
std::vector<std::shared_ptr<Character> > getCharacters() const;
int getMagazineAmmo() const;
int getTotalAmmo() const;
std::string getWeaponName() const;
void reload();
void toggleWeapon();
void selectFirstWeapon();

View File

@ -16,6 +16,7 @@
Weapon::Weapon(World& world, Character& holder, const Yaml& config) :
mWorld(world),
mHolder(holder),
mName(config.get("name", std::string())),
mProjectile(config.get("bullet", std::string("bullet.yaml"))),
mDamage(config.get("damage", 0)),
mProjectileSpeed(config.get("projectile_speed", 0.0f)),
@ -120,6 +121,11 @@ Weapon::getTotalAmmo() const {
return mTotalAmmo;
}
std::string
Weapon::getName() const {
return mName;
}
void
Weapon::reload() {
if (mMagazineAmmo == mMagazineSize)

View File

@ -31,6 +31,7 @@ public:
void onThink(int elapsed);
int getMagazineAmmo() const;
int getTotalAmmo() const;
std::string getName() const;
void reload();
void cancelReload();
@ -43,6 +44,7 @@ private:
Character& mHolder;
thor::Timer mTimer;
const std::string mName;
const Yaml mProjectile;
const int mDamage;
const float mProjectileSpeed;

View File

@ -38,6 +38,7 @@ public:
void setDestination(const sf::Vector2f& destination);
using Character::getMagazineAmmo;
using Character::getTotalAmmo;
using Character::getWeaponName;
using Character::reload;
using Character::toggleWeapon;
using Character::selectFirstWeapon;