1
0
mirror of https://github.com/vcmi/vcmi.git synced 2024-11-24 08:32:34 +02:00

* improved comment coverage in CPlayerInterface.h and CBattleInterface.h

* corrected road blitting when hero moves smoothly and road is near top edge of screen
This commit is contained in:
mateuszb 2009-03-22 16:04:46 +00:00
parent 3ea97f7893
commit 6d5ed19ad3
4 changed files with 215 additions and 189 deletions

View File

@ -1,8 +1,6 @@
#ifndef __CBATTLEINTERFACE_H__
#define __CBATTLEINTERFACE_H__
#include "global.h"
#include "CPlayerInterface.h"
#include <list>
@ -35,8 +33,8 @@ public:
void show(SDL_Surface * to); //prints next frame of animation to to
void activate();
void deactivate();
void setPhase(int newPhase);
void clickLeft(boost::logic::tribool down);
void setPhase(int newPhase); //sets phase of hero animation
void clickLeft(boost::logic::tribool down); //call-in
CBattleHero(const std::string & defName, int phaseG, int imageG, bool filpG, unsigned char player, const CGHeroInstance * hero, const CBattleInterface * owner); //c-tor
~CBattleHero(); //d-tor
};
@ -46,10 +44,10 @@ class CBattleHex : public Hoverable, public MotionInterested, public ClickableL,
private:
bool setAlterText; //if true, this hex has set alternative text in console and will clean it
public:
unsigned int myNumber;
bool accesible;
unsigned int myNumber; //number of hex in commonly used format
bool accesible; //if true, this hex is accessible for units
//CStack * ourStack;
bool hovered, strictHovered;
bool hovered, strictHovered; //for determining if hex is hovered by mouse (this is different problem than hex's graphic hovering)
CBattleInterface * myInterface; //interface that owns me
static std::pair<int, int> getXYUnitAnim(const int & hexNum, const bool & attacker, const CCreature * creature); //returns (x, y) of left top corner of animation
//for user interactions
@ -94,7 +92,7 @@ public:
CBattleReslutWindow(const BattleResult & br, const SDL_Rect & pos, const CBattleInterface * owner); //c-tor
~CBattleReslutWindow(); //d-tor
void bExitf();
void bExitf(); //exit button callback
void activate();
void deactivate();
@ -113,8 +111,8 @@ public:
CBattleOptionsWindow(const SDL_Rect & position, CBattleInterface * owner); //c-tor
~CBattleOptionsWindow(); //d-tor
void bDefaultf();
void bExitf();
void bDefaultf(); //dafault button callback
void bExitf(); //exit button callback
void activate();
void deactivate();
@ -128,7 +126,7 @@ private:
AdventureMapButton * bOptions, * bSurrender, * bFlee, * bAutofight, * bSpell,
* bWait, * bDefence, * bConsoleUp, * bConsoleDown;
CBattleConsole * console;
CBattleHero * attackingHero, * defendingHero;
CBattleHero * attackingHero, * defendingHero; //fighting heroes
CCreatureSet * army1, * army2; //fighting armies
CGHeroInstance * attackingHeroInstance, * defendingHeroInstance;
std::map< int, CCreatureAnimation * > creAnims; //animations of creatures from fighting armies (order by BattleInfo's stacks' ID)
@ -178,7 +176,7 @@ private:
int animStartDelay; //how many times projectile must be attempted to be shown till it's really show (decremented after hit)
bool reverse; //if true, projectile will be flipped by vertical asix
};
std::list<SProjectileInfo> projectiles;
std::list<SProjectileInfo> projectiles; //projectiles flying on battlefield
void projectileShowHelper(SDL_Surface * to=NULL); //prints projectiles present on the battlefield
void giveCommand(ui8 action, ui16 tile, ui32 stack, si32 additional=-1);
bool isTileAttackable(const int & number) const; //returns true if tile 'number' is neighbouring any tile from active stack's range or is one of these tiles

View File

@ -2892,7 +2892,11 @@ void CHeroList::draw()
int CHeroList::getPosOfHero(const CArmedInstance* h)
{
return vstd::findPos(items,h,boost::bind(vstd::equal<std::pair<const CGHeroInstance*, CPath *>,const CArmedInstance *,const CGHeroInstance*>,_1,&std::pair<const CGHeroInstance*, CPath *>::first,_2));
return vstd::findPos(
items,h,
boost::bind(vstd::equal<std::pair<const CGHeroInstance*, CPath *>,
const CArmedInstance *,const CGHeroInstance*>,_1,
&std::pair<const CGHeroInstance*, CPath *>::first,_2));
}

View File

@ -60,9 +60,7 @@ struct Point
:x(a.x),y(a.y)
{}
Point operator+(const Point &b)
Point operator+(const Point &b) const
{
return Point(x+b.x,y+b.y);
}
@ -72,7 +70,7 @@ struct Point
y += b.y;
return *this;
}
Point operator-(const Point &b)
Point operator-(const Point &b) const
{
return Point(x+b.x,y+b.y);
}
@ -82,7 +80,7 @@ struct Point
y -= b.y;
return *this;
}
bool operator<(const Point &b)
bool operator<(const Point &b) const //product order
{
return x < b.x && y < b.y;
}
@ -90,59 +88,67 @@ struct Point
struct Rect : public SDL_Rect
{
Rect()
Rect()//default c-tor
{
x = y = w = h = -1;
}
Rect(int X, int Y, int W, int H)
Rect(int X, int Y, int W, int H) //c-tor
{
x = X;
y = Y;
w = W;
h = H;
}
Rect(const SDL_Rect & r)
Rect(const SDL_Rect & r) //c-tor
{
x = r.x;
y = r.y;
w = r.w;
h = r.h;
}
bool isIn(int qx, int qy) const
bool isIn(int qx, int qy) const //determines if given point lies inside rect
{
if (qx > x && qx<x+w && qy>y && qy<y+h)
return true;
return false;
}
bool isIn(const Point &q) const
bool isIn(const Point &q) const //determines if given point lies inside rect
{
return isIn(q.x,q.y);
}
Point topLeft() const
Point topLeft() const //top left corner of this rect
{
return Point(x,y);
}
Point topRight() const
Point topRight() const //top right corner of this rect
{
return Point(x+w,y);
}
Point bottomLeft() const
Point bottomLeft() const //bottom left corner of this rect
{
return Point(x,y+h);
}
Point bottomRight() const
Point bottomRight() const //bottom right corner of this rect
{
return Point(x+w,y+h);
}
Rect operator+(const Rect &p) const
Rect operator+(const Rect &p) const //moves this rect by p's rect position
{
return Rect(x+p.x,y+p.y,w,h);
}
Rect operator+(const Point &p) const
Rect operator+(const Point &p) const //moves this rect by p's point position
{
return Rect(x+p.x,y+p.y,w,h);
}
Rect& operator+=(const Rect &p)
Rect& operator=(const Rect &p) //assignment operator
{
x = p.x;
y = p.y;
w = p.w;
h = p.h;
return *this;
}
Rect& operator+=(const Rect &p) //works as operator+
{
x += p.x;
y += p.y;
@ -150,7 +156,24 @@ struct Rect : public SDL_Rect
}
Rect operator&(const Rect &p) const //rect intersection
{
bool intersect = isIn(p.topLeft()) || isIn(p.bottomRight()) || isIn(p.topRight()) || isIn(p.bottomLeft());
bool intersect = true;
if(p.topLeft().y < y && p.bottomLeft().y < y) //rect p is above *this
{
intersect = false;
}
else if(p.topLeft().y > y+h && p.bottomLeft().y > y+h) //rect p is below *this
{
intersect = false;
}
else if(p.topLeft().x > x+w && p.topRight().x > x+w) //rect p is on the right hand side of this
{
intersect = false;
}
else if(p.topLeft().x < x && p.topRight().x < x) //rect p is on the left hand side of this
{
intersect = false;
}
if(intersect)
{
@ -185,7 +208,7 @@ public:
virtual void print(const std::string & text)=0; //prints text and refreshes statusbar
virtual void clear()=0;//clears statusbar and refreshes
virtual void show()=0; //shows statusbar (with current text)
virtual std::string getCurrent()=0;
virtual std::string getCurrent()=0; //returns currently displayed text
};
class IActivable
@ -208,47 +231,47 @@ public:
class CIntObject //interface object
{
public:
Rect pos;
int ID;
Rect pos; //position of object on the screen
int ID; //object uniqe ID, rarely (if at all) used
//virtual bool isIn(int x, int y)
//{
// return pos.isIn(x,y);
//}
virtual ~CIntObject(){};
virtual ~CIntObject(){}; //d-tor
};
class CSimpleWindow : public virtual CIntObject, public IShowable
{
public:
SDL_Surface * bitmap;
CIntObject * owner;
CIntObject * owner; //who made this window
virtual void show(SDL_Surface * to = NULL);
CSimpleWindow():bitmap(NULL),owner(NULL){};
virtual ~CSimpleWindow();
CSimpleWindow():bitmap(NULL),owner(NULL){}; //c-tor
virtual ~CSimpleWindow(); //d-tor
};
class CButtonBase : public virtual CIntObject, public IShowable, public IActivable //basic buttton class
{
public:
int bitmapOffset;
int type; //advmapbutton=2
bool abs;
bool active;
bool notFreeButton;
int bitmapOffset; //TODO: comment me
int type; //advmapbutton=2 //TODO: comment me
bool abs;//TODO: comment me
bool active; //if true, this button is active and can be pressed
bool notFreeButton; //TODO: comment me
CIntObject * ourObj; // "owner"
int state;
std::vector< std::vector<SDL_Surface*> > imgs;
int curimg;
int state; //TODO: comment me
std::vector< std::vector<SDL_Surface*> > imgs; //images for this button
int curimg; //curently displayed image from imgs
virtual void show(SDL_Surface * to = NULL);
virtual void activate()=0;
virtual void deactivate()=0;
CButtonBase();
virtual ~CButtonBase();
CButtonBase(); //c-tor
virtual ~CButtonBase(); //d-tor
};
class ClickableL : public virtual CIntObject //for left-clicks
{
public:
bool pressedL;
ClickableL();
bool pressedL; //for determining if object is L-pressed
ClickableL(); //c-tor
virtual ~ClickableL();//{};
virtual void clickLeft (boost::logic::tribool down)=0;
virtual void activate();
@ -257,8 +280,8 @@ public:
class ClickableR : public virtual CIntObject //for right-clicks
{
public:
bool pressedR;
ClickableR();
bool pressedR; //for determining if object is R-pressed
ClickableR(); //c-tor
virtual ~ClickableR();//{};
virtual void clickRight (boost::logic::tribool down)=0;
virtual void activate()=0;
@ -267,9 +290,9 @@ public:
class Hoverable : public virtual CIntObject
{
public:
Hoverable(){hovered=false;}
virtual ~Hoverable();//{};
bool hovered;
Hoverable(){hovered=false;} //c-tor
virtual ~Hoverable();//{}; //d-tor
bool hovered; //for determining if object is hovered
virtual void hover (bool on)=0;
virtual void activate()=0;
virtual void deactivate()=0;
@ -287,10 +310,10 @@ class KeyShortcut : public KeyInterested, public ClickableL
{
public:
std::set<int> assignedKeys;
KeyShortcut(){};
KeyShortcut(int key){assignedKeys.insert(key);};
KeyShortcut(std::set<int> Keys):assignedKeys(Keys){};
virtual void keyPressed(const SDL_KeyboardEvent & key);
KeyShortcut(){}; //c-tor
KeyShortcut(int key){assignedKeys.insert(key);}; //c-tor
KeyShortcut(std::set<int> Keys):assignedKeys(Keys){}; //c-tor
virtual void keyPressed(const SDL_KeyboardEvent & key); //call-in
};
class MotionInterested: public virtual CIntObject
@ -306,7 +329,7 @@ public:
class TimeInterested: public virtual CIntObject
{
public:
virtual ~TimeInterested(){};
virtual ~TimeInterested(){}; //d-tor
int toNextTick;
virtual void tick()=0;
virtual void activate();
@ -322,61 +345,62 @@ public:
virtual void show(SDL_Surface * to = NULL);
void activate();
void deactivate();
CInfoWindow(std::string text, int player, int charperline, const std::vector<SComponent*> &comps, std::vector<std::pair<std::string,CFunctionList<void()> > > &Buttons);
CInfoWindow();
~CInfoWindow();
CInfoWindow(std::string text, int player, int charperline, const std::vector<SComponent*> &comps, std::vector<std::pair<std::string,CFunctionList<void()> > > &Buttons); //c-tor
CInfoWindow(); //c-tor
~CInfoWindow(); //d-tor
};
class CSelWindow : public CInfoWindow //component selection window
{ //uwaga - to okno usuwa swoje komponenty przy zamykaniu
{ //warning - this window deletes its components by closing!
public:
void selectionChange(unsigned to);
void close();
CSelWindow(std::string text, int player, int charperline, std::vector<CSelectableComponent*> &comps, std::vector<std::pair<std::string,boost::function<void()> > > &Buttons);
CSelWindow(){};
CSelWindow(std::string text, int player, int charperline, std::vector<CSelectableComponent*> &comps, std::vector<std::pair<std::string,boost::function<void()> > > &Buttons); //c-tor
CSelWindow(){}; //c-tor
//notification - this class inherits important destructor from CInfoWindow
};
class CRClickPopup : public IShowable, public ClickableR
class CRClickPopup : public IShowable, public ClickableR //popup displayed on R-click
{
public:
virtual void activate();
virtual void deactivate();
virtual void close()=0;
void clickRight (boost::logic::tribool down);
virtual ~CRClickPopup(){};
virtual ~CRClickPopup(){}; //d-tor
};
class CInfoPopup : public CRClickPopup
{
public:
bool free;
SDL_Surface * bitmap;
CInfoPopup(SDL_Surface * Bitmap, int x, int y, bool Free=false);
bool free; //TODO: comment me
SDL_Surface * bitmap; //popup background
CInfoPopup(SDL_Surface * Bitmap, int x, int y, bool Free=false); //c-tor
void close();
void show(SDL_Surface * to = NULL);
CInfoPopup(){free=false;bitmap=NULL;}
~CInfoPopup(){};
CInfoPopup(){free=false;bitmap=NULL;} //default c-tor
~CInfoPopup(){}; //d-tor
};
class SComponent : public ClickableR
class SComponent : public ClickableR //common popup window component
{
public:
enum Etype
{
primskill, secskill, resource, creature, artifact, experience, secskill44, spell, morale, luck
} type;
int subtype;
int val;
} type; //component type
int subtype; //TODO: comment me
int val; //TODO: comment me
std::string description; //r-click
std::string subtitle;
std::string subtitle; //TODO: comment me
void init(Etype Type, int Subtype, int Val);
SComponent(Etype Type, int Subtype, int Val);
SComponent(const Component &c);
SComponent(){};
virtual ~SComponent(){};
SComponent(Etype Type, int Subtype, int Val); //c-tor
SComponent(const Component &c); //c-tor
SComponent(){}; //c-tor
virtual ~SComponent(){}; //d-tor
void clickRight (boost::logic::tribool down);
void clickRight (boost::logic::tribool down); //call-in
virtual SDL_Surface * getImg();
virtual void show(SDL_Surface * to = NULL);
virtual void activate();
@ -387,43 +411,43 @@ class CCustomImgComponent : public SComponent
{
public:
bool free; //should surface be freed on delete
SDL_Surface *bmp;
SDL_Surface *bmp; //our image
SDL_Surface * getImg();
CCustomImgComponent(Etype Type, int Subtype, int Val, SDL_Surface *sur, bool freeSur);
~CCustomImgComponent();
CCustomImgComponent(Etype Type, int Subtype, int Val, SDL_Surface *sur, bool freeSur); //c-tor
~CCustomImgComponent(); //d-tor
};
class CSelectableComponent : public SComponent, public KeyShortcut
{
public:
bool selected;
bool selected; //if true, this component is selected
bool customB;
bool customB; //TODO: comment me
SDL_Surface * border, *myBitmap;
boost::function<void()> onSelect;
boost::function<void()> onSelect; //function called on selection change
void clickLeft(boost::logic::tribool down);
void clickLeft(boost::logic::tribool down); //call-in
void init(SDL_Surface * Border);
CSelectableComponent(Etype Type, int Sub, int Val, boost::function<void()> OnSelect = 0, SDL_Surface * Border=NULL);
CSelectableComponent(const Component &c, boost::function<void()> OnSelect = 0, SDL_Surface * Border=NULL);
~CSelectableComponent();
CSelectableComponent(Etype Type, int Sub, int Val, boost::function<void()> OnSelect = 0, SDL_Surface * Border=NULL); //c-tor
CSelectableComponent(const Component &c, boost::function<void()> OnSelect = 0, SDL_Surface * Border=NULL); //c-tor
~CSelectableComponent(); //d-tor
virtual void show(SDL_Surface * to = NULL);
void activate();
void deactivate();
void select(bool on);
SDL_Surface * getImg();
SDL_Surface * getImg(); //returns myBitmap
};
class CGarrisonInt;
class CGarrisonSlot : public ClickableL, public ClickableR, public Hoverable
{
public:
CGarrisonInt *owner;
const CCreature * creature;
int count;
const CCreature * creature; //creature in slot
int count; //number of creatures
int upg; //0 - up garrison, 1 - down garrison
bool active;
bool active; //TODO: comment me
virtual void hover (bool on);
virtual void hover (bool on); //call-in
const CArmedInstance * getObj();
void clickRight (boost::logic::tribool down);
void clickLeft(boost::logic::tribool down);
@ -437,18 +461,18 @@ public:
class CGarrisonInt :public CIntObject
{
public:
int interx, intery;
CGarrisonSlot *highlighted;
int interx, intery; //intervals between slots
CGarrisonSlot *highlighted; //choosen slot
SDL_Surface *&sur;
int offx, offy, p2;
SDL_Surface *&sur; //TODO: comment me
int offx, offy, p2; //TODO: comment me
bool ignoreEvent, update, active, splitting, pb;
const CCreatureSet *set1;
const CCreatureSet *set2;
const CCreatureSet *set1; //top set of creatures
const CCreatureSet *set2; //bottom set of creatures
std::vector<CGarrisonSlot*> *sup, *sdown;
const CArmedInstance *oup, *odown;
std::vector<CGarrisonSlot*> *sup, *sdown; //TODO: comment me
const CArmedInstance *oup, *odown; //TODO: comment me
void activate();
void deactivate();
@ -459,31 +483,31 @@ public:
void createSlots();
void recreateSlots();
void splitClick();
void splitStacks(int am2);
void splitClick(); //handles click on split button
void splitStacks(int am2); //TODO: comment me
CGarrisonInt(int x, int y, int inx, int iny, SDL_Surface *&pomsur, int OX, int OY, const CArmedInstance *s1, const CArmedInstance *s2=NULL);
~CGarrisonInt();
CGarrisonInt(int x, int y, int inx, int iny, SDL_Surface *&pomsur, int OX, int OY, const CArmedInstance *s1, const CArmedInstance *s2=NULL); //c-tor
~CGarrisonInt(); //d-tor
};
class CPlayerInterface : public CGameInterface
{
public:
//minor interfaces
CondSh<bool> *showingDialog;
boost::recursive_mutex *pim;
bool makingTurn;
int heroMoveSpeed;
CondSh<bool> *showingDialog; //indicates if dialog box is displayed
boost::recursive_mutex *pim; //locks read/write of this
bool makingTurn; //indicates if player is already making his turn
int heroMoveSpeed; //speed of player's hero movement
void setHeroMoveSpeed(int newSpeed) {heroMoveSpeed = newSpeed;} //set for the member above
int mapScrollingSpeed;
int mapScrollingSpeed; //map scrolling speed
void setMapScrollingSpeed(int newSpeed) {mapScrollingSpeed = newSpeed;} //set the member above
SDL_Event * current;
SDL_Event * current; //current event
CMainInterface *curint;
CAdvMapInt * adventureInt;
CCastleInterface * castleInt;
CBattleInterface * battleInt;
FPSmanager * mainFPSmng;
IStatusBar *statusbar;
IStatusBar *statusbar; //advmap statusbar; should it be used by other windows with statusbar?
//to commucate with engine
CCallback * cb;
const BattleAction *curAction;
@ -527,7 +551,7 @@ public:
void actionStarted(const BattleAction* action);//occurs BEFORE action taken by active stack or by the hero
BattleAction activeStack(int stackID); //called when it's turn of that stack
void battleAttack(BattleAttack *ba); //stack performs attack
void battleEnd(BattleResult *br);
void battleEnd(BattleResult *br); //end of battle
void battleResultQuited();
void battleNewRound(int round); //called at the beggining of each turn, round=-1 is the tactic phase, round=0 is the first "normal" turn
void battleStackMoved(int ID, int dest, int distance);
@ -541,7 +565,7 @@ public:
//-------------//
void redrawHeroWin(const CGHeroInstance * hero);
void updateWater();
void showComp(SComponent comp);
void showComp(SComponent comp); //TODO: comment me
void openTownWindow(const CGTownInstance * town); //shows townscreen
void openHeroWindow(const CGHeroInstance * hero); //shows hero window with given hero
SDL_Surface * infoWin(const CGObjectInstance * specific); //specific=0 => draws info about selected town/hero
@ -550,7 +574,7 @@ public:
void handleKeyUp(SDL_Event *sEvent);
void handleMouseMotion(SDL_Event *sEvent);
void init(ICallback * CB);
int3 repairScreenPos(int3 pos);
int3 repairScreenPos(int3 pos); //returns position closest to pos we can center screen on
void removeObjToBlit(IShowable* obj);
void showInfoDialog(std::string &text, const std::vector<SComponent*> & components);
void showYesNoDialog(std::string &text, const std::vector<SComponent*> & components, CFunctionList<void()> onYes, CFunctionList<void()> onNo, bool deactivateCur, bool DelComps); //deactivateCur - whether current main interface should be deactivated; delComps - if components will be deleted on window close
@ -572,28 +596,28 @@ public:
void print(const std::string & text); //prints text and refreshes statusbar
void clear();//clears statusbar and refreshes
void show(); //shows statusbar (with current text)
std::string getCurrent();
std::string getCurrent(); //getter for current
};
class CList
: public ClickableL, public ClickableR, public Hoverable, public KeyInterested, public virtual CIntObject, public MotionInterested
{
public:
SDL_Surface * bg;
CDefHandler *arrup, *arrdo;
SDL_Surface * bg; //background bitmap
CDefHandler *arrup, *arrdo; //button arrows for scrolling list
SDL_Surface *empty, *selection;
SDL_Rect arrupp, arrdop; //positions of arrows
int posw, posh; //position width/height
int selected, //id of selected position, <0 if none
from;
const int SIZE;
const int SIZE; //size of list
boost::logic::tribool pressed; //true=up; false=down; indeterminate=none
CList(int Size = 5);
CList(int Size = 5); //c-tor
void clickLeft(boost::logic::tribool down);
void activate();
void deactivate();
virtual void mouseMoved (const SDL_MouseMotionEvent & sEvent)=0;
virtual void mouseMoved (const SDL_MouseMotionEvent & sEvent)=0; //call-in
virtual void genList()=0;
virtual void select(int which)=0;
virtual void draw()=0;
@ -602,22 +626,22 @@ class CHeroList
: public CList
{
public:
CDefHandler *mobile, *mana;
CDefHandler *mobile, *mana; //mana and movement indicators
std::vector<std::pair<const CGHeroInstance*, CPath *> > items;
int posmobx, posporx, posmanx, posmoby, pospory, posmany;
CHeroList(int Size);
int getPosOfHero(const CArmedInstance* h);
CHeroList(int Size); //c-tor
int getPosOfHero(const CArmedInstance* h); //hero's position on list
void genList();
void select(int which);
void mouseMoved (const SDL_MouseMotionEvent & sEvent);
void clickLeft(boost::logic::tribool down);
void clickRight(boost::logic::tribool down);
void hover (bool on);
void keyPressed (const SDL_KeyboardEvent & key);
void select(int which); //call-in
void mouseMoved (const SDL_MouseMotionEvent & sEvent); //call-in
void clickLeft(boost::logic::tribool down); //call-in
void clickRight(boost::logic::tribool down); //call-in
void hover (bool on); //call-in
void keyPressed (const SDL_KeyboardEvent & key); //call-in
void updateHList(const CGHeroInstance *toRemove=NULL); //removes specific hero from the list or recreates it
void updateMove(const CGHeroInstance* which); //draws move points bar
void redrawAllOne(int which);
void redrawAllOne(int which); //not imeplemented
void draw();
void init();
};
@ -626,19 +650,19 @@ class CTownList
: public CList
{
public:
boost::function<void()> fun;
std::vector<const CGTownInstance*> items;
boost::function<void()> fun; //function called on selection change
std::vector<const CGTownInstance*> items; //towns on list
int posporx,pospory;
CTownList(int Size, int x, int y, std::string arrupg, std::string arrdog);
~CTownList();
CTownList(int Size, int x, int y, std::string arrupg, std::string arrdog); //c-tor
~CTownList(); //d-tor
void genList();
void select(int which);
void mouseMoved (const SDL_MouseMotionEvent & sEvent);
void clickLeft(boost::logic::tribool down);
void clickRight(boost::logic::tribool down);
void hover (bool on);
void keyPressed (const SDL_KeyboardEvent & key);
void select(int which); //call-in
void mouseMoved (const SDL_MouseMotionEvent & sEvent); //call-in
void clickLeft(boost::logic::tribool down); //call-in
void clickRight(boost::logic::tribool down); //call-in
void hover (bool on); //call-in
void keyPressed (const SDL_KeyboardEvent & key); //call-in
void draw();
};
@ -646,12 +670,12 @@ class CCreaturePic //draws picture with creature on background, use nextFrame=tr
{
public:
bool big; //big => 100x130; !big => 100x120
CCreature *c;
CCreatureAnimation *anim;
CCreaturePic(CCreature *cre, bool Big=true);
~CCreaturePic();
int blitPic(SDL_Surface *to, int x, int y, bool nextFrame);
SDL_Surface * getPic(bool nextFrame);
CCreature *c; //which creature's picture
CCreatureAnimation *anim; //displayed animation
CCreaturePic(CCreature *cre, bool Big=true); //c-tor
~CCreaturePic(); //d-tor
int blitPic(SDL_Surface *to, int x, int y, bool nextFrame); //prints creature on screen
SDL_Surface * getPic(bool nextFrame); //returns frame of animation
};
class CRecrutationWindow : public IShowable, public ClickableL, public ClickableR
@ -660,16 +684,16 @@ public:
struct creinfo
{
SDL_Rect pos;
CCreaturePic *pic;
CCreaturePic *pic; //creature's animation
int ID, amount; //creature ID and available amount
std::vector<std::pair<int,int> > res; //res_id - cost_per_unit
};
std::vector<int> amounts; //how many creatures we can afford
std::vector<creinfo> creatures;
std::vector<creinfo> creatures; //recruitable creatures
boost::function<void(int,int)> recruit; //void (int ID, int amount) <-- call to recruit creatures
CSlider *slider;
CSlider *slider; //for selecting amount
AdventureMapButton *max, *buy, *cancel;
SDL_Surface *bitmap;
SDL_Surface *bitmap; //background
CStatusBar *bar;
int which; //which creature is active
@ -683,8 +707,8 @@ public:
void activate();
void deactivate();
void show(SDL_Surface * to = NULL);
CRecrutationWindow(const std::vector<std::pair<int,int> > & Creatures, const boost::function<void(int,int)> & Recruit); //creatures - pairs<creature_ID,amount>
~CRecrutationWindow();
CRecrutationWindow(const std::vector<std::pair<int,int> > & Creatures, const boost::function<void(int,int)> & Recruit); //creatures - pairs<creature_ID,amount> //c-tor
~CRecrutationWindow(); //d-tor
};
class CSplitWindow : public IShowable, public KeyInterested, public ClickableL
@ -692,47 +716,47 @@ class CSplitWindow : public IShowable, public KeyInterested, public ClickableL
public:
CGarrisonInt *gar;
CSlider *slider;
CCreaturePic *anim;
CCreaturePic *anim; //creature's animation
AdventureMapButton *ok, *cancel;
SDL_Surface *bitmap;
int a1, a2, c;
bool which;
SDL_Surface *bitmap; //background
int a1, a2, c; //TODO: comment me
bool which; //TODO: comment me
CSplitWindow(int cid, int max, CGarrisonInt *Owner);
~CSplitWindow();
CSplitWindow(int cid, int max, CGarrisonInt *Owner); //c-tor
~CSplitWindow(); //d-tor
void activate();
void split();
void close();
void deactivate();
void show(SDL_Surface * to = NULL);
void clickLeft(boost::logic::tribool down);
void keyPressed (const SDL_KeyboardEvent & key);
void clickLeft(boost::logic::tribool down); //call-in
void keyPressed (const SDL_KeyboardEvent & key); //call-in
void sliderMoved(int to);
};
class CCreInfoWindow : public IShowable, public KeyInterested, public ClickableR
{
public:
bool active;
bool active; //TODO: comment me
int type;//0 - rclick popup; 1 - normal window
SDL_Surface *bitmap;
char anf;
SDL_Surface *bitmap; //background
char anf; //TODO: comment me
std::string count; //creature count in text format
boost::function<void()> dsm;
boost::function<void()> dsm; //TODO: comment me
CCreaturePic *anim;
CCreature *c;
CInfoWindow *dependant; //it may be dialog asking whther upgrade/dismiss stack (if opened)
std::vector<SComponent*> upgResCost; //cost of upgrade (if not possible then empty)
AdventureMapButton *dismiss, *upgrade, *ok;
CCreInfoWindow(int Cid, int Type, int creatureCount, StackState *State, boost::function<void()> Upg, boost::function<void()> Dsm, UpgradeInfo *ui);
~CCreInfoWindow();
CCreInfoWindow(int Cid, int Type, int creatureCount, StackState *State, boost::function<void()> Upg, boost::function<void()> Dsm, UpgradeInfo *ui); //c-tor
~CCreInfoWindow(); //d-tor
void activate();
void close();
void clickRight(boost::logic::tribool down);
void clickRight(boost::logic::tribool down); //call-in
void dismissF();
void keyPressed (const SDL_KeyboardEvent & key);
void keyPressed (const SDL_KeyboardEvent & key); //call-in
void deactivate();
void show(SDL_Surface * to = NULL);
void onUpgradeYes();
@ -743,14 +767,14 @@ class CLevelWindow : public IShowable, public CIntObject
{
public:
int heroType;
SDL_Surface *bitmap;
SDL_Surface *bitmap; //background
std::vector<CSelectableComponent *> comps; //skills to select
AdventureMapButton *ok;
boost::function<void(ui32)> cb;
void close();
CLevelWindow(const CGHeroInstance *hero, int pskill, std::vector<ui16> &skills, boost::function<void(ui32)> &callback);
~CLevelWindow();
CLevelWindow(const CGHeroInstance *hero, int pskill, std::vector<ui16> &skills, boost::function<void(ui32)> &callback); //c-tor
~CLevelWindow(); //d-tor
void activate();
void deactivate();
void selectionChanged(unsigned to);
@ -760,10 +784,10 @@ public:
class CMinorResDataBar : public IShowable, public CIntObject
{
public:
SDL_Surface *bg;
SDL_Surface *bg; //background bitmap
void show(SDL_Surface * to=NULL);
CMinorResDataBar();
~CMinorResDataBar();
CMinorResDataBar(); //c-tor
~CMinorResDataBar(); //d-tor
};
class CMarketplaceWindow : public IShowActivable, public CIntObject
@ -785,13 +809,13 @@ public:
CTradeableItem(int Type, int ID, bool Left);
};
SDL_Surface *bg;
SDL_Surface *bg; //background
std::vector<CTradeableItem*> left, right;
std::vector<std::string> rSubs;
std::vector<std::string> rSubs; //offer caption
CTradeableItem *hLeft, *hRight; //highlighted items (NULL if no highlight)
int mode,//0 - res<->res; 1 - res<->plauer; 2 - buy artifact; 3 - sell artifact
r1, r2;
r1, r2; //TODO: comment me
AdventureMapButton *ok, *max, *deal;
CSlider *slider;
@ -802,9 +826,9 @@ public:
void sliderMoved(int to);
void makeDeal();
void selectionChanged(bool side); //true == left
CMarketplaceWindow(int Mode=0);
~CMarketplaceWindow();
void setMode(int mode);
CMarketplaceWindow(int Mode=0); //c-tor
~CMarketplaceWindow(); //d-tor
void setMode(int mode); //mode setter
void clear();
};
@ -844,9 +868,9 @@ public:
void hover (bool on);
HeroPortrait(int &sel, int id, int x, int y, const CGHeroInstance *H);
void show(SDL_Surface * to = NULL);
} h1, h2;
} h1, h2; //recruitable heroes
SDL_Surface *bg;
SDL_Surface *bg; //background
CStatusBar *bar;
int selected;//0 (left) or 1 (right)

View File

@ -651,7 +651,7 @@ SDL_Surface * CMapHandler::terrainRect(int x, int y, int dx, int dy, int level,
}
if(ttiles[x+bx][y+by][level].roadbitmap.size())
{
CSDL_Ext::blit8bppAlphaTo24bpp(ttiles[x+bx][y+by][level].roadbitmap[anim%ttiles[x+bx][y+by][level].roadbitmap.size()], &genRect(sr.h, sr.w, 0, (by==-1 ? 16 : 0)),su,&sr);
CSDL_Ext::blit8bppAlphaTo24bpp(ttiles[x+bx][y+by][level].roadbitmap[anim%ttiles[x+bx][y+by][level].roadbitmap.size()], &genRect(sr.h, sr.w, 0, (by==-1 && moveY == 0 ? 16 : 0)),su,&sr);
}
}
}