「ioquake3」からの変更をインポートし、他の武器と同様にプレイヤーのマシンガンをドロップします。

This commit is contained in:
2025-07-11 09:52:27 -03:00
parent 4a446796c3
commit 473290922a
4 changed files with 113 additions and 109 deletions

View File

@@ -110,18 +110,18 @@ void TossClientItems( gentity_t *self ) {
int i;
gentity_t *drop;
// drop the weapon if not a gauntlet or machinegun
// Drop the weapon if not a gauntlet or machinegun
weapon = self->s.weapon;
//Never drop in elimination or last man standing mode!
if( g_gametype.integer == GT_ELIMINATION || g_gametype.integer == GT_LMS)
// Never drop in elimination or last man standing mode!
if( g_gametype.integer == GT_ELIMINATION || g_gametype.integer == GT_LMS) {
return;
}
// make a special check to see if they are changing to a new
// weapon that isn't the mg or gauntlet. Without this, a client
// can pick up a weapon, be killed, and not drop the weapon because
// Make a special check to see if they are changing to a new weapon that isn't the mg or gauntlet.
// Without this, a client can pick up a weapon, be killed, and not drop the weapon because
// their weapon change hasn't completed yet and they are still holding the MG.
if ( weapon == WP_MACHINEGUN || weapon == WP_GRAPPLING_HOOK ) {
if ( weapon == WP_GRAPPLING_HOOK ) {
if ( self->client->ps.weaponstate == WEAPON_DROPPING ) {
weapon = self->client->pers.cmd.weapon;
}
@@ -130,12 +130,10 @@ void TossClientItems( gentity_t *self ) {
}
}
if (g_instantgib.integer || g_rockets.integer || g_danmaku.integer || g_gametype.integer == GT_CTF_ELIMINATION || g_elimination_allgametypes.integer){
//Nothing!
}
else
if ( weapon > WP_MACHINEGUN && weapon != WP_GRAPPLING_HOOK &&
self->client->ps.ammo[ weapon ] ) {
// Never drop anything with these mutators activated, either (Instagib, Rocket Arena, Bullet Hell, etc)
if (g_instantgib.integer || g_rockets.integer || g_danmaku.integer || g_gametype.integer == GT_CTF_ELIMINATION || g_elimination_allgametypes.integer) {
return;
} else if ( weapon >= WP_MACHINEGUN && weapon != WP_GRAPPLING_HOOK && self->client->ps.ammo[ weapon ] ) {
// find the item type for this weapon
item = BG_FindItemForWeapon( weapon );

View File

@@ -33,23 +33,23 @@ DEMOS MENU
#define ART_BACK0 "menu/art/back_0"
#define ART_BACK1 "menu/art/back_1"
#define ART_BACK1 "menu/art/back_1"
#define ART_GO0 "menu/art/play_0"
#define ART_GO1 "menu/art/play_1"
#define ART_FRAMEL "menu/art/frame2_l"
#define ART_FRAMER "menu/art/frame1_r"
#define ART_ARROWS "menu/art/arrows_vert_0"
#define ART_ARROWUP "menu/art/arrows_vert_top"
#define ART_ARROWDN "menu/art/arrows_vert_bot"
#define ART_ARROWS "menu/art/arrows_horz_0"
#define ART_ARROWLEFT "menu/art/arrows_horz_left"
#define ART_ARROWRIGHT "menu/art/arrows_horz_right"
#define MAX_DEMOS 128
#define NAMEBUFSIZE ( MAX_DEMOS * 16 )
#define MAX_DEMOS 1024
#define NAMEBUFSIZE (MAX_DEMOS * 32)
#define ID_BACK 10
#define ID_GO 11
#define ID_LIST 12
#define ID_SCROLLDN 13
#define ID_SCROLLUP 14
#define ID_RIGHT 13
#define ID_LEFT 14
#define ARROWS_WIDTH 128
#define ARROWS_HEIGHT 48
@@ -72,6 +72,7 @@ typedef struct {
int numDemos;
char names[NAMEBUFSIZE];
char *demolist[MAX_DEMOS];
} demos_t;
@@ -94,47 +95,25 @@ static void Demos_MenuEvent( void *ptr, int event ) {
trap_Cmd_ExecuteText( EXEC_APPEND, va( "demo %s\n",
s_demos.list.itemnames[s_demos.list.curvalue]) );
break;
case ID_BACK:
UI_PopMenu();
break;
case ID_SCROLLUP:
ScrollList_Key( &s_demos.list, K_UPARROW );
case ID_LEFT:
ScrollList_Key( &s_demos.list, K_LEFTARROW );
break;
case ID_SCROLLDN:
ScrollList_Key( &s_demos.list, K_DOWNARROW );
break;
case ID_RIGHT:
ScrollList_Key( &s_demos.list, K_RIGHTARROW );
break;
}
}
/*
=================
UI_DemosMenu_Key
=================
*/
static sfxHandle_t UI_DemosMenu_Key( int key ) {
menucommon_s *item;
item = Menu_ItemAtCursor( &s_demos.menu );
if( key == K_MWHEELUP ) {
ScrollList_Key( &s_demos.list, K_UPARROW );
}
if( key == K_MWHEELDOWN ) {
ScrollList_Key( &s_demos.list, K_DOWNARROW );
}
return Menu_DefaultKey( &s_demos.menu, key );
}
static void meowdrawdemo( void ) {
static void UI_Demo_MenuDraw( void ) {
Menu_Draw(&s_demos.menu);
}
}
/*
===============
@@ -142,18 +121,18 @@ Demos_MenuInit
===============
*/
static void Demos_MenuInit( void ) {
int i;
int i, j;
int len;
char *demoname, extension[32];
int protocol, protocolLegacy;
memset( &s_demos, 0 ,sizeof(demos_t) );
s_demos.menu.key = UI_DemosMenu_Key;
Demos_Cache();
s_demos.menu.fullscreen = qtrue;
s_demos.menu.wrapAround = qtrue;
s_demos.menu.draw = meowdrawdemo;
s_demos.menu.wrapAround = qtrue;
s_demos.menu.draw = UI_Demo_MenuDraw;
s_demos.banner.generic.type = MTYPE_BTEXT;
s_demos.banner.generic.x = 320;
@@ -165,7 +144,7 @@ static void Demos_MenuInit( void ) {
s_demos.framel.generic.type = MTYPE_BITMAP;
s_demos.framel.generic.name = ART_FRAMEL;
s_demos.framel.generic.flags = QMF_INACTIVE;
s_demos.framel.generic.x = 0;
s_demos.framel.generic.x = 0;
s_demos.framel.generic.y = 78;
s_demos.framel.width = 256;
s_demos.framel.height = 329;
@@ -181,30 +160,30 @@ static void Demos_MenuInit( void ) {
s_demos.arrows.generic.type = MTYPE_BITMAP;
s_demos.arrows.generic.name = ART_ARROWS;
s_demos.arrows.generic.flags = QMF_INACTIVE;
s_demos.arrows.generic.x = 512+48+12;
s_demos.arrows.generic.y = 240-64+48;
s_demos.arrows.width = 64;
s_demos.arrows.height = 128;
s_demos.arrows.generic.x = 320-ARROWS_WIDTH/2;
s_demos.arrows.generic.y = 400;
s_demos.arrows.width = ARROWS_WIDTH;
s_demos.arrows.height = ARROWS_HEIGHT;
s_demos.left.generic.type = MTYPE_BITMAP;
s_demos.left.generic.flags = QMF_LEFT_JUSTIFY|QMF_PULSEIFFOCUS|QMF_MOUSEONLY;
s_demos.left.generic.x = 512+48+12;
s_demos.left.generic.y = 240-64+48;
s_demos.left.generic.id = ID_SCROLLUP;
s_demos.left.generic.x = 320-ARROWS_WIDTH/2;
s_demos.left.generic.y = 400;
s_demos.left.generic.id = ID_LEFT;
s_demos.left.generic.callback = Demos_MenuEvent;
s_demos.left.width = 64;
s_demos.left.height = 64;
s_demos.left.focuspic = ART_ARROWUP;
s_demos.left.width = ARROWS_WIDTH/2;
s_demos.left.height = ARROWS_HEIGHT;
s_demos.left.focuspic = ART_ARROWLEFT;
s_demos.right.generic.type = MTYPE_BITMAP;
s_demos.right.generic.flags = QMF_LEFT_JUSTIFY|QMF_PULSEIFFOCUS|QMF_MOUSEONLY;
s_demos.right.generic.x = 512+48+12;
s_demos.right.generic.y = 240+48;
s_demos.right.generic.id = ID_SCROLLDN;
s_demos.right.generic.x = 320;
s_demos.right.generic.y = 400;
s_demos.right.generic.id = ID_RIGHT;
s_demos.right.generic.callback = Demos_MenuEvent;
s_demos.right.width = 64;
s_demos.right.height = 64;
s_demos.right.focuspic = ART_ARROWDN;
s_demos.right.width = ARROWS_WIDTH/2;
s_demos.right.height = ARROWS_HEIGHT;
s_demos.right.focuspic = ART_ARROWRIGHT;
s_demos.back.generic.type = MTYPE_BITMAP;
s_demos.back.generic.name = ART_BACK0;
@@ -229,41 +208,67 @@ static void Demos_MenuInit( void ) {
s_demos.go.focuspic = ART_GO1;
s_demos.list.generic.type = MTYPE_SCROLLLIST;
s_demos.list.generic.flags = QMF_HIGHLIGHT_IF_FOCUS|QMF_SMALLFONT;
s_demos.list.generic.flags = QMF_PULSEIFFOCUS;
s_demos.list.generic.callback = Demos_MenuEvent;
s_demos.list.generic.id = ID_LIST;
s_demos.list.generic.x = 22;
s_demos.list.generic.y = 50;
s_demos.list.width = 70;
s_demos.list.height = 23;
Com_sprintf(extension, sizeof(extension), "dm_%d", (int)trap_Cvar_VariableValue( "protocol" ) );
s_demos.list.numitems = trap_FS_GetFileList( "demos", extension, s_demos.names, NAMEBUFSIZE );
s_demos.list.generic.x = 118;
s_demos.list.generic.y = 130;
s_demos.list.width = 16;
s_demos.list.height = 14;
s_demos.list.itemnames = (const char **)s_demos.demolist;
//s_demos.list.columns = 1;
s_demos.list.columns = 3;
if (!s_demos.list.numitems) {
strcpy( s_demos.names, "No Demos Found." );
protocolLegacy = trap_Cvar_VariableValue("com_legacyprotocol");
protocol = trap_Cvar_VariableValue("com_protocol");
if(!protocol)
protocol = trap_Cvar_VariableValue("protocol");
if(protocolLegacy == protocol)
protocolLegacy = 0;
Com_sprintf(extension, sizeof(extension), ".%s%d", DEMOEXT, protocol);
s_demos.numDemos = trap_FS_GetFileList("demos", extension, s_demos.names, ARRAY_LEN(s_demos.names));
demoname = s_demos.names;
i = 0;
for(j = 0; j < 2; j++)
{
if(s_demos.numDemos > MAX_DEMOS)
s_demos.numDemos = MAX_DEMOS;
for(; i < s_demos.numDemos; i++)
{
s_demos.list.itemnames[i] = demoname;
len = strlen(demoname);
demoname += len + 1;
}
if(!j)
{
if(protocolLegacy > 0 && s_demos.numDemos < MAX_DEMOS)
{
Com_sprintf(extension, sizeof(extension), ".%s%d", DEMOEXT, protocolLegacy);
s_demos.numDemos += trap_FS_GetFileList("demos", extension, demoname,
ARRAY_LEN(s_demos.names) - (demoname - s_demos.names));
}
else
break;
}
}
s_demos.list.numitems = s_demos.numDemos;
if(!s_demos.numDemos)
{
s_demos.list.itemnames[0] = "No Demos Found.";
s_demos.list.numitems = 1;
//degenerate case, not selectable
s_demos.go.generic.flags |= (QMF_INACTIVE|QMF_HIDDEN);
}
else if (s_demos.list.numitems > MAX_DEMOS)
s_demos.list.numitems = MAX_DEMOS;
demoname = s_demos.names;
for ( i = 0; i < s_demos.list.numitems; i++ ) {
s_demos.list.itemnames[i] = demoname;
// strip extension
len = strlen( demoname );
if (!Q_stricmp(demoname + len - 4,".dm3"))
demoname[len-4] = '\0';
// Q_strupr(demoname);
demoname += len + 1;
}
Menu_AddItem( &s_demos.menu, &s_demos.banner );
Menu_AddItem( &s_demos.menu, &s_demos.framel );
@@ -289,8 +294,8 @@ void Demos_Cache( void ) {
trap_R_RegisterShaderNoMip( ART_FRAMEL );
trap_R_RegisterShaderNoMip( ART_FRAMER );
trap_R_RegisterShaderNoMip( ART_ARROWS );
trap_R_RegisterShaderNoMip( ART_ARROWUP );
trap_R_RegisterShaderNoMip( ART_ARROWDN );
trap_R_RegisterShaderNoMip( ART_ARROWLEFT );
trap_R_RegisterShaderNoMip( ART_ARROWRIGHT );
}
/*

View File

@@ -219,7 +219,7 @@ and that local cinematics are killed
*/
void UI_MainMenu( void ) {
int y;
int style = UI_LEFT | UI_DROPSHADOW;
int style = UI_CENTER | UI_DROPSHADOW;
trap_Cvar_Set( "sv_killserver", "1" );
trap_Cvar_SetValue( "handicap", 100 ); //Reset handicap during server change, it must be ser per game
@@ -259,7 +259,7 @@ void UI_MainMenu( void ) {
s_main.singleplayer.generic.id = ID_SINGLEPLAYER;
s_main.singleplayer.generic.callback = Main_MenuEvent;
s_main.singleplayer.string = "SINGLE PLAYER";
s_main.singleplayer.color = color_orange;
s_main.singleplayer.color = color_white;
s_main.singleplayer.style = style;
y += MAIN_MENU_VERTICAL_SPACING;
@@ -270,7 +270,7 @@ void UI_MainMenu( void ) {
s_main.multiplayer.generic.id = ID_MULTIPLAYER;
s_main.multiplayer.generic.callback = Main_MenuEvent;
s_main.multiplayer.string = "MULTIPLAYER";
s_main.multiplayer.color = color_orange;
s_main.multiplayer.color = color_white;
s_main.multiplayer.style = style;
y += MAIN_MENU_VERTICAL_SPACING;
@@ -281,7 +281,7 @@ void UI_MainMenu( void ) {
s_main.setup.generic.id = ID_SETUP;
s_main.setup.generic.callback = Main_MenuEvent;
s_main.setup.string = "SETUP";
s_main.setup.color = color_orange;
s_main.setup.color = color_white;
s_main.setup.style = style;
y += MAIN_MENU_VERTICAL_SPACING;
@@ -292,7 +292,7 @@ void UI_MainMenu( void ) {
s_main.demos.generic.id = ID_DEMOS;
s_main.demos.generic.callback = Main_MenuEvent;
s_main.demos.string = "DEMOS";
s_main.demos.color = color_orange;
s_main.demos.color = color_white;
s_main.demos.style = style;
y += MAIN_MENU_VERTICAL_SPACING;
@@ -303,7 +303,7 @@ void UI_MainMenu( void ) {
s_main.challenges.generic.id = ID_CHALLENGES;
s_main.challenges.generic.callback = Main_MenuEvent;
s_main.challenges.string = "STATISTICS";
s_main.challenges.color = color_orange;
s_main.challenges.color = color_white;
s_main.challenges.style = style;
y += MAIN_MENU_VERTICAL_SPACING;
@@ -314,7 +314,7 @@ void UI_MainMenu( void ) {
s_main.mods.generic.id = ID_MODS;
s_main.mods.generic.callback = Main_MenuEvent;
s_main.mods.string = "MODS";
s_main.mods.color = color_orange;
s_main.mods.color = color_white;
s_main.mods.style = style;
y += MAIN_MENU_VERTICAL_SPACING;
@@ -325,7 +325,7 @@ void UI_MainMenu( void ) {
s_main.exit.generic.id = ID_EXIT;
s_main.exit.generic.callback = Main_MenuEvent;
s_main.exit.string = "EXIT";
s_main.exit.color = color_orange;
s_main.exit.color = color_white;
s_main.exit.style = style;
Menu_AddItem( &s_main.menu, &s_main.singleplayer );

View File

@@ -50,6 +50,7 @@ Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
#define Q3_VERSION PRODUCT_NAME " " PRODUCT_VERSION
#define MAX_TEAMNAME 32
#define DEMOEXT "dm_"
#ifdef _MSC_VER