This repository has been archived on 2022-06-27. You can view files and clone it, but cannot push or open issues or pull requests.
Xash3DArchive/engine/client/cl_cmds.c

274 lines
5.0 KiB
C
Raw Normal View History

2007-11-06 22:00:00 +01:00
//=======================================================================
// Copyright XashXT Group 2007 <20>
// cl_cmds.c - client console commnds
//=======================================================================
2008-06-09 22:00:00 +02:00
#include "common.h"
2007-11-06 22:00:00 +01:00
#include "client.h"
2009-08-07 22:00:00 +02:00
#define SCRSHOT_TYPE "jpg"
2008-10-20 22:00:00 +02:00
2007-11-13 22:00:00 +01:00
/*
================
SCR_Loading_f
2008-08-04 22:00:00 +02:00
loading
2007-11-13 22:00:00 +01:00
================
*/
2008-08-04 22:00:00 +02:00
void SCR_Loading_f( void )
2007-11-13 22:00:00 +01:00
{
2007-11-14 22:00:00 +01:00
S_StopAllSounds();
2007-11-13 22:00:00 +01:00
}
2008-08-04 22:00:00 +02:00
/*
====================
CL_SetFont_f
setfont <fontname>
====================
*/
2008-01-20 22:00:00 +01:00
void CL_SetFont_f( void )
{
2008-11-15 22:00:00 +01:00
if( Cmd_Argc() < 2 )
2008-01-20 22:00:00 +01:00
{
2008-11-15 22:00:00 +01:00
Msg( "Usage: setfont <fontname> <console>\n" );
2008-01-20 22:00:00 +01:00
return;
}
2008-11-15 22:00:00 +01:00
switch(Cmd_Argc( ))
{
case 2:
Cvar_Set( "cl_font", Cmd_Argv( 1 ));
cls.clientFont = re->RegisterShader( va( "gfx/fonts/%s", cl_font->string ), SHADER_FONT );
break;
case 3:
Cvar_Set( "con_font", Cmd_Argv( 1 ));
cls.consoleFont = re->RegisterShader( va( "gfx/fonts/%s", con_font->string ), SHADER_FONT );
break;
default:
Msg( "setfont: invalid aruments\n" );
break;
}
2008-01-20 22:00:00 +01:00
}
2008-08-04 22:00:00 +02:00
/*
====================
CL_PlayVideo_f
movie <moviename>
====================
*/
void CL_PlayVideo_f( void )
{
if( Cmd_Argc() != 2 )
{
Msg( "movie <moviename>\n" );
return;
}
if( cls.state == ca_active )
{
// FIXME: get rid of this stupid alias
Cbuf_AddText(va("killserver\n; wait\n; movie %s\n;", Cmd_Argv(1)));
return;
}
SCR_PlayCinematic( Cmd_Argv(1), 0 );
}
2008-08-02 22:00:00 +02:00
/*
===============
CL_Download_f
Request a download from the server
===============
*/
void CL_Download_f( void )
{
if( Cmd_Argc() != 2 )
{
Msg( "Usage: download <filename>\n" );
return;
}
CL_CheckOrDownloadFile(Cmd_Argv(1));
}
2007-11-06 22:00:00 +01:00
/*
==================
CL_ScreenshotGetName
==================
*/
void CL_ScreenshotGetName( int lastnum, char *filename )
{
int a, b, c, d;
2009-07-03 22:00:00 +02:00
if( !filename ) return;
if( lastnum < 0 || lastnum > 9999 )
2007-11-06 22:00:00 +01:00
{
// bound
2008-10-20 22:00:00 +02:00
com.sprintf( filename, "scrshots/%s/shot9999.%s", cl.configstrings[CS_NAME], SCRSHOT_TYPE );
2007-11-06 22:00:00 +01:00
return;
}
a = lastnum / 1000;
lastnum -= a * 1000;
b = lastnum / 100;
lastnum -= b * 100;
c = lastnum / 10;
lastnum -= c * 10;
d = lastnum;
2008-10-20 22:00:00 +02:00
com.sprintf( filename, "scrshots/%s/shot%i%i%i%i.%s", cl.configstrings[CS_NAME], a, b, c, d, SCRSHOT_TYPE );
2007-11-06 22:00:00 +01:00
}
/*
==============================================================================
SCREEN SHOTS
==============================================================================
*/
/*
==================
CL_ScreenShot_f
normal screenshot
==================
*/
void CL_ScreenShot_f( void )
{
2008-07-23 22:00:00 +02:00
int i;
string checkname;
2007-11-06 22:00:00 +01:00
// scan for a free filename
2009-07-03 22:00:00 +02:00
for( i = 0; i <= 9999; i++ )
2007-11-06 22:00:00 +01:00
{
CL_ScreenshotGetName( i, checkname );
2009-07-03 22:00:00 +02:00
if( !FS_FileExists( checkname )) break;
2007-11-06 22:00:00 +01:00
}
Con_ClearNotify();
re->ScrShot( checkname, false );
}
2008-11-09 22:00:00 +01:00
void CL_EnvShot_f( void )
{
string basename;
2009-07-03 22:00:00 +02:00
if( Cmd_Argc() < 2 )
2008-11-09 22:00:00 +01:00
{
2009-07-03 22:00:00 +02:00
Msg( "Usage: envshot <shotname>\n" );
2008-11-09 22:00:00 +01:00
return;
}
Con_ClearNotify();
2009-08-11 22:00:00 +02:00
com.snprintf( basename, MAX_STRING, "env/%s", Cmd_Argv( 1 ));
2008-11-09 22:00:00 +01:00
re->EnvShot( basename, cl_envshot_size->integer, false );
}
void CL_SkyShot_f( void )
{
string basename;
2009-07-03 22:00:00 +02:00
if( Cmd_Argc() < 2 )
2008-11-09 22:00:00 +01:00
{
2009-07-03 22:00:00 +02:00
Msg( "Usage: envshot <shotname>\n" );
2008-11-09 22:00:00 +01:00
return;
}
Con_ClearNotify();
2009-08-11 22:00:00 +02:00
com.snprintf( basename, MAX_STRING, "env/%s", Cmd_Argv( 1 ));
2008-11-09 22:00:00 +01:00
re->EnvShot( basename, cl_envshot_size->integer, true );
}
2007-11-06 22:00:00 +01:00
/*
==================
CL_LevelShot_f
splash logo while map is loading
==================
*/
void CL_LevelShot_f( void )
{
2008-07-23 22:00:00 +02:00
string checkname;
2007-11-06 22:00:00 +01:00
2009-01-25 22:00:00 +01:00
if( !cl.need_levelshot ) return;
2007-11-06 22:00:00 +01:00
// check for exist
2009-08-07 22:00:00 +02:00
com.sprintf( checkname, "levelshots/%s.jpg", cl.configstrings[CS_NAME] );
2009-01-05 22:00:00 +01:00
if( !FS_FileExists( checkname )) re->ScrShot( checkname, true );
cl.need_levelshot = false; // done
2007-11-13 22:00:00 +01:00
}
/*
=================
CL_SetSky_f
Set a specific sky and rotation speed
=================
*/
void CL_SetSky_f( void )
{
2009-08-07 22:00:00 +02:00
if( Cmd_Argc() < 2 )
2007-11-13 22:00:00 +01:00
{
2009-07-03 22:00:00 +02:00
Msg( "Usage: sky <shadername>\n" );
2007-11-13 22:00:00 +01:00
return;
}
2009-07-26 22:00:00 +02:00
re->RegisterShader( Cmd_Argv(1), SHADER_SKY );
2007-11-13 22:00:00 +01:00
}
/*
================
SCR_TimeRefresh_f
2008-08-04 22:00:00 +02:00
timerefres [noflip]
2007-11-13 22:00:00 +01:00
================
*/
2008-06-30 22:00:00 +02:00
void SCR_TimeRefresh_f( void )
2007-11-13 22:00:00 +01:00
{
int i;
2009-06-22 22:00:00 +02:00
double start, stop;
double time;
2007-11-13 22:00:00 +01:00
if ( cls.state != ca_active )
return;
2009-06-22 22:00:00 +02:00
start = Sys_DoubleTime();
2007-11-13 22:00:00 +01:00
2008-06-30 22:00:00 +02:00
if( Cmd_Argc() == 2 )
2007-11-13 22:00:00 +01:00
{
// run without page flipping
2008-10-19 22:00:00 +02:00
re->BeginFrame();
2008-06-30 22:00:00 +02:00
for( i = 0; i < 128; i++ )
2007-11-13 22:00:00 +01:00
{
2009-06-22 22:00:00 +02:00
cl.refdef.viewangles[1] = i / 128.0 * 360.0f;
re->RenderFrame( &cl.refdef );
2007-11-13 22:00:00 +01:00
}
re->EndFrame();
}
else
{
2008-06-30 22:00:00 +02:00
for( i = 0; i < 128; i++ )
2007-11-13 22:00:00 +01:00
{
2009-06-22 22:00:00 +02:00
cl.refdef.viewangles[1] = i / 128.0 * 360.0f;
2007-11-13 22:00:00 +01:00
2008-10-19 22:00:00 +02:00
re->BeginFrame();
2009-07-03 22:00:00 +02:00
re->RenderFrame( &cl.refdef );
2007-11-13 22:00:00 +01:00
re->EndFrame();
}
}
2009-06-22 22:00:00 +02:00
stop = Sys_DoubleTime ();
time = (stop - start);
2008-06-30 22:00:00 +02:00
Msg( "%f seconds (%f fps)\n", time, 128 / time );
2008-08-04 22:00:00 +02:00
}
/*
=============
SCR_Viewpos_f
viewpos
=============
*/
void SCR_Viewpos_f( void )
{
2009-06-22 22:00:00 +02:00
Msg( "( %g %g %g )\n", cl.refdef.vieworg[0], cl.refdef.vieworg[1], cl.refdef.vieworg[2] );
2007-11-06 22:00:00 +01:00
}