X-Git-Url: https://git.dogcows.com/gitweb?p=chaz%2Fyoink;a=blobdiff_plain;f=src%2FHud.hh;h=2262b062983ae1d8faedc89bdc0cdcda21aaa270;hp=8fec549278514ff98814a9799fb09cee494e7450;hb=e973a129b5b83b628ba3f09e8c95682fc74080cd;hpb=25aefe01ef7dbdb603c51411e04b0d6a6107684f diff --git a/src/Hud.hh b/src/Hud.hh index 8fec549..2262b06 100644 --- a/src/Hud.hh +++ b/src/Hud.hh @@ -35,16 +35,21 @@ */ #include +#include #include #include -#include +#include +#include "GameState.hh" + + +// TODO this stuff is still just hacked up class ProgressBar : public Mf::Drawable { public: - ProgressBar(const Mf::Tilemap& tilemap, Mf::Tilemap::Index index); + ProgressBar(const Mf::Texture& tilemap, Mf::Texture::TileIndex index); void resize(const Mf::Rectangle& rect); @@ -54,50 +59,62 @@ public: private: - Mf::Scalar progress_; + Mf::Scalar mProgress; - Mf::Vector2 vertices_[8]; - Mf::Scalar width_; + Mf::Vector2 mVertices[8]; + Mf::Scalar mWidth; - Mf::Tilemap tilemap_; - Mf::Scalar texCoords_[8]; - Mf::Scalar midCoords_[2]; + Mf::Texture mTilemap; + Mf::Scalar mTexCoords[8]; + Mf::Scalar mMidCoords[2]; }; -class Hud : public Mf::Drawable +class Hud; +typedef boost::shared_ptr HudP; + +class Hud : public Mf::Layer { public: - Hud(); + Hud(GameState& state); + + static HudP alloc(GameState& state) + { + return HudP(new Hud(state)); + } void setBar1Progress(Mf::Scalar progress) { // pass through - bar1_.setProgress(progress); + mBar1.setProgress(progress); } void setBar2Progress(Mf::Scalar progress) { // pass through - bar2_.setProgress(progress); + mBar2.setProgress(progress); } void setNumber(unsigned value); void resize(int width, int height); + void update(Mf::Scalar t, Mf::Scalar dt); void draw(Mf::Scalar alpha = 0.0) const; + bool handleEvent(const Mf::Event& event); private: - ProgressBar bar1_; - ProgressBar bar2_; + GameState& mState; + + ProgressBar mBar1; + ProgressBar mBar2; - unsigned number_; - Mf::Tilemap font_; + unsigned mNumber; + Mf::Texture mFont; - Mf::Matrix4 projection_; + Mf::Matrix4 mProjection; };