2009-04-16 14:14:13 +03:00
# ifndef __CGAMEINTERFACE_H__
# define __CGAMEINTERFACE_H__
# include "global.h"
# include <set>
# include <vector>
# include "lib/BattleAction.h"
# include "client/FunctionList.h"
2009-04-22 21:48:56 +03:00
# include "hch/CMusicHandler.h"
2009-04-16 14:14:13 +03:00
2009-04-15 17:03:31 +03:00
/*
* CGameInterface . h , part of VCMI engine
*
* Authors : listed in file AUTHORS in main folder
*
* License : GNU General Public License v2 .0 or later
* Full text of license available in license . txt file , in main folder
*
2009-04-16 14:14:13 +03:00
*/
using namespace boost : : logic ;
class CCallback ;
class ICallback ;
class CGlobalAI ;
class CGHeroInstance ;
class Component ;
class CSelectableComponent ;
2009-07-03 22:57:14 +03:00
struct TryMoveHero ;
2009-04-16 14:14:13 +03:00
class CGHeroInstance ;
class CGTownInstance ;
class CGObjectInstance ;
2009-07-06 22:41:27 +03:00
class CGDwelling ;
2009-04-16 14:14:13 +03:00
class CCreatureSet ;
class CArmedInstance ;
2009-07-26 06:33:13 +03:00
class IShipyard ;
2009-04-16 14:14:13 +03:00
struct BattleResult ;
struct BattleAttack ;
struct BattleStackAttacked ;
2009-05-12 06:35:51 +03:00
struct SpellCast ;
2009-04-16 14:14:13 +03:00
struct SetStackEffect ;
struct HeroBonus ;
struct PackageApplied ;
2009-07-30 15:49:45 +03:00
struct SetObjectProperty ;
2009-09-01 16:54:13 +03:00
struct CatapultAttack ;
2009-09-05 17:10:26 +03:00
struct BattleStacksRemoved ;
2009-04-16 14:14:13 +03:00
class CLoadFile ;
class CSaveFile ;
template < typename Serializer > class CISer ;
template < typename Serializer > class COSer ;
class CObstacle
{
int ID ;
int position ;
//TODO: add some kind of the blockmap
} ;
struct StackState
{
StackState ( ) { attackBonus = defenseBonus = healthBonus = speedBonus = morale = luck = shotsLeft = currentHealth = 0 ; } ;
int attackBonus , defenseBonus , healthBonus , speedBonus ;
int currentHealth ;
int shotsLeft ;
std : : set < int > effects ; //IDs of spells affecting stack
int morale , luck ;
2009-07-30 15:49:45 +03:00
int dmgMultiplier ; //for ballista dmg bonus handling
2009-04-16 14:14:13 +03:00
} ;
class CGameInterface
{
public :
bool human ;
int playerID , serialID ;
std : : string dllName ;
virtual void buildChanged ( const CGTownInstance * town , int buildingID , int what ) { } ; //what: 1 - built, 2 - demolished
virtual void garrisonChanged ( const CGObjectInstance * obj ) { } ;
virtual void heroArtifactSetChanged ( const CGHeroInstance * hero ) { } ;
virtual void heroCreated ( const CGHeroInstance * ) { } ;
virtual void heroGotLevel ( const CGHeroInstance * hero , int pskill , std : : vector < ui16 > & skills , boost : : function < void ( ui32 ) > & callback ) = 0 ; //pskill is gained primary skill, interface has to choose one of given skills and call callback with selection id
virtual void heroInGarrisonChange ( const CGTownInstance * town ) { } ;
2009-08-13 04:03:11 +03:00
//virtual void heroKilled(const CGHeroInstance*){};
2009-07-03 22:57:14 +03:00
virtual void heroMoved ( const TryMoveHero & details ) { } ;
2009-08-16 18:39:18 +03:00
virtual void heroPrimarySkillChanged ( const CGHeroInstance * hero , int which , si64 val ) { } ;
2009-04-16 14:14:13 +03:00
virtual void heroManaPointsChanged ( const CGHeroInstance * hero ) { } //not called at the beginning of turn and after spell casts
virtual void heroMovePointsChanged ( const CGHeroInstance * hero ) { } //not called at the beginning of turn and after movement
virtual void heroVisitsTown ( const CGHeroInstance * hero , const CGTownInstance * town ) { } ;
virtual void init ( ICallback * CB ) { } ;
virtual void receivedResource ( int type , int val ) { } ;
2009-04-30 17:59:30 +03:00
virtual void showInfoDialog ( const std : : string & text , const std : : vector < Component * > & components , int soundID ) { } ;
2009-07-26 13:43:22 +03:00
virtual void showRecruitmentDialog ( const CGDwelling * dwelling , const CArmedInstance * dst , int level ) { }
2009-07-26 06:33:13 +03:00
virtual void showShipyardDialog ( const IShipyard * obj ) { } //obj may be town or shipyard; state: 0 - can buid, 1 - lack of resources, 2 - dest tile is blocked, 3 - no water
2009-04-30 17:59:30 +03:00
virtual void showBlockingDialog ( const std : : string & text , const std : : vector < Component > & components , ui32 askID , const int soundID , bool selection , bool cancel ) = 0 ; //Show a dialog, player must take decision. If selection then he has to choose between one of given components, if cancel he is allowed to not choose. After making choice, CCallback::selectionMade should be called with number of selected component (1 - n) or 0 for cancel (if allowed) and askID.
2009-09-09 20:49:03 +03:00
virtual void showGarrisonDialog ( const CArmedInstance * up , const CGHeroInstance * down , bool removableUnits , boost : : function < void ( ) > & onEnd ) = 0 ; //all stacks operations between these objects become allowed, interface has to call onEnd when done
2009-04-16 14:14:13 +03:00
virtual void tileHidden ( const std : : set < int3 > & pos ) { } ;
virtual void tileRevealed ( const std : : set < int3 > & pos ) { } ;
2009-07-26 06:33:13 +03:00
virtual void newObject ( const CGObjectInstance * obj ) { } ; //eg. ship built in shipyard
2009-04-16 14:14:13 +03:00
virtual void yourTurn ( ) { } ;
2009-08-13 04:03:11 +03:00
virtual void centerView ( int3 pos , int focusTime ) { } ;
2009-07-26 13:43:22 +03:00
virtual void availableCreaturesChanged ( const CGDwelling * town ) { } ;
2009-04-16 14:14:13 +03:00
virtual void heroBonusChanged ( const CGHeroInstance * hero , const HeroBonus & bonus , bool gain ) { } ; //if gain hero received bonus, else he lost it
2009-06-16 14:18:14 +03:00
virtual void requestRealized ( PackageApplied * pa ) { } ;
virtual void heroExchangeStarted ( si32 hero1 , si32 hero2 ) { } ;
2009-07-30 15:49:45 +03:00
virtual void objectPropertyChanged ( const SetObjectProperty * sop ) { } ; //eg. mine has been flagged
2009-08-04 02:53:18 +03:00
virtual void objectRemoved ( const CGObjectInstance * obj ) { } ; //eg. collected resource, picked artifact, beaten hero
virtual void playerBlocked ( int reason ) { } ; //reason: 0 - upcoming battle
2009-04-16 14:14:13 +03:00
virtual void serialize ( COSer < CSaveFile > & h , const int version ) { } ; //saving
virtual void serialize ( CISer < CLoadFile > & h , const int version ) { } ; //loading
//battle call-ins
virtual void actionFinished ( const BattleAction * action ) { } ; //occurs AFTER every action taken by any stack or by the hero
virtual void actionStarted ( const BattleAction * action ) { } ; //occurs BEFORE every action taken by any stack or by the hero
virtual BattleAction activeStack ( int stackID ) = 0 ; //called when it's turn of that stack
virtual void battleAttack ( BattleAttack * ba ) { } ; //called when stack is performing attack
virtual void battleStacksAttacked ( std : : set < BattleStackAttacked > & bsa ) { } ; //called when stack receives damage (after battleAttack())
virtual void battleEnd ( BattleResult * br ) { } ;
2009-08-04 02:53:18 +03:00
virtual void battleResultsApplied ( ) { } ; //called when all effects of last battle are applied
2009-04-16 14:14:13 +03:00
virtual void battleNewRound ( int round ) { } ; //called at the beggining of each turn, round=-1 is the tactic phase, round=0 is the first "normal" turn
virtual void battleStackMoved ( int ID , int dest , int distance , bool end ) { } ;
2009-05-12 06:35:51 +03:00
virtual void battleSpellCast ( SpellCast * sc ) { } ;
2009-04-16 14:14:13 +03:00
virtual void battleStacksEffectsSet ( SetStackEffect & sse ) { } ; //called when a specific effect is set to stacks
virtual void battleStart ( CCreatureSet * army1 , CCreatureSet * army2 , int3 tile , CGHeroInstance * hero1 , CGHeroInstance * hero2 , bool side ) { } ; //called by engine when battle starts; side=0 - left, side=1 - right
virtual void battlefieldPrepared ( int battlefieldType , std : : vector < CObstacle * > obstacles ) { } ; //called when battlefield is prepared, prior the battle beginning
2009-08-06 08:08:17 +03:00
virtual void battleStacksHealedRes ( const std : : vector < std : : pair < ui32 , ui32 > > & healedStacks ) { } ; //called when stacks are healed / resurrected first element of pair - stack id, second - healed hp
2009-08-06 17:02:21 +03:00
virtual void battleNewStackAppeared ( int stackID ) { } ; //not called at the beginning of a battle or by resurrection; called eg. when elemental is summoned
2009-08-19 13:59:42 +03:00
virtual void battleObstaclesRemoved ( const std : : set < si32 > & removedObstacles ) { } ; //called when a certain set of obstacles is removed from batlefield; IDs of them are given
2009-09-01 16:54:13 +03:00
virtual void battleCatapultAttacked ( const CatapultAttack & ca ) { } ; //called when catapult makes an attack
2009-09-05 17:10:26 +03:00
virtual void battleStacksRemoved ( const BattleStacksRemoved & bsr ) { } ; //called when certain stack is completely removed from battlefield
2009-04-16 14:14:13 +03:00
} ;
class CAIHandler
{
public :
static CGlobalAI * getNewAI ( CCallback * cb , std : : string dllname ) ;
} ;
class CGlobalAI : public CGameInterface // AI class (to derivate)
{
public :
//CGlobalAI();
virtual void yourTurn ( ) { } ;
virtual void heroKilled ( const CGHeroInstance * ) { } ;
virtual void heroCreated ( const CGHeroInstance * ) { } ;
virtual void battleStackMoved ( int ID , int dest , int distance ) { } ;
virtual void battleStackAttacking ( int ID , int dest ) { } ;
virtual void battleStackIsAttacked ( int ID , int dmg , int killed , int IDby , bool byShooting ) { } ;
virtual BattleAction activeStack ( int stackID ) { BattleAction ba ; ba . actionType = 3 ; ba . stackNumber = stackID ; return ba ; } ;
} ;
# endif // __CGAMEINTERFACE_H__