2007-06-06 22:29:40 +03:00
// CMT.cpp : Defines the entry point for the console application.
//
2009-05-20 13:08:56 +03:00
# include "../stdafx.h"
2007-06-06 22:29:40 +03:00
# include <cmath>
2007-06-20 15:00:18 +03:00
# include <string>
2007-06-06 22:29:40 +03:00
# include <vector>
2008-07-27 20:07:37 +03:00
# include <queue>
2007-06-06 22:29:40 +03:00
# include <cmath>
2008-09-17 13:18:22 +03:00
# include <boost/algorithm/string.hpp>
2009-05-20 13:08:56 +03:00
# include <boost/filesystem/operations.hpp>
2008-07-25 20:28:28 +03:00
# include <boost/thread.hpp>
2008-12-21 21:17:35 +02:00
# include <SDL_ttf.h>
# include <SDL_mixer.h>
2008-07-25 20:28:28 +03:00
# include "SDL_Extensions.h"
2008-08-04 18:56:36 +03:00
# include "SDL_framerate.h"
# include "CGameInfo.h"
2009-05-20 13:08:56 +03:00
# include "../mapHandler.h"
# include "../global.h"
2008-08-04 18:56:36 +03:00
# include "CPreGame.h"
2008-09-17 13:18:22 +03:00
# include "CCastleInterface.h"
2009-05-20 13:08:56 +03:00
# include "../CConsoleHandler.h"
2007-08-21 16:48:18 +03:00
# include "CCursorHandler.h"
2009-05-20 13:08:56 +03:00
# include "../lib/CGameState.h"
# include "../CCallback.h"
2007-11-19 00:58:28 +02:00
# include "CPlayerInterface.h"
2007-12-06 20:55:58 +02:00
# include "CAdvmapInterface.h"
2009-05-20 13:08:56 +03:00
# include "../hch/CBuildingHandler.h"
# include "../hch/CVideoHandler.h"
# include "../hch/CHeroHandler.h"
# include "../hch/CCreatureHandler.h"
# include "../hch/CSpellHandler.h"
# include "../hch/CMusicHandler.h"
2009-06-20 04:40:52 +03:00
# include "../hch/CVideoHandler.h"
2009-05-20 13:08:56 +03:00
# include "../hch/CLodHandler.h"
# include "../hch/CDefHandler.h"
# include "../hch/CAmbarCendamo.h"
# include "../hch/CGeneralTextHandler.h"
# include "Graphics.h"
# include "Client.h"
# include "CConfigHandler.h"
# include "../lib/Connection.h"
# include "../lib/VCMI_Lib.h"
2008-12-21 21:17:35 +02:00
# include <cstdlib>
2009-05-20 13:08:56 +03:00
# include "../lib/NetPacks.h"
2008-12-21 21:17:35 +02:00
2009-02-08 17:39:26 +02:00
# if __MINGW32__
# undef main
# endif
2009-04-15 17:03:31 +03:00
/*
* CMT . cpp , 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-07-31 23:10:22 +03:00
std : : string NAME_AFFIX = " client " ;
std : : string NAME = NAME_VER + std : : string ( " ( " ) + NAME_AFFIX + ' ) ' ; //application name
2009-05-25 02:21:55 +03:00
SDL_Surface * screen = NULL , //main screen surface
* screen2 = NULL , //and hlp surface (used to store not-active interfaces layer)
* screenBuf = screen ; //points to screen (if only advmapint is present) or screen2 (else) - should be used when updating controls which are not regularly redrawed
2009-04-11 04:32:50 +03:00
2009-07-18 06:13:13 +03:00
SystemOptions GDefaultOptions ;
2009-03-12 20:50:36 +02:00
std : : queue < SDL_Event * > events ;
2008-08-04 18:56:36 +03:00
boost : : mutex eventsM ;
2009-04-11 04:32:50 +03:00
2008-08-04 18:56:36 +03:00
TTF_Font * TNRB16 , * TNR , * GEOR13 , * GEORXX , * GEORM , * GEOR16 ;
2009-04-11 04:32:50 +03:00
2008-10-19 02:20:48 +03:00
void processCommand ( const std : : string & message , CClient * & client ) ;
2009-05-17 07:14:30 +03:00
static void setScreenRes ( int w , int h , int bpp , bool fullscreen ) ;
2009-06-23 11:14:49 +03:00
void dispose ( ) ;
2009-06-24 09:56:36 +03:00
void playIntro ( ) ;
void init ( )
{
timeHandler tmh , pomtime ;
# if SDL_BYTEORDER == SDL_BIG_ENDIAN
int rmask = 0xff000000 ; int gmask = 0x00ff0000 ; int bmask = 0x0000ff00 ; int amask = 0x000000ff ;
# else
int rmask = 0x000000ff ; int gmask = 0x0000ff00 ; int bmask = 0x00ff0000 ; int amask = 0xff000000 ;
# endif
CSDL_Ext : : std32bppSurface = SDL_CreateRGBSurface ( SDL_SWSURFACE , 1 , 1 , 32 , rmask , gmask , bmask , amask ) ;
tlog0 < < " \t Initializing minors: " < < pomtime . getDif ( ) < < std : : endl ;
TTF_Init ( ) ;
atexit ( TTF_Quit ) ;
TNRB16 = TTF_OpenFont ( " Fonts " PATHSEPARATOR " tnrb.ttf " , 16 ) ;
GEOR13 = TTF_OpenFont ( " Fonts " PATHSEPARATOR " georgia.ttf " , 13 ) ;
GEOR16 = TTF_OpenFont ( " Fonts " PATHSEPARATOR " georgia.ttf " , 16 ) ;
GEORXX = TTF_OpenFont ( " Fonts " PATHSEPARATOR " tnrb.ttf " , 22 ) ;
GEORM = TTF_OpenFont ( " Fonts " PATHSEPARATOR " georgia.ttf " , 10 ) ;
if ( ! ( TNRB16 & & GEOR16 & & GEORXX & & GEORM ) )
{
tlog1 < < " One of the fonts couldn't be loaded! \n " ;
exit ( - 1 ) ;
}
THC tlog0 < < " \t Initializing fonts: " < < pomtime . getDif ( ) < < std : : endl ;
2009-07-18 06:13:13 +03:00
{
//read system options
CLoadFile settings ( " config " PATHSEPARATOR " sysopts.bin " ) ;
if ( settings . sfile )
{
settings > > GDefaultOptions ;
}
else //file not found (probably, may be also some kind of access problem
{
tlog2 < < " Warning: Cannot read system options, default settings will be used. \n " ;
//Try to create file
tlog2 < < " VCMI will try to save default system options... \n " ;
GDefaultOptions . settingsChanged ( ) ;
}
}
THC tlog0 < < " \t Loading default system settings: " < < pomtime . getDif ( ) < < std : : endl ;
2009-06-24 09:56:36 +03:00
//initializing audio
// Note: because of interface button range, volume can only be a
// multiple of 11, from 0 to 99.
CGI - > soundh = new CSoundHandler ;
CGI - > soundh - > init ( ) ;
2009-07-18 06:13:13 +03:00
CGI - > soundh - > setVolume ( GDefaultOptions . soundVolume ) ;
2009-06-24 09:56:36 +03:00
CGI - > musich = new CMusicHandler ;
CGI - > musich - > init ( ) ;
2009-07-18 06:13:13 +03:00
CGI - > musich - > setVolume ( GDefaultOptions . musicVolume ) ;
2009-06-24 09:56:36 +03:00
tlog0 < < " \t Initializing sound: " < < pomtime . getDif ( ) < < std : : endl ;
tlog0 < < " Initializing screen, fonts and sound handling: " < < tmh . getDif ( ) < < std : : endl ;
initDLL ( : : console , logfile ) ;
CGI - > setFromLib ( ) ;
CGI - > soundh - > initCreaturesSounds ( CGI - > creh - > creatures ) ;
CGI - > soundh - > initSpellsSounds ( CGI - > spellh - > spells ) ;
tlog0 < < " Initializing VCMI_Lib: " < < tmh . getDif ( ) < < std : : endl ;
pomtime . getDif ( ) ;
CGI - > curh = new CCursorHandler ;
CGI - > curh - > initCursor ( ) ;
CGI - > curh - > show ( ) ;
tlog0 < < " Screen handler: " < < pomtime . getDif ( ) < < std : : endl ;
pomtime . getDif ( ) ;
graphics = new Graphics ( ) ;
2009-07-06 22:41:27 +03:00
graphics - > loadHeroAnims ( ) ;
2009-06-24 09:56:36 +03:00
tlog0 < < " \t Main graphics: " < < tmh . getDif ( ) < < std : : endl ;
tlog0 < < " Initializing game graphics: " < < tmh . getDif ( ) < < std : : endl ;
CMessage : : init ( ) ;
tlog0 < < " Message handler: " < < tmh . getDif ( ) < < std : : endl ;
CPG = new CPreGame ( ) ; //main menu and submenus
tlog0 < < " Initialization CPreGame (together): " < < tmh . getDif ( ) < < std : : endl ;
}
2009-04-14 15:47:09 +03:00
2008-08-04 12:05:52 +03:00
# ifndef __GNUC__
2008-06-30 03:06:41 +03:00
int _tmain ( int argc , _TCHAR * argv [ ] )
2008-08-04 18:56:36 +03:00
# else
2008-09-10 00:10:24 +03:00
int main ( int argc , char * * argv )
2008-08-04 18:56:36 +03:00
# endif
2009-02-08 17:39:26 +02:00
{
2008-11-09 00:29:19 +02:00
tlog0 < < " Starting... " < < std : : endl ;
2009-06-24 09:56:36 +03:00
timeHandler total , pomtime ;
2008-10-19 02:20:48 +03:00
CClient * client = NULL ;
2008-11-15 15:44:32 +02:00
std : : cout . flags ( std : : ios : : unitbuf ) ;
2008-11-09 00:29:19 +02:00
logfile = new std : : ofstream ( " VCMI_Client_log.txt " ) ;
2009-06-23 11:14:49 +03:00
console = new CConsoleHandler ;
2009-07-11 02:40:10 +03:00
* console - > cb = boost : : bind ( & processCommand , _1 , boost : : ref ( client ) ) ;
2009-06-23 11:14:49 +03:00
console - > start ( ) ;
atexit ( dispose ) ;
2008-11-09 00:29:19 +02:00
tlog0 < < " Creating console and logfile: " < < pomtime . getDif ( ) < < std : : endl ;
conf . init ( ) ;
tlog0 < < " Loading settings: " < < pomtime . getDif ( ) < < std : : endl ;
2008-09-19 11:16:19 +03:00
tlog0 < < NAME < < std : : endl ;
2008-11-09 00:29:19 +02:00
2008-06-16 13:51:14 +03:00
srand ( time ( NULL ) ) ;
CPG = NULL ;
atexit ( SDL_Quit ) ;
2009-06-24 09:56:36 +03:00
CGI = new CGameInfo ; //contains all global informations about game (texts, lodHandlers, map handler itp.)
2008-09-17 13:18:22 +03:00
if ( SDL_Init ( SDL_INIT_VIDEO | SDL_INIT_TIMER | SDL_INIT_AUDIO ) = = 0 )
2007-06-06 22:29:40 +03:00
{
2009-04-14 15:47:09 +03:00
setScreenRes ( 800 , 600 , conf . cc . bpp , conf . cc . fullscreen ) ;
tlog0 < < " \t Initializing screen: " < < pomtime . getDif ( ) < < std : : endl ;
2009-06-23 11:14:49 +03:00
2009-06-20 04:40:52 +03:00
// Initialize video
2009-06-24 09:56:36 +03:00
CGI - > videoh = new CVideoPlayer ;
2009-06-20 04:40:52 +03:00
tlog0 < < " \t Initializing video: " < < pomtime . getDif ( ) < < std : : endl ;
2009-06-24 09:56:36 +03:00
//we can properly play intro only in the main thread, so we have to move loading to the separate thread
boost : : thread loading ( init ) ;
playIntro ( ) ;
SDL_FillRect ( screen , NULL , 0 ) ;
SDL_Flip ( screen ) ;
loading . join ( ) ;
2009-01-07 21:40:19 +02:00
tlog0 < < " Initialization of VCMI (together): " < < total . getDif ( ) < < std : : endl ;
2008-09-12 11:51:46 +03:00
2009-05-29 06:03:19 +03:00
2009-06-24 09:56:36 +03:00
SDL_EnableKeyRepeat ( SDL_DEFAULT_REPEAT_DELAY , SDL_DEFAULT_REPEAT_INTERVAL ) ;
CGI - > musich - > playMusic ( musicBase : : mainMenu , - 1 ) ;
CPG - > showMainMenu ( ) ;
StartInfo * options = new StartInfo ( CPG - > runLoop ( ) ) ;
2008-08-09 02:02:32 +03:00
2009-02-01 22:31:41 +02:00
if ( screen - > w ! = conf . cc . resx | | screen - > h ! = conf . cc . resy )
{
2009-04-14 15:47:09 +03:00
setScreenRes ( conf . cc . resx , conf . cc . resy , conf . cc . bpp , conf . cc . fullscreen ) ;
2009-02-01 22:31:41 +02:00
}
2009-01-11 00:08:18 +02:00
CClient cl ;
if ( options - > mode = = 0 ) //new game
2008-09-12 11:51:46 +03:00
{
2009-06-24 09:56:36 +03:00
pomtime . getDif ( ) ;
2009-02-08 17:39:26 +02:00
char portc [ 10 ] ;
2009-01-11 00:08:18 +02:00
SDL_itoa ( conf . cc . port , portc , 10 ) ;
CClient : : runServer ( portc ) ;
2009-06-24 09:56:36 +03:00
tlog0 < < " Preparing shared memory and starting server: " < < pomtime . getDif ( ) < < std : : endl ;
2009-01-11 00:08:18 +02:00
2009-06-24 09:56:36 +03:00
pomtime . getDif ( ) ; //reset timers
2009-01-11 00:08:18 +02:00
CConnection * c = NULL ;
//wait until server is ready
tlog0 < < " Waiting for server... " ;
2009-01-30 23:28:02 +02:00
cl . waitForServer ( ) ;
2009-06-24 09:56:36 +03:00
tlog0 < < pomtime . getDif ( ) < < std : : endl ;
2009-01-11 00:08:18 +02:00
while ( ! c )
2008-09-12 11:51:46 +03:00
{
2009-01-11 00:08:18 +02:00
try
{
tlog0 < < " Establishing connection... \n " ;
c = new CConnection ( conf . cc . server , portc , NAME ) ;
}
catch ( . . . )
{
tlog1 < < " \n Cannot establish connection! Retrying within 2 seconds " < < std : : endl ;
SDL_Delay ( 2000 ) ;
}
2008-09-12 11:51:46 +03:00
}
2009-06-24 09:56:36 +03:00
THC tlog0 < < " \t Connecting to the server: " < < pomtime . getDif ( ) < < std : : endl ;
2009-01-11 00:08:18 +02:00
cl . newGame ( c , options ) ;
client = & cl ;
2009-06-24 09:56:36 +03:00
CGI - > musich - > stopMusic ( ) ;
2009-01-11 00:08:18 +02:00
boost : : thread t ( boost : : bind ( & CClient : : run , & cl ) ) ;
2008-09-12 11:51:46 +03:00
}
2009-01-11 00:08:18 +02:00
else //load game
2008-08-09 02:02:32 +03:00
{
2009-01-11 00:08:18 +02:00
std : : string fname = options - > mapname ;
boost : : algorithm : : erase_last ( fname , " .vlgm1 " ) ;
cl . load ( fname ) ;
client = & cl ;
2009-06-24 09:56:36 +03:00
CGI - > musich - > stopMusic ( ) ;
2009-01-11 00:08:18 +02:00
boost : : thread t ( boost : : bind ( & CClient : : run , & cl ) ) ;
2008-08-09 02:02:32 +03:00
}
2009-01-11 00:08:18 +02:00
2009-03-12 20:50:36 +02:00
SDL_Event * ev = NULL ;
2008-07-27 20:07:37 +03:00
while ( 1 ) //main SDL events loop
{
2009-03-12 20:50:36 +02:00
ev = new SDL_Event ( ) ;
2009-04-14 13:46:42 +03:00
int ret = SDL_WaitEvent ( ev ) ;
if ( ret = = 0 | | ( ev - > type = = SDL_QUIT ) | | ( ev - > type = = SDL_KEYDOWN & & ev - > key . keysym . sym = = SDLK_F4 & & ( ev - > key . keysym . mod & KMOD_ALT ) ) )
2008-07-27 20:07:37 +03:00
{
2009-04-11 04:32:50 +03:00
LOCPLINT - > pim - > lock ( ) ;
2008-08-25 13:25:16 +03:00
cl . close ( ) ;
2009-06-23 11:14:49 +03:00
console - > end ( ) ;
2008-08-25 13:25:16 +03:00
SDL_Delay ( 750 ) ;
2008-09-19 11:16:19 +03:00
tlog0 < < " Ending... \n " ;
2008-12-21 21:17:35 +02:00
exit ( EXIT_SUCCESS ) ;
2008-07-27 20:07:37 +03:00
}
2009-03-12 20:50:36 +02:00
else if ( ev - > type = = SDL_KEYDOWN & & ev - > key . keysym . sym = = SDLK_F4 )
2009-01-07 21:40:19 +02:00
{
2009-04-14 15:47:09 +03:00
boost : : unique_lock < boost : : recursive_mutex > lock ( * LOCPLINT - > pim ) ;
2009-01-25 18:19:34 +02:00
bool full = ! ( screen - > flags & SDL_FULLSCREEN ) ;
2009-04-14 15:47:09 +03:00
setScreenRes ( conf . cc . resx , conf . cc . resy , conf . cc . bpp , full ) ;
LOCPLINT - > totalRedraw ( ) ;
2009-01-07 21:40:19 +02:00
}
2008-07-27 20:07:37 +03:00
eventsM . lock ( ) ;
events . push ( ev ) ;
eventsM . unlock ( ) ;
2008-08-04 18:56:36 +03:00
}
2007-06-06 22:29:40 +03:00
}
else
{
2008-09-19 11:16:19 +03:00
tlog1 < < " Something was wrong: " < < SDL_GetError ( ) < < std : : endl ;
2007-06-06 22:29:40 +03:00
return - 1 ;
}
2007-06-07 20:45:56 +03:00
}
2008-09-17 13:18:22 +03:00
2008-10-19 02:20:48 +03:00
void processCommand ( const std : : string & message , CClient * & client )
2008-09-17 13:18:22 +03:00
{
std : : istringstream readed ;
readed . str ( message ) ;
std : : string cn ; //command name
readed > > cn ;
int3 src , dst ;
2008-12-21 21:17:35 +02:00
// int heronum;//TODO use me
2008-09-17 13:18:22 +03:00
int3 dest ;
2009-04-04 22:26:41 +03:00
if ( LOCPLINT & & LOCPLINT - > cingconsole )
LOCPLINT - > cingconsole - > print ( message ) ;
2008-09-17 13:18:22 +03:00
if ( message = = std : : string ( " die, fool " ) )
2008-12-21 21:17:35 +02:00
exit ( EXIT_SUCCESS ) ;
2008-09-17 13:18:22 +03:00
else if ( cn = = std : : string ( " activate " ) )
{
int what ;
readed > > what ;
switch ( what )
{
case 0 :
2009-04-14 15:47:09 +03:00
LOCPLINT - > topInt ( ) - > activate ( ) ;
2008-09-17 13:18:22 +03:00
break ;
case 1 :
LOCPLINT - > adventureInt - > activate ( ) ;
break ;
case 2 :
LOCPLINT - > castleInt - > activate ( ) ;
break ;
}
}
2008-11-16 03:06:15 +02:00
else if ( cn = = " save " )
{
std : : string fname ;
readed > > fname ;
client - > save ( fname ) ;
}
2009-07-20 11:18:33 +03:00
else if ( cn = = " list " )
{
if ( CPG )
for ( int i = 0 ; i < CPG - > ourScenSel - > mapsel . ourGames . size ( ) ; i + + )
tlog0 < < i < < " . \t " < < CPG - > ourScenSel - > mapsel . ourGames [ i ] - > filename < < std : : endl ;
}
2009-01-11 00:08:18 +02:00
else if ( cn = = " load " )
{
std : : string fname ;
readed > > fname ;
client - > load ( fname ) ;
}
2009-07-20 11:18:33 +03:00
else if ( cn = = " ln " )
{
int num ;
readed > > num ;
std : : string & name = CPG - > ourScenSel - > mapsel . ourGames [ num ] - > filename ;
client - > load ( name . substr ( 0 , name . size ( ) - 6 ) ) ;
}
2009-02-01 22:31:41 +02:00
else if ( cn = = " resolution " )
{
2009-08-01 22:25:12 +03:00
if ( LOCPLINT )
{
tlog1 < < " Resolution can be set only before starting the game. \n " ;
return ;
}
2009-02-01 22:31:41 +02:00
std : : map < std : : pair < int , int > , config : : GUIOptions > : : iterator j ;
int i = 1 , hlp = 1 ;
tlog4 < < " Available screen resolutions: \n " ;
for ( j = conf . guiOptions . begin ( ) ; j ! = conf . guiOptions . end ( ) ; j + + )
tlog4 < < i + + < < " . " < < j - > first . first < < " x " < < j - > first . second < < std : : endl ;
tlog4 < < " Type number from 1 to " < < i - 1 < < " to set appropriate resolution or 0 to cancel. \n " ;
std : : cin > > i ;
2009-06-02 01:31:11 +03:00
if ( i < 0 | | i > conf . guiOptions . size ( ) | | std : : cin . bad ( ) | | std : : cin . fail ( ) )
2009-02-09 18:18:48 +02:00
{
2009-06-02 01:31:11 +03:00
std : : cin . clear ( ) ;
2009-02-09 18:18:48 +02:00
tlog1 < < " Invalid resolution ID! Not a number between 0 and " < < conf . guiOptions . size ( ) < < " . No settings changed. \n " ;
}
2009-06-02 01:31:11 +03:00
else if ( ! i )
{
return ;
}
2009-02-01 22:31:41 +02:00
else
{
2009-02-09 18:18:48 +02:00
for ( j = conf . guiOptions . begin ( ) ; j ! = conf . guiOptions . end ( ) & & hlp + + < i ; j + + ) ; //move j to the i-th resolution info
2009-02-01 22:31:41 +02:00
conf . cc . resx = j - > first . first ;
conf . cc . resy = j - > first . second ;
tlog0 < < " Screen resolution set to " < < conf . cc . resx < < " x " < < conf . cc . resy < < " . It will be aplied when the game starts. \n " ;
}
}
2008-09-17 13:18:22 +03:00
else if ( message = = " get txt " )
{
boost : : filesystem : : create_directory ( " Extracted_txts " ) ;
2008-09-19 11:16:19 +03:00
tlog0 < < " Command accepted. Opening .lod file... \t " ;
2008-09-17 13:18:22 +03:00
CLodHandler * txth = new CLodHandler ;
2008-11-01 00:41:22 +02:00
txth - > init ( std : : string ( DATA_DIR " Data " PATHSEPARATOR " H3bitmap.lod " ) , " " ) ;
2008-09-19 11:16:19 +03:00
tlog0 < < " done. \n Scanning .lod file \n " ;
2008-09-17 13:18:22 +03:00
int curp = 0 ;
2008-10-18 14:41:24 +03:00
std : : string pattern = " .TXT " , pom ;
2008-09-17 13:18:22 +03:00
for ( int i = 0 ; i < txth - > entries . size ( ) ; i + + )
{
2008-10-18 14:41:24 +03:00
pom = txth - > entries [ i ] . nameStr ;
2008-09-17 13:18:22 +03:00
if ( boost : : algorithm : : find_last ( pom , pattern ) )
{
2009-06-09 08:02:22 +03:00
txth - > extractFile ( std : : string ( " Extracted_txts " PATHSEPARATOR ) + pom , pom ) ;
2008-09-17 13:18:22 +03:00
}
if ( i % 8 ) continue ;
int p2 = ( ( float ) i / ( float ) txth - > entries . size ( ) ) * ( float ) 100 ;
if ( p2 ! = curp )
{
curp = p2 ;
2008-09-19 11:16:19 +03:00
tlog0 < < " \r " < < curp < < " % " ;
2008-09-17 13:18:22 +03:00
}
}
2008-09-19 11:16:19 +03:00
tlog0 < < " \r Extracting done :) \n " ;
2008-09-17 13:18:22 +03:00
}
2009-07-31 23:10:22 +03:00
else if ( cn = = " crash " )
{
int * ptr = NULL ;
* ptr = 666 ;
//disaster!
}
2008-10-19 02:20:48 +03:00
else if ( client & & client - > serv & & client - > serv - > connected ) //send to server
{
2009-04-04 22:26:41 +03:00
PlayerMessage pm ( LOCPLINT - > playerID , message ) ;
* client - > serv < < & pm ;
2008-10-19 02:20:48 +03:00
}
2009-04-14 15:47:09 +03:00
}
2009-06-24 09:56:36 +03:00
//plays intro, ends when intro is over or button has been pressed (handles events)
void playIntro ( )
{
if ( CGI - > videoh - > openAndPlayVideo ( " 3DOLOGO.SMK " , 60 , 40 , screen , true ) )
{
CGI - > videoh - > openAndPlayVideo ( " AZVS.SMK " , 60 , 80 , screen , true ) ;
}
}
2009-06-23 11:14:49 +03:00
void dispose ( )
{
delete logfile ;
delete console ;
}
2009-05-17 07:14:30 +03:00
static void setScreenRes ( int w , int h , int bpp , bool fullscreen )
2009-04-14 15:47:09 +03:00
{
2009-05-17 07:14:30 +03:00
if ( screen ) //screen has been already initialized
2009-04-14 15:47:09 +03:00
SDL_QuitSubSystem ( SDL_INIT_VIDEO ) ;
SDL_InitSubSystem ( SDL_INIT_VIDEO ) ;
2009-05-17 07:14:30 +03:00
// VCMI will only work with 3 or 4 bytes per pixel
if ( bpp < 24 ) bpp = 24 ;
if ( bpp > 32 ) bpp = 32 ;
// Try to use the best screen depth for the display
2009-07-16 02:58:47 +03:00
int suggestedBpp = SDL_VideoModeOK ( w , h , bpp , SDL_SWSURFACE | ( fullscreen ? SDL_FULLSCREEN : 0 ) ) ;
if ( suggestedBpp = = 0 )
{
tlog2 < < " Warning: SDL says that " < < w < < " x " < < h < < " resolution is not available! \n " ;
suggestedBpp = bpp ;
}
else if ( suggestedBpp ! = bpp )
{
tlog2 < < " Warning: SDL says that " < < bpp < < " bpp is wrong and suggests " < < suggestedBpp < < std : : endl ;
}
if ( ( screen = SDL_SetVideoMode ( w , h , suggestedBpp , SDL_SWSURFACE | ( fullscreen ? SDL_FULLSCREEN : 0 ) ) ) = = NULL )
{
tlog1 < < " Requested screen resolution is not available ( " < < w < < " x " < < h < < " x " < < suggestedBpp < < " bpp) \n " ;
2009-05-17 07:14:30 +03:00
throw " Requested screen resolution is not available \n " ;
}
2009-04-14 15:47:09 +03:00
if ( screen2 )
SDL_FreeSurface ( screen2 ) ;
screen2 = CSDL_Ext : : copySurface ( screen ) ;
SDL_EnableUNICODE ( 1 ) ;
SDL_WM_SetCaption ( NAME . c_str ( ) , " " ) ; //set window title
SDL_ShowCursor ( SDL_DISABLE ) ;
2009-05-06 05:32:36 +03:00
}