mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-01 06:01:00 +00:00
fad3606c44
git-svn-id: https://svn.eduke32.com/eduke32@5198 1a8010ca-5511-0410-912e-c29ae57300e0
3715 lines
99 KiB
C
3715 lines
99 KiB
C
//-------------------------------------------------------------------------
|
|
/*
|
|
Copyright (C) 1996, 2005 - 3D Realms Entertainment
|
|
|
|
This file is NOT part of Shadow Warrior version 1.2
|
|
However, it is either an older version of a file that is, or is
|
|
some test code written during the development of Shadow Warrior.
|
|
This file is provided purely for educational interest.
|
|
|
|
Shadow Warrior is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU General Public License
|
|
as published by the Free Software Foundation; either version 2
|
|
of the License, or (at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
See the GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
Prepared for public release: 03/28/2005 - Charlie Wiederhold, 3D Realms
|
|
*/
|
|
//-------------------------------------------------------------------------
|
|
|
|
#include "build.h"
|
|
#include "editor.h"
|
|
#include "cache1d.h"
|
|
|
|
#include "keys.h"
|
|
#include "names2.h"
|
|
#include "game.h"
|
|
#include "tags.h"
|
|
#include "pal.h"
|
|
|
|
#define M_RED 102
|
|
#define M_BLUE 198
|
|
|
|
|
|
void ToggleFAF(void); // brooms.c
|
|
void FAF_AfterDrawRooms(void); // brooms.c
|
|
void ResetBuildFAF(void); // brooms.c
|
|
|
|
|
|
// Jim's Vars
|
|
|
|
#define BUILD_DEV_VER 0 // True if this is the developer version of build.
|
|
|
|
|
|
// Idle time counter
|
|
//int idleclock=0; // How much time is spent not touching the keyboard.
|
|
//int slackerclock=0; // Accumulated no keyboard time, adds every 30 secs
|
|
//int oldtotalclock=0;
|
|
|
|
// Sprite lists
|
|
int numsprite[MAXSPRITES], multisprite[MAXSPRITES];
|
|
|
|
// Next available tag tracking vars
|
|
short siNextTag = 1; // Shows next available tag if there
|
|
// is an open gap in tagging
|
|
short siNextEndTag = 1; // Shows the hightest possible next
|
|
// tag
|
|
|
|
int loaded_numwalls;
|
|
// Boolean flags used for sprite searching
|
|
SWBOOL bFindPicNum = TRUE; // Default
|
|
SWBOOL bFindHiTag = FALSE;
|
|
SWBOOL bFindLowTag = FALSE;
|
|
SWBOOL bVoxelsOn = TRUE; // Turn voxels on by default
|
|
SWBOOL bSpinBobVoxels = TRUE; // Do twizzly stuff to voxels
|
|
SWBOOL bAutoSize = TRUE; // Autosizing on/off
|
|
|
|
int nextvoxid = 0;
|
|
char *defsfilename = "sw.def";
|
|
|
|
// Globals used to hold current sprite type being searched for.
|
|
short FindPicNum = 0;
|
|
short FindSpriteNum = 0;
|
|
|
|
// My Function Prototypes
|
|
void ContextHelp(short spritenum);
|
|
void LoadKVXFromScript(char *filename);
|
|
|
|
//void LogUserTime( SWBOOL bIsLoggingIn );
|
|
|
|
// voxelarray format is:
|
|
// spritenumber, voxelnumber
|
|
extern int aVoxelArray[MAXSPRITES];
|
|
|
|
// Ken ALT highlighted array
|
|
extern short highlightsector[MAXSECTORS];
|
|
extern short highlightsectorcnt;
|
|
|
|
|
|
int DispMono = FALSE;
|
|
|
|
//
|
|
// KENS setup variables
|
|
//
|
|
|
|
#define MAX_STAG_INFO 1024
|
|
typedef struct
|
|
{
|
|
char name[64];
|
|
int flags;
|
|
} STAG_INFO, *STAG_INFOp;
|
|
|
|
STAG_INFO StagInfo[MAX_STAG_INFO];
|
|
|
|
void PrintStatus(char *string, int num, char x, char y, char color);
|
|
|
|
#define NUMOPTIONS 8
|
|
char option[NUMOPTIONS] = {0, 0, 0, 0, 0, 0, 1, 0};
|
|
char keys[NUMBUILDKEYS] =
|
|
{
|
|
0xc8, 0xd0, 0xcb, 0xcd, 0x2a, 0x9d, 0x1d, 0x39,
|
|
0x1e, 0x2c, 0xd1, 0xc9, 0x33, 0x34,
|
|
0x9c, 0x1c, 0xd, 0xc, 0xf, 0x45
|
|
};
|
|
|
|
#define MODE_3D 200
|
|
|
|
extern short pointhighlight, linehighlight;
|
|
extern short defaultspritecstat;
|
|
extern int posx, posy, posz;
|
|
extern short cursectnum;
|
|
extern short ang;
|
|
extern int horiz;
|
|
extern short asksave;
|
|
short ExtSectorTag[MAXSECTORS][4];
|
|
static char tempbuf[256];
|
|
char ds[256];
|
|
|
|
enum
|
|
{
|
|
CAPTION_NONE,
|
|
CAPTION_DEFAULT,
|
|
CAPTION_NAMES,
|
|
CAPTION_MOST,
|
|
CAPTION_ALL,
|
|
CAPTION_MAX,
|
|
};
|
|
short CaptionMode = CAPTION_NAMES;
|
|
|
|
|
|
// RIGHT ALT selection key
|
|
extern short highlightsector[MAXSECTORS];
|
|
extern short highlightsectorcnt;
|
|
|
|
// RIGHT SHIFT selection key
|
|
#define SPRITE_FLAG 16384
|
|
extern short highlight[MAXWALLS]; // sprite nums are + 16348
|
|
extern short highlightcnt;
|
|
|
|
// Variables copied with the tab key
|
|
extern short temppicnum, tempcstat, templotag, temphitag, tempextra;
|
|
|
|
void SectorMoveFloorZ(int);
|
|
void SectorMoveCeilingZ(int);
|
|
|
|
void BuildStagTable(void);
|
|
void Message(char *string, char color);
|
|
void ShowMessage(void);
|
|
void ShadeMenu(void);
|
|
void FindNextTag(void);
|
|
void ShowNextTag(void);
|
|
void FindSprite(short picnum, short findspritenum);
|
|
void FindNextSprite(short picnum);
|
|
void SetClipdist2D(void);
|
|
void DrawClipBox(short spritenum);
|
|
|
|
//printext16 parameters:
|
|
//printext16(int xpos, int ypos, short col, short backcol,
|
|
// char name[82], char fontsize)
|
|
// xpos 0-639 (top left)
|
|
// ypos 0-479 (top left)
|
|
// col 0-15
|
|
// backcol 0-15, -1 is transparent background
|
|
// name
|
|
// fontsize 0=8*8, 1=3*5
|
|
|
|
//drawline16 parameters:
|
|
// drawline16(int x1, int y1, int x2, int y2, char col)
|
|
// x1, x2 0-639
|
|
// y1, y2 0-143 (status bar is 144 high, origin is top-left of STATUS BAR)
|
|
// col 0-15
|
|
|
|
//Detecting 2D / 3D mode:
|
|
// qsetmode is 200 in 3D mode
|
|
// qsetmode is 350/480 in 2D mode
|
|
//
|
|
//You can read these variables when F5-F8 is pressed in 3D mode only:
|
|
//
|
|
// If (searchstat == 0) WALL searchsector=sector, searchwall=wall
|
|
// If (searchstat == 1) CEILING searchsector=sector
|
|
// If (searchstat == 2) FLOOR searchsector=sector
|
|
// If (searchstat == 3) SPRITE searchsector=sector, searchwall=sprite
|
|
// If (searchstat == 4) MASKED WALL searchsector=sector, searchwall=wall
|
|
//
|
|
// searchsector is the sector of the selected item for all 5 searchstat's
|
|
//
|
|
// searchwall is undefined if searchstat is 1 or 2
|
|
// searchwall is the wall if searchstat = 0 or 4
|
|
// searchwall is the sprite if searchstat = 3 (Yeah, I know - it says wall,
|
|
// but trust me, it's the sprite number)
|
|
|
|
void
|
|
ResetKeys(void)
|
|
{
|
|
unsigned i;
|
|
|
|
for (i = 0; i < SIZ(keystatus); i++)
|
|
{
|
|
KEY_PRESSED(i) = 0;
|
|
}
|
|
}
|
|
|
|
void ExtPreCheckKeys(void)
|
|
{
|
|
ToggleFAF();
|
|
}
|
|
|
|
|
|
// Toggle sprites on/off. Good for frame rate checks.
|
|
SWBOOL DebugActorFreeze = 0;
|
|
|
|
void
|
|
ToggleSprites()
|
|
{
|
|
spritetype *tspr;
|
|
|
|
|
|
DebugActorFreeze++;
|
|
if (DebugActorFreeze > 2)
|
|
DebugActorFreeze = 0;
|
|
|
|
// Don't show any sprites, period
|
|
if (DebugActorFreeze == 2)
|
|
{
|
|
short i;
|
|
|
|
for (i = 0, tspr = &sprite[0]; i < MAXSPRITES; i++, tspr++)
|
|
{
|
|
SET(tspr->cstat, CSTAT_SPRITE_INVISIBLE);
|
|
// if (TEST(tspr->cstat, CSTAT_SPRITE_BLOCK))
|
|
// {
|
|
// SET(tspr->extra, SPRX_BLOCK);
|
|
// RESET(tspr->cstat, CSTAT_SPRITE_BLOCK);
|
|
// }
|
|
}
|
|
}
|
|
|
|
|
|
// Show all sprites except actors and ST's
|
|
if (DebugActorFreeze == 1)
|
|
{
|
|
short i;
|
|
|
|
for (i = 0, tspr = &sprite[0]; i < MAXSPRITES; i++, tspr++)
|
|
{
|
|
switch (tspr->picnum)
|
|
{
|
|
case COOLIE_RUN_R0:
|
|
case ZOMBIE_RUN_R0:
|
|
case NINJA_RUN_R0:
|
|
case SERP_RUN_R0:
|
|
case LAVA_RUN_R0:
|
|
case SKEL_RUN_R0:
|
|
case GORO_RUN_R0:
|
|
case HORNET_RUN_R0:
|
|
case SKULL_R0:
|
|
case RIPPER_RUN_R0:
|
|
case 2307: // ST1
|
|
case 2308: // ST2
|
|
case 2309: // QJ
|
|
case 2310: // QJD
|
|
case 2311: // QSJ
|
|
case 2312: // QSCN
|
|
case 2313: // QEXIT
|
|
SET(tspr->cstat, CSTAT_SPRITE_INVISIBLE);
|
|
// if (TEST(tspr->cstat, CSTAT_SPRITE_BLOCK))
|
|
// {
|
|
// SET(tspr->extra, SPRX_BLOCK);
|
|
// RESET(tspr->cstat, CSTAT_SPRITE_BLOCK);
|
|
// }
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
// Show all sprites
|
|
if (DebugActorFreeze == FALSE)
|
|
{
|
|
short i;
|
|
|
|
for (i = 0, tspr = &sprite[0]; i < MAXSPRITES; i++, tspr++)
|
|
{
|
|
RESET(tspr->cstat, CSTAT_SPRITE_INVISIBLE);
|
|
// if (TEST(tspr->extra, SPRX_BLOCK))
|
|
// SET(tspr->cstat, CSTAT_SPRITE_BLOCK);
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
void
|
|
DoAutoSize(spritetype *tspr)
|
|
{
|
|
short i;
|
|
|
|
if (!bAutoSize)
|
|
return;
|
|
|
|
switch (tspr->picnum)
|
|
{
|
|
case ICON_STAR: // 1793
|
|
break;
|
|
case ICON_UZI: // 1797
|
|
tspr->xrepeat = 43;
|
|
tspr->yrepeat = 40;
|
|
break;
|
|
case ICON_UZIFLOOR: // 1807
|
|
tspr->xrepeat = 43;
|
|
tspr->yrepeat = 40;
|
|
break;
|
|
case ICON_LG_UZI_AMMO: // 1799
|
|
break;
|
|
case ICON_HEART: // 1824
|
|
break;
|
|
case ICON_HEART_LG_AMMO: // 1820
|
|
break;
|
|
case ICON_GUARD_HEAD: // 1814
|
|
break;
|
|
case ICON_FIREBALL_LG_AMMO: // 3035
|
|
break;
|
|
case ICON_ROCKET: // 1843
|
|
break;
|
|
case ICON_SHOTGUN: // 1794
|
|
tspr->xrepeat = 57;
|
|
tspr->yrepeat = 58;
|
|
break;
|
|
case ICON_LG_ROCKET: // 1796
|
|
break;
|
|
case ICON_LG_SHOTSHELL: // 1823
|
|
break;
|
|
case ICON_MICRO_GUN: // 1818
|
|
break;
|
|
case ICON_MICRO_BATTERY: // 1800
|
|
break;
|
|
case ICON_GRENADE_LAUNCHER: // 1817
|
|
tspr->xrepeat = 54;
|
|
tspr->yrepeat = 52;
|
|
break;
|
|
case ICON_LG_GRENADE: // 1831
|
|
break;
|
|
case ICON_LG_MINE: // 1842
|
|
break;
|
|
case ICON_RAIL_GUN: // 1811
|
|
tspr->xrepeat = 50;
|
|
tspr->yrepeat = 54;
|
|
break;
|
|
case ICON_RAIL_AMMO: // 1812
|
|
break;
|
|
case ICON_SM_MEDKIT: // 1802
|
|
break;
|
|
case ICON_MEDKIT: // 1803
|
|
break;
|
|
case ICON_CHEMBOMB:
|
|
tspr->xrepeat = 64;
|
|
tspr->yrepeat = 47;
|
|
break;
|
|
case ICON_FLASHBOMB:
|
|
tspr->xrepeat = 32;
|
|
tspr->yrepeat = 34;
|
|
break;
|
|
case ICON_NUKE:
|
|
break;
|
|
case ICON_CALTROPS:
|
|
tspr->xrepeat = 37;
|
|
tspr->yrepeat = 30;
|
|
break;
|
|
case ICON_BOOSTER: // 1810
|
|
tspr->xrepeat = 30;
|
|
tspr->yrepeat = 38;
|
|
break;
|
|
case ICON_HEAT_CARD: // 1819
|
|
tspr->xrepeat = 46;
|
|
tspr->yrepeat = 47;
|
|
break;
|
|
case ICON_REPAIR_KIT: // 1813
|
|
break;
|
|
case ICON_EXPLOSIVE_BOX: // 1801
|
|
break;
|
|
case ICON_ENVIRON_SUIT: // 1837
|
|
break;
|
|
case ICON_FLY: // 1782
|
|
break;
|
|
case ICON_CLOAK: // 1826
|
|
break;
|
|
case ICON_NIGHT_VISION: // 3031
|
|
tspr->xrepeat = 59;
|
|
tspr->yrepeat = 71;
|
|
break;
|
|
case ICON_NAPALM: // 3046
|
|
break;
|
|
case ICON_RING: // 3050
|
|
break;
|
|
case ICON_RINGAMMO: // 3054
|
|
break;
|
|
case ICON_NAPALMAMMO: // 3058
|
|
break;
|
|
case ICON_GRENADE: // 3059
|
|
break;
|
|
case ICON_ARMOR: // 3030
|
|
tspr->xrepeat = 82;
|
|
tspr->yrepeat = 84;
|
|
break;
|
|
case BLUE_KEY: // 1766
|
|
break;
|
|
case RED_KEY: // 1770
|
|
break;
|
|
case GREEN_KEY: // 1774
|
|
break;
|
|
case YELLOW_KEY: // 1778
|
|
break;
|
|
case BLUE_CARD:
|
|
case RED_CARD:
|
|
case GREEN_CARD:
|
|
case YELLOW_CARD:
|
|
tspr->xrepeat = 36;
|
|
tspr->yrepeat = 33;
|
|
break;
|
|
case GOLD_SKELKEY:
|
|
case SILVER_SKELKEY:
|
|
case BRONZE_SKELKEY:
|
|
case RED_SKELKEY:
|
|
tspr->xrepeat = 39;
|
|
tspr->yrepeat = 45;
|
|
break;
|
|
case SKEL_LOCKED:
|
|
case SKEL_UNLOCKED:
|
|
tspr->xrepeat = 47;
|
|
tspr->yrepeat = 40;
|
|
break;
|
|
case RAMCARD_LOCKED:
|
|
case RAMCARD_UNLOCKED:
|
|
case CARD_LOCKED:
|
|
case CARD_UNLOCKED:
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
|
|
// Rotation angles for sprites
|
|
short rotang = 0;
|
|
|
|
void
|
|
ExtAnalyzeSprites(void)
|
|
{
|
|
int i, currsprite;
|
|
spritetype *tspr;
|
|
|
|
|
|
rotang += 4;
|
|
if (rotang > 2047)
|
|
rotang = 0;
|
|
|
|
for (i = 0, tspr = &tsprite[0]; i < spritesortcnt; i++, tspr++)
|
|
{
|
|
|
|
// Take care of autosizing
|
|
DoAutoSize(tspr);
|
|
|
|
tspr->shade += 6;
|
|
if (sector[tspr->sectnum].ceilingstat & 1)
|
|
tspr->shade += sector[tspr->sectnum].ceilingshade;
|
|
else
|
|
tspr->shade += sector[tspr->sectnum].floorshade;
|
|
|
|
if (tspr->picnum == ICON_ARMOR)
|
|
{
|
|
if (tspr->pal != 19) // Red
|
|
tspr->pal = 17; // Gray
|
|
}
|
|
|
|
// Check for voxels
|
|
if (bVoxelsOn)
|
|
{
|
|
if (bSpinBobVoxels)
|
|
{
|
|
switch (tspr->picnum)
|
|
{
|
|
case ICON_STAR: // 1793
|
|
case ICON_UZI: // 1797
|
|
case ICON_UZIFLOOR: // 1807
|
|
case ICON_LG_UZI_AMMO: // 1799
|
|
case ICON_HEART: // 1824
|
|
case ICON_HEART_LG_AMMO: // 1820
|
|
case ICON_GUARD_HEAD: // 1814
|
|
case ICON_FIREBALL_LG_AMMO: // 3035
|
|
case ICON_ROCKET: // 1843
|
|
case ICON_SHOTGUN: // 1794
|
|
case ICON_LG_ROCKET: // 1796
|
|
case ICON_LG_SHOTSHELL: // 1823
|
|
case ICON_MICRO_GUN: // 1818
|
|
case ICON_MICRO_BATTERY: // 1800
|
|
case ICON_GRENADE_LAUNCHER: // 1817
|
|
case ICON_LG_GRENADE: // 1831
|
|
case ICON_LG_MINE: // 1842
|
|
case ICON_RAIL_GUN: // 1811
|
|
case ICON_RAIL_AMMO: // 1812
|
|
case ICON_SM_MEDKIT: // 1802
|
|
case ICON_MEDKIT: // 1803
|
|
case ICON_BOOSTER: // 1810
|
|
case ICON_HEAT_CARD: // 1819
|
|
case ICON_REPAIR_KIT: // 1813
|
|
case ICON_EXPLOSIVE_BOX: // 1801
|
|
case ICON_ENVIRON_SUIT: // 1837
|
|
case ICON_FLY: // 1782
|
|
case ICON_CLOAK: // 1826
|
|
case ICON_NIGHT_VISION: // 3031
|
|
case ICON_NAPALM: // 3046
|
|
case ICON_RING: // 3050
|
|
// case ICON_GOROAMMO: // 3035
|
|
// case ICON_HEARTAMMO: // 1820
|
|
case ICON_RINGAMMO: // 3054
|
|
case ICON_NAPALMAMMO: // 3058
|
|
case ICON_GRENADE: // 3059
|
|
// case ICON_OXYGEN: // 1800
|
|
case ICON_ARMOR: // 3030
|
|
case BLUE_KEY: // 1766
|
|
case RED_KEY: // 1770
|
|
case GREEN_KEY: // 1774
|
|
case YELLOW_KEY: // 1778
|
|
case ICON_CHEMBOMB:
|
|
case ICON_FLASHBOMB:
|
|
case ICON_NUKE:
|
|
case ICON_CALTROPS:
|
|
tspr->ang = rotang;
|
|
// tspr->z+=(sintable[(rotang*2)%2047]/16);
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (aVoxelArray[tspr->picnum] >= 0)
|
|
{
|
|
|
|
// Turn on voxels
|
|
tspr->picnum = aVoxelArray[tspr->picnum]; // Get the voxel number
|
|
tspr->cstat |= 48; // Set stat to voxelize sprite
|
|
}
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
uint8_t*
|
|
BKeyPressed(void)
|
|
{
|
|
uint8_t* k;
|
|
|
|
for (k = (uint8_t*) & KEY_PRESSED(0); k < (uint8_t*) &KEY_PRESSED(SIZ(keystatus)); k++)
|
|
{
|
|
if (*k)
|
|
return k;
|
|
}
|
|
|
|
return NULL;
|
|
}
|
|
|
|
uint8_t*
|
|
KeyPressedRange(uint8_t* kb, uint8_t* ke)
|
|
{
|
|
uint8_t* k;
|
|
|
|
for (k = kb; k <= ke; k++)
|
|
{
|
|
if (*k)
|
|
return k;
|
|
}
|
|
|
|
return NULL;
|
|
}
|
|
|
|
void
|
|
ResetKeyRange(uint8_t* kb, uint8_t* ke)
|
|
{
|
|
uint8_t* k;
|
|
|
|
for (k = kb; k <= ke; k++)
|
|
{
|
|
*k = 0;
|
|
}
|
|
}
|
|
|
|
#if 0
|
|
void
|
|
ExtInit(void)
|
|
{
|
|
void InitPalette(void);
|
|
int i, fil;
|
|
|
|
initgroupfile("sw.grp");
|
|
if ((fil = open("setup.dat", O_BINARY | O_RDWR, S_IREAD)) != -1)
|
|
{
|
|
read(fil, &option[0], NUMOPTIONS);
|
|
read(fil, &keys[0], NUMKEYS);
|
|
memcpy((void *) buildkeys, (void *) keys, NUMKEYS); // Trick to make build
|
|
// use setup.dat keys
|
|
close(fil);
|
|
}
|
|
if (option[4] > 0)
|
|
option[4] = 0;
|
|
initmouse();
|
|
|
|
initengine();
|
|
vidoption = option[0];
|
|
xdim = vesares[option[6] & 15][0];
|
|
ydim = vesares[option[6] & 15][1];
|
|
|
|
#if 0
|
|
switch (option[0])
|
|
{
|
|
case 0:
|
|
initengine(0, chainxres[option[6] & 15], chainyres[option[6] >> 4]);
|
|
break;
|
|
case 1:
|
|
initengine(1, vesares[option[6] & 15][0], vesares[option[6] & 15][1]);
|
|
break;
|
|
default:
|
|
initengine(option[0], 320L, 200L);
|
|
}
|
|
#endif
|
|
|
|
InitPalette();
|
|
|
|
defaultspritecstat = 0; // use old centering mode
|
|
kensplayerheight = 58;
|
|
zmode = 0;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
char *startwin_labeltext = "Starting Build Editor for Shadow Warrior...";
|
|
|
|
int
|
|
ExtInit(void)
|
|
{
|
|
int rv = 0;
|
|
char *swgrp = "sw.grp";
|
|
|
|
#ifndef BUILD_DEV_VER
|
|
char ch;
|
|
|
|
printf("\n------------------------------------------------------------------------------\n");
|
|
printf("BUILD.EXE for Shadow Warrior\n\n");
|
|
printf("Copyright (c) 1993 - 1997, 3D Realms Entertainment.\n");
|
|
printf("\n");
|
|
printf("IMPORTANT: This editor and associated tools and utilities are NOT\n");
|
|
printf("shareware and may NOT be freely distributed to any BBS, CD, floppy, or\n");
|
|
printf("any other media. These tools may NOT be sold or repackaged for sale in\n");
|
|
printf("a commercial product.\n");
|
|
printf("\n");
|
|
printf("Any levels created with these editors and tools may only be used with the\n");
|
|
printf("full (registered) copy of Shadow Warrior, and not the shareware version.\n");
|
|
printf("Please refer to LICENSE.DOC for further information on levels created with\n");
|
|
printf("BUILD.EXE.\n");
|
|
printf("\n");
|
|
printf("Press <Y> if you have read and accepted the terms of LICENSE.DOC,\n");
|
|
printf("or any other key to abort the program. \n");
|
|
printf("\n");
|
|
ch = getch();
|
|
|
|
if (ch == 'y' || ch == 'Y') // if user press Y
|
|
{
|
|
#endif
|
|
|
|
|
|
void InitPalette(void);
|
|
int i, fil;
|
|
|
|
// Store user log in time
|
|
//LogUserTime(TRUE); // Send true because user is logging
|
|
// in.
|
|
|
|
#ifdef _WIN32
|
|
if (!access("user_profiles_enabled", F_OK))
|
|
#endif
|
|
{
|
|
char cwd[BMAX_PATH];
|
|
char *homedir;
|
|
int asperr;
|
|
|
|
#if defined(__linux) || defined(__FreeBSD__) || defined(__NetBSD__) || defined(__OpenBSD__)
|
|
addsearchpath("/usr/share/games/jfsw");
|
|
addsearchpath("/usr/local/share/games/jfsw");
|
|
#elif defined(__APPLE__)
|
|
addsearchpath("/Library/Application Support/JFShadowWarrior");
|
|
#endif
|
|
if (getcwd(cwd,BMAX_PATH)) addsearchpath(cwd);
|
|
if ((homedir = Bgethomedir()))
|
|
{
|
|
Bsnprintf(cwd,sizeof(cwd),"%s/"
|
|
#if defined(_WIN32)
|
|
"JFShadowWarrior"
|
|
#elif defined(__APPLE__)
|
|
"Library/Application Support/JFShadowWarrior"
|
|
#else
|
|
".jfsw"
|
|
#endif
|
|
,homedir);
|
|
asperr = addsearchpath(cwd);
|
|
if (asperr == -2)
|
|
{
|
|
if (Bmkdir(cwd,S_IRWXU) == 0) asperr = addsearchpath(cwd);
|
|
else asperr = -1;
|
|
}
|
|
if (asperr == 0)
|
|
chdir(cwd);
|
|
free(homedir);
|
|
}
|
|
}
|
|
|
|
if (getenv("SWGRP"))
|
|
{
|
|
swgrp = getenv("SWGRP");
|
|
buildprintf("Using %s as main GRP file\n", swgrp);
|
|
}
|
|
initgroupfile(swgrp);
|
|
/*
|
|
if ((fil = open("setup.dat", O_BINARY | O_RDWR, S_IREAD)) != -1)
|
|
{
|
|
read(fil, &option[0], NUMOPTIONS);
|
|
read(fil, &keys[0], NUMKEYS);
|
|
memcpy((void *) buildkeys, (void *) keys, NUMKEYS); // Trick to make build
|
|
// use setup.dat keys
|
|
close(fil);
|
|
}
|
|
*/
|
|
bpp = 8;
|
|
if (loadsetup("build.cfg") < 0) buildputs("Configuration file not found, using defaults.\n"), rv = 1;
|
|
Bmemcpy((void *)buildkeys,(void *)keys,NUMBUILDKEYS); //Trick to make build use setup.dat keys
|
|
if (option[4] > 0)
|
|
option[4] = 0;
|
|
if (initengine())
|
|
{
|
|
wm_msgbox("Build Engine Initialisation Error",
|
|
"There was a problem initialising the Build engine: %s", engineerrstr);
|
|
return -1;
|
|
}
|
|
initinput();
|
|
initmouse();
|
|
|
|
InitPalette();
|
|
|
|
defaultspritecstat = 0; // use old centering mode
|
|
kensplayerheight = 58;
|
|
zmode = 0;
|
|
|
|
#ifndef BUILD_DEV_VER
|
|
} // end user press Y
|
|
else
|
|
{
|
|
printf("------------------------------------------------------------------------------\n");
|
|
exit(0);
|
|
}
|
|
#endif
|
|
return rv;
|
|
}
|
|
|
|
|
|
void
|
|
ExtUnInit(void)
|
|
{
|
|
uninitgroupfile();
|
|
writesetup("build.cfg");
|
|
// Store user log in time
|
|
//LogUserTime(FALSE); // FALSE means user is logging out
|
|
// now.
|
|
}
|
|
|
|
void
|
|
SetSpriteExtra(void)
|
|
{
|
|
SPRITEp sp;
|
|
int i;
|
|
|
|
#define DEFAULT_SKILL 2
|
|
|
|
// for (sp = sprite; sp < &sprite[MAXSPRITES]; sp++)
|
|
for (sp = sprite; sp < &sprite[MAXSPRITES]; sp++)
|
|
{
|
|
if (sp->picnum == ST1)
|
|
{
|
|
if (sp->owner == -1)
|
|
sp->owner = 0;
|
|
}
|
|
else
|
|
{
|
|
sp->owner = -1;
|
|
}
|
|
|
|
if (sp->extra == -1)
|
|
{
|
|
sp->extra = 0;
|
|
SET(sp->extra, DEFAULT_SKILL);
|
|
}
|
|
}
|
|
|
|
// loaded_numwalls is what numwalls is after a load
|
|
// only new walls get their extra's set
|
|
if (loaded_numwalls != numwalls)
|
|
{
|
|
for (i = 0; i < numwalls; i++)
|
|
{
|
|
if (wall[i].extra != 0)
|
|
wall[i].extra = 0;
|
|
}
|
|
}
|
|
loaded_numwalls = numwalls;
|
|
}
|
|
|
|
void
|
|
ResetSpriteFound(void)
|
|
{
|
|
SPRITEp sp;
|
|
|
|
for (sp = sprite; sp < &sprite[MAXSPRITES]; sp++)
|
|
{
|
|
RESET(sp->extra, SPRX_FOUND);
|
|
}
|
|
}
|
|
|
|
|
|
// imported from allen code
|
|
void
|
|
Keys3D(void)
|
|
{
|
|
int i;
|
|
|
|
// 'PGUP - Move a floor/ceiling sector up 8 pixels.
|
|
if (keystatus[KEYSC_RCTRL] && keystatus[KEYSC_PGUP])
|
|
{
|
|
switch (searchstat)
|
|
{
|
|
case 1: // Ceiling
|
|
sector[searchsector].ceilingz -= (1024 * 8);
|
|
keystatus[KEYSC_PGUP] = 0;
|
|
break;
|
|
case 2: // Floor
|
|
sector[searchsector].floorz -= (1024 * 8);
|
|
keystatus[KEYSC_PGUP] = 0;
|
|
break;
|
|
}
|
|
|
|
}
|
|
|
|
// 'PGDN - Move a floor/ceiling sector down 8 pixels.
|
|
if (keystatus[KEYSC_RCTRL] && keystatus[KEYSC_PGDN])
|
|
{
|
|
switch (searchstat)
|
|
{
|
|
case 1: // Ceiling
|
|
sector[searchsector].ceilingz += (1024 * 8);
|
|
keystatus[KEYSC_PGDN] = 0;
|
|
break;
|
|
case 2: // Floor
|
|
sector[searchsector].floorz += (1024 * 8);
|
|
keystatus[KEYSC_PGDN] = 0;
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
// R - Set relative mode on a floor/ceiling.
|
|
if (!keystatus[KEYSC_ENTER] && !keystatus[KEYSC_QUOTE] && keystatus[KEYSC_R])
|
|
{
|
|
switch (searchstat)
|
|
{
|
|
case 0:
|
|
case 4: // Wall
|
|
break;
|
|
case 1: // Ceiling
|
|
if (sector[searchsector].ceilingstat & 65)
|
|
Message("Ceiling Relative OFF", M_RED);
|
|
else
|
|
Message("Ceiling Relative ON", M_BLUE);
|
|
break;
|
|
case 2: // Floor
|
|
if (sector[searchsector].floorstat & 65)
|
|
Message("Floor Relative OFF", M_RED);
|
|
else
|
|
Message("Floor Relative ON", M_BLUE);
|
|
break;
|
|
case 3: // Sprite
|
|
break;
|
|
}
|
|
}
|
|
|
|
// '+ = Shade down a floor ceiling while keeping sprites constant
|
|
if (keystatus[KEYSC_QUOTE] && keystatus[KEYSC_GPLUS])
|
|
{
|
|
SWBOOL dospriteshade = FALSE;
|
|
|
|
keystatus[KEYSC_GPLUS] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 1:
|
|
if (sector[searchsector].ceilingstat & 1)
|
|
dospriteshade = TRUE;
|
|
if (sector[searchsector].ceilingshade > -128)
|
|
sector[searchsector].ceilingshade--;
|
|
break;
|
|
case 2:
|
|
if (!(sector[searchsector].ceilingstat & 1))
|
|
dospriteshade = TRUE;
|
|
if (sector[searchsector].floorshade > -128)
|
|
sector[searchsector].floorshade--;
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
|
|
if (dospriteshade)
|
|
{
|
|
for (i = 0; i < MAXSPRITES; i++)
|
|
{
|
|
if (sprite[i].sectnum == searchsector)
|
|
{
|
|
if (sprite[i].shade < 127)
|
|
sprite[i].shade++;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
// '- = Shade down a floor ceiling while keeping sprites constant
|
|
if (keystatus[KEYSC_QUOTE] && keystatus[KEYSC_GMINUS])
|
|
{
|
|
SWBOOL dospriteshade = FALSE;
|
|
|
|
keystatus[KEYSC_GMINUS] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 1:
|
|
if (sector[searchsector].ceilingstat & 1)
|
|
dospriteshade = TRUE;
|
|
if (sector[searchsector].ceilingshade < 127)
|
|
sector[searchsector].ceilingshade++;
|
|
break;
|
|
case 2:
|
|
if (!(sector[searchsector].ceilingstat & 1))
|
|
dospriteshade = TRUE;
|
|
if (sector[searchsector].floorshade < 127)
|
|
sector[searchsector].floorshade++;
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
|
|
if (dospriteshade)
|
|
{
|
|
for (i = 0; i < MAXSPRITES; i++)
|
|
{
|
|
if (sprite[i].sectnum == searchsector)
|
|
{
|
|
if (sprite[i].shade > -128)
|
|
sprite[i].shade--;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
// 'ENTER - Copies only the bitmap in the copy buffer to
|
|
// wall/ceiling/floor/sprite,
|
|
// whatever the cursor is pointing to. Does not copy x/y repeats etc.,
|
|
// like ENTER does.
|
|
if (keystatus[KEYSC_QUOTE] && keystatus[KEYSC_ENTER]) // ' ENTER
|
|
{
|
|
printext256(0, 0, 15, 0, "Put Graphic ONLY", 0);
|
|
keystatus[KEYSC_ENTER] = 0;
|
|
switch (searchstat)
|
|
{
|
|
case 0:
|
|
wall[searchwall].picnum = temppicnum;
|
|
break;
|
|
case 1:
|
|
sector[searchsector].ceilingpicnum = temppicnum;
|
|
break;
|
|
case 2:
|
|
sector[searchsector].floorpicnum = temppicnum;
|
|
break;
|
|
case 3:
|
|
sprite[searchwall].picnum = temppicnum;
|
|
break;
|
|
case 4:
|
|
wall[searchwall].overpicnum = temppicnum;
|
|
break;
|
|
}
|
|
}
|
|
|
|
// ;S
|
|
if (keystatus[KEYSC_SEMI] && keystatus[KEYSC_S]) // ; S
|
|
{
|
|
keystatus[KEYSC_S] = 0;
|
|
switch (searchstat)
|
|
{
|
|
|
|
case 0:
|
|
case 4:
|
|
for (i = 0; i < MAXWALLS; i++)
|
|
{
|
|
if (wall[i].picnum == temppicnum)
|
|
{
|
|
wall[i].shade = tempshade;
|
|
}
|
|
}
|
|
break;
|
|
case 1:
|
|
case 2:
|
|
for (i = 0; i < MAXSECTORS; i++)
|
|
{
|
|
if (searchstat)
|
|
if (sector[i].ceilingpicnum == temppicnum)
|
|
{
|
|
sector[i].ceilingshade = tempshade;
|
|
}
|
|
if (searchstat == 2)
|
|
if (sector[i].floorpicnum == temppicnum)
|
|
{
|
|
sector[i].floorshade = tempshade;
|
|
}
|
|
}
|
|
break;
|
|
case 3:
|
|
for (i = 0; i < MAXSPRITES; i++)
|
|
{
|
|
if (sprite[i].picnum == temppicnum)
|
|
{
|
|
sprite[i].shade = tempshade;
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
|
|
// 'C - Does a global tile replacement using bitmap only, no x/y repeat,
|
|
// etc....
|
|
// Works for walls, sectors, or sprites.
|
|
if (keystatus[KEYSC_QUOTE] && keystatus[KEYSC_C]) // ' C
|
|
{
|
|
short searchpicnum = 0;
|
|
short w, start_wall, end_wall, currsector;
|
|
|
|
keystatus[KEYSC_C] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
|
|
case 0:
|
|
case 4:
|
|
searchpicnum = wall[searchwall].picnum;
|
|
if (highlightsectorcnt <= 0)
|
|
{
|
|
for (i = 0; i < MAXWALLS; i++)
|
|
{
|
|
if (wall[i].picnum == searchpicnum)
|
|
{
|
|
wall[i].picnum = temppicnum;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
for (i = 0; i < highlightsectorcnt; i++)
|
|
{
|
|
currsector = highlightsector[i];
|
|
start_wall = sector[currsector].wallptr;
|
|
end_wall = start_wall + sector[currsector].wallnum;
|
|
|
|
for (w = start_wall; w < end_wall; w++)
|
|
{
|
|
if (wall[w].picnum == searchpicnum)
|
|
wall[w].picnum = temppicnum;
|
|
}
|
|
}
|
|
}
|
|
break;
|
|
case 1:
|
|
if (highlightsectorcnt <= 0)
|
|
{
|
|
searchpicnum = sector[searchsector].ceilingpicnum;
|
|
for (i = 0; i < MAXSECTORS; i++)
|
|
{
|
|
if (sector[i].ceilingpicnum == searchpicnum)
|
|
{
|
|
sector[i].ceilingpicnum = temppicnum;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
for (i = 0; i < highlightsectorcnt; i++)
|
|
{
|
|
currsector = highlightsector[i];
|
|
|
|
if (sector[currsector].ceilingpicnum == searchpicnum)
|
|
sector[currsector].ceilingpicnum = temppicnum;
|
|
}
|
|
}
|
|
case 2:
|
|
searchpicnum = sector[searchsector].floorpicnum;
|
|
if (highlightsectorcnt <= 0)
|
|
{
|
|
for (i = 0; i < MAXSECTORS; i++)
|
|
{
|
|
if (sector[i].floorpicnum == searchpicnum)
|
|
{
|
|
sector[i].floorpicnum = temppicnum;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
for (i = 0; i < highlightsectorcnt; i++)
|
|
{
|
|
currsector = highlightsector[i];
|
|
|
|
if (sector[currsector].floorpicnum == searchpicnum)
|
|
sector[currsector].floorpicnum = temppicnum;
|
|
}
|
|
}
|
|
break;
|
|
case 3:
|
|
searchpicnum = sprite[searchwall].picnum;
|
|
|
|
if (highlightsectorcnt <= 0)
|
|
{
|
|
for (i = 0; i < MAXSPRITES; i++)
|
|
{
|
|
if (sprite[i].picnum == searchpicnum)
|
|
sprite[i].picnum = temppicnum;
|
|
}
|
|
}
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
|
|
// 'T - Set's the low tag of a wall/sector/sprite.
|
|
if (keystatus[KEYSC_QUOTE] && keystatus[KEYSC_T]) // ' T
|
|
{
|
|
keystatus[KEYSC_T] = 0;
|
|
switch (searchstat)
|
|
{
|
|
case 0:
|
|
case 4:
|
|
strcpy(tempbuf, "Wall lotag: ");
|
|
wall[searchwall].lotag =
|
|
getnumber256(tempbuf, wall[searchwall].lotag, 65536L, 1);
|
|
break;
|
|
case 1:
|
|
case 2:
|
|
strcpy(tempbuf, "Sector lotag: ");
|
|
sector[searchsector].lotag =
|
|
getnumber256(tempbuf, sector[searchsector].lotag, 65536L, 1);
|
|
break;
|
|
case 3:
|
|
strcpy(tempbuf, "Sprite lotag: ");
|
|
sprite[searchwall].lotag =
|
|
getnumber256(tempbuf, sprite[searchwall].lotag, 65536L, 1);
|
|
// Find the next lotag
|
|
if (sprite[searchwall].picnum == ST1)
|
|
{
|
|
FindNextTag();
|
|
ShowNextTag();
|
|
}
|
|
|
|
break;
|
|
}
|
|
}
|
|
|
|
// 'H - Sets the high tag of a wall/sector/sprite.
|
|
if (keystatus[KEYSC_QUOTE] && keystatus[KEYSC_H]) // ' H
|
|
{
|
|
keystatus[KEYSC_H] = 0;
|
|
switch (searchstat)
|
|
{
|
|
case 0:
|
|
case 4:
|
|
strcpy(tempbuf, "Wall hitag: ");
|
|
wall[searchwall].hitag =
|
|
getnumber256(tempbuf, wall[searchwall].hitag, 65536L, 1);
|
|
break;
|
|
case 1:
|
|
case 2:
|
|
strcpy(tempbuf, "Sector hitag: ");
|
|
sector[searchsector].hitag =
|
|
getnumber256(tempbuf, sector[searchsector].hitag, 65536L, 1);
|
|
break;
|
|
case 3:
|
|
strcpy(tempbuf, "Sprite hitag: ");
|
|
sprite[searchwall].hitag =
|
|
getnumber256(tempbuf, sprite[searchwall].hitag, 65536L, 1);
|
|
break;
|
|
}
|
|
}
|
|
|
|
// 'S - Sets the shade of a wall/sector/sprite using an entered input
|
|
// value
|
|
// between 0-65536.
|
|
if (keystatus[KEYSC_QUOTE] && keystatus[KEYSC_S]) // ' S
|
|
{
|
|
keystatus[KEYSC_S] = 0;
|
|
switch (searchstat)
|
|
{
|
|
case 0:
|
|
case 4:
|
|
strcpy(tempbuf, "Wall shade: ");
|
|
wall[searchwall].shade =
|
|
getnumber256(tempbuf, wall[searchwall].shade, 65536L, 1);
|
|
break;
|
|
case 1:
|
|
case 2:
|
|
strcpy(tempbuf, "Sector shade: ");
|
|
if (searchstat == 1)
|
|
sector[searchsector].ceilingshade =
|
|
getnumber256(tempbuf, sector[searchsector].ceilingshade, 65536L, 1);
|
|
if (searchstat == 2)
|
|
sector[searchsector].floorshade =
|
|
getnumber256(tempbuf, sector[searchsector].floorshade, 65536L, 1);
|
|
break;
|
|
case 3:
|
|
strcpy(tempbuf, "Sprite shade: ");
|
|
sprite[searchwall].shade =
|
|
getnumber256(tempbuf, sprite[searchwall].shade, 65536L, 1);
|
|
break;
|
|
}
|
|
}
|
|
|
|
// 'V - Sets sector visibility on a sector using an input value between
|
|
// 0-65536.
|
|
if (keystatus[KEYSC_QUOTE] && keystatus[KEYSC_V]) // ' V
|
|
{
|
|
keystatus[KEYSC_V] = 0;
|
|
switch (searchstat)
|
|
{
|
|
case 1:
|
|
case 2:
|
|
strcpy(tempbuf, "Sector visibility: ");
|
|
sector[searchsector].visibility =
|
|
getnumber256(tempbuf, sector[searchsector].visibility, 65536L, 1);
|
|
break;
|
|
}
|
|
}
|
|
|
|
// 'X - Toggles voxel sprites on/off
|
|
if (keystatus[KEYSC_QUOTE] && keystatus[KEYSC_X]) // ' X
|
|
{
|
|
keystatus[KEYSC_X] = 0;
|
|
|
|
bVoxelsOn = !bVoxelsOn;
|
|
}
|
|
|
|
// 'Z - Toggles voxel rotation on/off
|
|
if (keystatus[KEYSC_QUOTE] && keystatus[KEYSC_Z]) // ' Z
|
|
{
|
|
keystatus[KEYSC_Z] = 0;
|
|
|
|
bSpinBobVoxels = !bSpinBobVoxels;
|
|
}
|
|
|
|
// 'A - Toggles sprite autosizing on/off
|
|
if (keystatus[KEYSC_QUOTE] && keystatus[KEYSC_A]) // ' A
|
|
{
|
|
keystatus[KEYSC_A] = 0;
|
|
|
|
bAutoSize = !bAutoSize;
|
|
}
|
|
|
|
// 'M - Toggles sprites on/off
|
|
if (keystatus[KEYSC_QUOTE] && keystatus[KEYSC_M]) // ' M
|
|
{
|
|
keystatus[KEYSC_M] = 0;
|
|
|
|
ToggleSprites();
|
|
}
|
|
|
|
// 'P - Will copy palette to all sectors highlighted with R-Alt key
|
|
if (keystatus[KEYSC_QUOTE] && keystatus[KEYSC_P]) // ' P
|
|
{
|
|
short w, start_wall, end_wall, currsector;
|
|
|
|
keystatus[KEYSC_P] = 0;
|
|
|
|
for (i = 0; i < highlightsectorcnt; i++)
|
|
{
|
|
currsector = highlightsector[i];
|
|
sector[currsector].ceilingpal = temppal;
|
|
sector[currsector].floorpal = temppal;
|
|
// Do all the walls in the sector
|
|
start_wall = sector[currsector].wallptr;
|
|
end_wall = start_wall + sector[currsector].wallnum;
|
|
|
|
for (w = start_wall; w < end_wall; w++)
|
|
{
|
|
wall[w].pal = temppal;
|
|
}
|
|
}
|
|
}
|
|
|
|
// ;P - Will copy palette to all sectors highlighted with R-Alt key
|
|
if (keystatus[KEYSC_SEMI] && keystatus[KEYSC_P]) // ; P
|
|
{
|
|
short w, start_wall, end_wall, currsector;
|
|
|
|
keystatus[KEYSC_P] = 0;
|
|
|
|
for (i = 0; i < highlightsectorcnt; i++)
|
|
{
|
|
currsector = highlightsector[i];
|
|
|
|
if ((sector[currsector].ceilingpal == temppal && temppal != 0) || (temppal == 0 && sector[currsector].ceilingpal != 0))
|
|
sector[currsector].ceilingshade = 127;
|
|
if ((sector[currsector].floorpal == temppal && temppal != 0) || (temppal == 0 && sector[currsector].ceilingpal != 0))
|
|
sector[currsector].floorshade = 127;
|
|
|
|
// Do all the walls in the sector
|
|
start_wall = sector[currsector].wallptr;
|
|
end_wall = start_wall + sector[currsector].wallnum;
|
|
|
|
for (w = start_wall; w < end_wall; w++)
|
|
{
|
|
if ((wall[w].pal == temppal && temppal != 0) || (temppal == 0 && wall[w].pal != 0))
|
|
wall[w].shade = 127;
|
|
}
|
|
}
|
|
}
|
|
|
|
ShowMessage();
|
|
} // end Keys3D()
|
|
|
|
// Used to help print out the item status list
|
|
void
|
|
PrintStatus(char *string, int num, char x, char y, char color)
|
|
{
|
|
sprintf(tempbuf, "%s %d", string, num);
|
|
printext16(x * 8, ydim16+y * 8, color, -1, tempbuf, 0);
|
|
}
|
|
|
|
void
|
|
MoreKeys(short searchstat, short searchwall, short searchsector, short pointhighlight)
|
|
{
|
|
|
|
typedef short GET_NUM_FUNC (char *, short, int, char);
|
|
typedef GET_NUM_FUNC *GET_NUM_FUNCp;
|
|
typedef void PRINT_MSG_FUNC (char *);
|
|
typedef PRINT_MSG_FUNC *PRINT_MSG_FUNCp;
|
|
SPRITEp sp;
|
|
|
|
int i;
|
|
int value;
|
|
|
|
GET_NUM_FUNCp getnumber;
|
|
PRINT_MSG_FUNCp printmessage;
|
|
|
|
if (qsetmode == MODE_3D)
|
|
{
|
|
getnumber = getnumber256;
|
|
printmessage = printmessage256;
|
|
}
|
|
else
|
|
{
|
|
getnumber = getnumber16;
|
|
printmessage = printmessage16;
|
|
|
|
if (TEST(pointhighlight, SPRITE_FLAG))
|
|
{
|
|
searchstat = 3;
|
|
searchwall = RESET(pointhighlight, SPRITE_FLAG);
|
|
}
|
|
else
|
|
{
|
|
// for now make search stat invalid
|
|
searchstat = 5;
|
|
}
|
|
}
|
|
|
|
sp = &sprite[searchwall];
|
|
|
|
|
|
|
|
if (KEY_PRESSED(KEYSC_RALT + 128) && KEY_PRESSED(KEYSC_RCTRL + 128))
|
|
{
|
|
if (KEY_PRESSED(KEYSC_KPMINUS))
|
|
{
|
|
KEY_PRESSED(KEYSC_KPMINUS) = 0;
|
|
visibility = visibility - (visibility >> 3);
|
|
|
|
if (visibility < 0)
|
|
visibility = 16348;
|
|
}
|
|
else if (KEY_PRESSED(KEYSC_KPPLUS))
|
|
{
|
|
KEY_PRESSED(KEYSC_KPPLUS) = 0;
|
|
visibility = visibility + (visibility >> 3);
|
|
|
|
if (visibility > 16348)
|
|
visibility = 0;
|
|
}
|
|
}
|
|
|
|
|
|
if (keystatus[KEYSC_QUOTE])
|
|
{
|
|
|
|
if (keystatus[KEYSC_K]) // ' K
|
|
{
|
|
short data;
|
|
SPRITEp sp = &sprite[searchwall];
|
|
|
|
keystatus[KEYSC_K] = 0;
|
|
switch (searchstat)
|
|
{
|
|
case 3:
|
|
data = TEST(sp->extra, SPRX_SKILL);
|
|
|
|
//data = getnumber256(tempbuf, data, 65536L);
|
|
data++; // Toggle
|
|
|
|
if (data > 3)
|
|
data = 0;
|
|
|
|
RESET(sp->extra, SPRX_SKILL);
|
|
SET(sp->extra, data);
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (keystatus[KEYSC_RSHIFT] || keystatus[KEYSC_LSHIFT])
|
|
{
|
|
if (keystatus[KEYSC_1])
|
|
{
|
|
keystatus[KEYSC_1] = 0;
|
|
keystatus[KEYSC_SEMI] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 3:
|
|
sprintf(tempbuf, "Sprite tag 11 (shade) (snum = %d): ", searchwall);
|
|
SPRITE_TAG11(searchwall) =
|
|
getnumber(tempbuf, SPRITE_TAG11(searchwall), 65536L, 0);
|
|
break;
|
|
}
|
|
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_2])
|
|
{
|
|
keystatus[KEYSC_2] = 0;
|
|
keystatus[KEYSC_SEMI] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 3:
|
|
strcpy(tempbuf, "Sprite tag 12 (pal): ");
|
|
SPRITE_TAG12(searchwall) =
|
|
getnumber(tempbuf, SPRITE_TAG12(searchwall), 65536L, 0);
|
|
break;
|
|
}
|
|
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_3])
|
|
{
|
|
keystatus[KEYSC_3] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 3:
|
|
strcpy(tempbuf, "Sprite tag 13 (xoffset/yoffset): ");
|
|
i = getnumber(tempbuf, SPRITE_TAG13(searchwall), 65536L, 0);
|
|
SET_SPRITE_TAG13(searchwall, i);
|
|
break;
|
|
}
|
|
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_4])
|
|
{
|
|
keystatus[KEYSC_4] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 3:
|
|
strcpy(tempbuf, "Sprite tag 14 (xrepeat/yrepeat): ");
|
|
i = getnumber(tempbuf, SPRITE_TAG14(searchwall), 65536L, 0);
|
|
SET_SPRITE_TAG14(searchwall, i);
|
|
break;
|
|
}
|
|
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_5])
|
|
{
|
|
keystatus[KEYSC_5] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 3:
|
|
strcpy(tempbuf, "Sprite tag 15 (z): ");
|
|
SPRITE_TAG15(searchwall) =
|
|
getnumber(tempbuf, SPRITE_TAG15(searchwall), 65536L, 0);
|
|
break;
|
|
}
|
|
|
|
printmessage("");
|
|
}
|
|
}
|
|
|
|
if (keystatus[KEYSC_1])
|
|
{
|
|
keystatus[KEYSC_1] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 0:
|
|
case 4:
|
|
strcpy(tempbuf, "Wall tag 1 (hitag): ");
|
|
wall[searchwall].hitag =
|
|
getnumber(tempbuf, wall[searchwall].hitag, 65536L, 0);
|
|
break;
|
|
case 1:
|
|
case 2:
|
|
strcpy(tempbuf, "Sector tag 1 (hitag): ");
|
|
sector[searchsector].hitag =
|
|
getnumber(tempbuf, sector[searchsector].hitag, 65536L, 0);
|
|
break;
|
|
case 3:
|
|
strcpy(tempbuf, "Sprite tag 1 (hitag): ");
|
|
SPRITE_TAG1(searchwall) =
|
|
getnumber(tempbuf, SPRITE_TAG1(searchwall), 65536L, 0);
|
|
break;
|
|
}
|
|
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_2])
|
|
{
|
|
keystatus[KEYSC_2] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 0:
|
|
case 4:
|
|
strcpy(tempbuf, "Wall tag 2 (lotag): ");
|
|
wall[searchwall].lotag =
|
|
getnumber(tempbuf, wall[searchwall].lotag, 65536L, 0);
|
|
break;
|
|
case 1:
|
|
case 2:
|
|
strcpy(tempbuf, "Sector tag 2 (lotag): ");
|
|
sector[searchsector].lotag =
|
|
getnumber(tempbuf, sector[searchsector].lotag, 65536L, 0);
|
|
break;
|
|
case 3:
|
|
strcpy(tempbuf, "Sprite tag 2 (lotag): ");
|
|
SPRITE_TAG2(searchwall) =
|
|
getnumber(tempbuf, SPRITE_TAG2(searchwall), 65536L, 0);
|
|
// Find the next lotag
|
|
if (sprite[searchwall].picnum == ST1)
|
|
{
|
|
FindNextTag();
|
|
ShowNextTag();
|
|
}
|
|
break;
|
|
}
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_3])
|
|
{
|
|
keystatus[KEYSC_3] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 0:
|
|
case 4:
|
|
strcpy(tempbuf, "Wall tag 3 (xpanning): ");
|
|
wall[searchwall].xpanning =
|
|
getnumber(tempbuf, wall[searchwall].xpanning, 65536L, 0);
|
|
break;
|
|
case 1:
|
|
case 2:
|
|
strcpy(tempbuf, "Sector tag 3 (ceilingxpanning): ");
|
|
sector[searchsector].ceilingxpanning =
|
|
getnumber(tempbuf, sector[searchsector].ceilingxpanning, 65536L, 0);
|
|
break;
|
|
case 3:
|
|
strcpy(tempbuf, "Sprite tag 3 (clipdist) : ");
|
|
SPRITE_TAG3(searchwall) =
|
|
getnumber(tempbuf, SPRITE_TAG3(searchwall), 65536L, 0);
|
|
|
|
break;
|
|
}
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_4])
|
|
{
|
|
keystatus[KEYSC_4] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 0:
|
|
case 4:
|
|
strcpy(tempbuf, "Wall tag 4 (ypanning): ");
|
|
wall[searchwall].ypanning =
|
|
getnumber(tempbuf, wall[searchwall].ypanning, 65536L, 0);
|
|
break;
|
|
case 1:
|
|
case 2:
|
|
strcpy(tempbuf, "Sector tag 4 (ceilingypanning): ");
|
|
sector[searchsector].ceilingypanning =
|
|
getnumber(tempbuf, sector[searchsector].ceilingypanning, 65536L, 0);
|
|
break;
|
|
case 3:
|
|
strcpy(tempbuf, "Sprite tag 4 (ang) : ");
|
|
SPRITE_TAG4(searchwall) =
|
|
getnumber(tempbuf, SPRITE_TAG4(searchwall), 65536L, 0);
|
|
break;
|
|
}
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_5])
|
|
{
|
|
keystatus[KEYSC_5] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 0:
|
|
case 4:
|
|
break;
|
|
case 1:
|
|
case 2:
|
|
strcpy(tempbuf, "Sector tag 5 (floorxpanning): ");
|
|
sector[searchsector].floorxpanning =
|
|
getnumber(tempbuf, sector[searchsector].floorxpanning, 65536L, 0);
|
|
break;
|
|
case 3:
|
|
strcpy(tempbuf, "Sprite tag 5 (xvel) : ");
|
|
SPRITE_TAG5(searchwall) =
|
|
getnumber(tempbuf, SPRITE_TAG5(searchwall), 65536L, 0);
|
|
break;
|
|
}
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_6])
|
|
{
|
|
keystatus[KEYSC_6] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 0:
|
|
case 4:
|
|
break;
|
|
case 1:
|
|
case 2:
|
|
strcpy(tempbuf, "Sector tag 6 (floorypanning): ");
|
|
sector[searchsector].floorypanning =
|
|
getnumber(tempbuf, sector[searchsector].floorypanning, 65536L, 0);
|
|
break;
|
|
case 3:
|
|
strcpy(tempbuf, "Sprite tag 6 (yvel) : ");
|
|
SPRITE_TAG6(searchwall) =
|
|
getnumber(tempbuf, SPRITE_TAG6(searchwall), 65536L, 0);
|
|
break;
|
|
}
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_7])
|
|
{
|
|
keystatus[KEYSC_7] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 0:
|
|
case 4:
|
|
break;
|
|
case 1:
|
|
case 2:
|
|
strcpy(tempbuf, "Sector tag 7 (floorypanning): ");
|
|
sector[searchsector].floorypanning =
|
|
getnumber(tempbuf, sector[searchsector].floorypanning, 65536L, 0);
|
|
break;
|
|
case 3:
|
|
strcpy(tempbuf, "Sprite tag 7 (zvel 1) <0-255> : ");
|
|
SPRITE_TAG7(searchwall) =
|
|
getnumber(tempbuf, SPRITE_TAG7(searchwall), 65536L, 0);
|
|
break;
|
|
}
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_8])
|
|
{
|
|
keystatus[KEYSC_8] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 0:
|
|
case 4:
|
|
break;
|
|
case 1:
|
|
case 2:
|
|
break;
|
|
case 3:
|
|
strcpy(tempbuf, "Sprite tag 8 (zvel 2) <0-255> : ");
|
|
SPRITE_TAG8(searchwall) =
|
|
getnumber(tempbuf, SPRITE_TAG8(searchwall), 65536L, 0);
|
|
break;
|
|
}
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_9])
|
|
{
|
|
keystatus[KEYSC_9] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 0:
|
|
case 4:
|
|
break;
|
|
case 1:
|
|
case 2:
|
|
break;
|
|
case 3:
|
|
strcpy(tempbuf, "Sprite tag 9 (owner 1) <0-255> : ");
|
|
SPRITE_TAG9(searchwall) =
|
|
getnumber(tempbuf, SPRITE_TAG9(searchwall), 65536L, 0);
|
|
break;
|
|
}
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_0])
|
|
{
|
|
keystatus[KEYSC_0] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 0:
|
|
case 4:
|
|
break;
|
|
case 1:
|
|
case 2:
|
|
break;
|
|
case 3:
|
|
strcpy(tempbuf, "Sprite tag 10 (owner 2) <0-255> : ");
|
|
SPRITE_TAG10(searchwall) =
|
|
getnumber(tempbuf, SPRITE_TAG10(searchwall), 65536L, 0);
|
|
break;
|
|
}
|
|
printmessage("");
|
|
}
|
|
|
|
}
|
|
|
|
if (!keystatus[KEYSC_SEMI])
|
|
return;
|
|
|
|
if (keystatus[KEYSC_RSHIFT] || keystatus[KEYSC_LSHIFT])
|
|
{
|
|
if (keystatus[KEYSC_1])
|
|
{
|
|
keystatus[KEYSC_1] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 3:
|
|
strcpy(tempbuf, "Boolean Sprite tag 11 (0 or 1): ");
|
|
value = !!TEST_BOOL11(sp);
|
|
value = getnumber(tempbuf, value, 65536L, 0);
|
|
|
|
if (value)
|
|
SET_BOOL11(sp);
|
|
else
|
|
RESET_BOOL11(sp);
|
|
|
|
break;
|
|
}
|
|
|
|
printmessage("");
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (keystatus[KEYSC_1])
|
|
{
|
|
keystatus[KEYSC_1] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 3:
|
|
strcpy(tempbuf, "Boolean Sprite tag 1 (0 or 1): ");
|
|
value = !!TEST_BOOL1(sp);
|
|
value = getnumber(tempbuf, value, 65536L, 0);
|
|
|
|
if (value)
|
|
SET_BOOL1(sp);
|
|
else
|
|
RESET_BOOL1(sp);
|
|
|
|
break;
|
|
}
|
|
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_2])
|
|
{
|
|
keystatus[KEYSC_2] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 3:
|
|
strcpy(tempbuf, "Boolean Sprite tag 2 (0 or 1): ");
|
|
value = !!TEST_BOOL2(sp);
|
|
value = getnumber(tempbuf, value, 65536L, 0);
|
|
|
|
if (value)
|
|
SET_BOOL2(sp);
|
|
else
|
|
RESET_BOOL2(sp);
|
|
|
|
break;
|
|
}
|
|
|
|
printmessage("");
|
|
}
|
|
|
|
|
|
if (keystatus[KEYSC_3])
|
|
{
|
|
keystatus[KEYSC_3] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 3:
|
|
strcpy(tempbuf, "Boolean Sprite tag 3 (0 or 1): ");
|
|
value = !!TEST_BOOL3(sp);
|
|
value = getnumber(tempbuf, value, 65536L, 0);
|
|
|
|
if (value)
|
|
SET_BOOL3(sp);
|
|
else
|
|
RESET_BOOL3(sp);
|
|
|
|
break;
|
|
}
|
|
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_4])
|
|
{
|
|
keystatus[KEYSC_4] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 3:
|
|
strcpy(tempbuf, "Boolean Sprite tag 4 (0 or 1): ");
|
|
value = !!TEST_BOOL4(sp);
|
|
value = getnumber(tempbuf, value, 65536L, 0);
|
|
|
|
if (value)
|
|
SET_BOOL4(sp);
|
|
else
|
|
RESET_BOOL4(sp);
|
|
|
|
break;
|
|
}
|
|
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_5])
|
|
{
|
|
keystatus[KEYSC_5] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 3:
|
|
strcpy(tempbuf, "Boolean Sprite tag 5 (0 or 1): ");
|
|
value = !!TEST_BOOL5(sp);
|
|
value = getnumber(tempbuf, value, 65536L, 0);
|
|
|
|
if (value)
|
|
SET_BOOL5(sp);
|
|
else
|
|
RESET_BOOL5(sp);
|
|
|
|
break;
|
|
}
|
|
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_6])
|
|
{
|
|
keystatus[KEYSC_6] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 3:
|
|
strcpy(tempbuf, "Boolean Sprite tag 6 (0 or 1): ");
|
|
value = !!TEST_BOOL6(sp);
|
|
value = getnumber(tempbuf, value, 65536L, 0);
|
|
|
|
if (value)
|
|
SET_BOOL6(sp);
|
|
else
|
|
RESET_BOOL6(sp);
|
|
|
|
break;
|
|
}
|
|
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_7])
|
|
{
|
|
keystatus[KEYSC_7] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 3:
|
|
strcpy(tempbuf, "Boolean Sprite tag 7 (0 or 1): ");
|
|
value = !!TEST_BOOL7(sp);
|
|
value = getnumber(tempbuf, value, 65536L, 0);
|
|
|
|
if (value)
|
|
SET_BOOL7(sp);
|
|
else
|
|
RESET_BOOL7(sp);
|
|
|
|
break;
|
|
}
|
|
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_8])
|
|
{
|
|
keystatus[KEYSC_8] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 3:
|
|
strcpy(tempbuf, "Boolean Sprite tag 8 (0 or 1): ");
|
|
value = !!TEST_BOOL8(sp);
|
|
value = getnumber(tempbuf, value, 65536L, 0);
|
|
|
|
if (value)
|
|
SET_BOOL8(sp);
|
|
else
|
|
RESET_BOOL8(sp);
|
|
|
|
break;
|
|
}
|
|
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_9])
|
|
{
|
|
keystatus[KEYSC_9] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 3:
|
|
strcpy(tempbuf, "Boolean Sprite tag 9 (0 or 1): ");
|
|
value = !!TEST_BOOL9(sp);
|
|
value = getnumber(tempbuf, value, 65536L, 0);
|
|
|
|
if (value)
|
|
SET_BOOL9(sp);
|
|
else
|
|
RESET_BOOL9(sp);
|
|
|
|
break;
|
|
}
|
|
|
|
printmessage("");
|
|
}
|
|
|
|
if (keystatus[KEYSC_0])
|
|
{
|
|
keystatus[KEYSC_0] = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 3:
|
|
strcpy(tempbuf, "Boolean Sprite tag 10 (0 or 1): ");
|
|
value = !!TEST_BOOL10(sp);
|
|
value = getnumber(tempbuf, value, 65536L, 0);
|
|
|
|
if (value)
|
|
SET_BOOL10(sp);
|
|
else
|
|
RESET_BOOL10(sp);
|
|
|
|
break;
|
|
}
|
|
|
|
printmessage("");
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
#define COINCURSOR 2440
|
|
|
|
int intro;
|
|
void
|
|
ExtCheckKeysNotice(void)
|
|
{
|
|
#if 0
|
|
if (qsetmode == 200) // In 3D mode
|
|
{
|
|
if (intro < 600)
|
|
{
|
|
intro++;
|
|
sprintf(tempbuf, BUILD_VER_MSG);
|
|
printext256(46 * 8, (24 * 8) - 1, 0, -1, tempbuf, 1);
|
|
printext256(46 * 8, 24 * 8, 15, -1, tempbuf, 1);
|
|
rotatesprite((320 - 8) << 16, (200 - 8) << 16, 64 << 9, 0, COINCURSOR + (((4 - totalclock >> 3)) & 7), 0, 0, 0, 0, 0, xdim - 1, ydim - 1);
|
|
}
|
|
}
|
|
#endif
|
|
} // end
|
|
|
|
void
|
|
ExtCheckKeys(void)
|
|
{
|
|
extern short f_c;
|
|
|
|
// int ticdiff=0;
|
|
|
|
// Display BUILD notice
|
|
ExtCheckKeysNotice();
|
|
|
|
FAF_AfterDrawRooms();
|
|
|
|
// try it every time through the loop
|
|
SetSpriteExtra();
|
|
sector[0].extra = visibility;
|
|
|
|
// if(!BKeyPressed())
|
|
// ticdiff = totalclock-oldtotalclock; // Difference in tics from last time
|
|
|
|
// oldtotalclock = totalclock; // Set old clock to new time
|
|
|
|
// slackerclock += ticdiff;
|
|
// ticdiff = 0; // Set it back to 0!
|
|
|
|
|
|
if (qsetmode == 200) // In 3D mode
|
|
{
|
|
#define AVERAGEFRAMES 16
|
|
static int frameval[AVERAGEFRAMES], framecnt = 0;
|
|
int i;
|
|
|
|
i = totalclock;
|
|
if (i != frameval[framecnt])
|
|
{
|
|
sprintf(tempbuf, "%d", ((120 * AVERAGEFRAMES) / (i - frameval[framecnt])) + f_c);
|
|
printext256(0L, 0L, 1, -1, tempbuf, 1);
|
|
frameval[framecnt] = i;
|
|
}
|
|
framecnt = ((framecnt + 1) & (AVERAGEFRAMES - 1));
|
|
|
|
}
|
|
|
|
MoreKeys(searchstat, searchwall, searchsector, pointhighlight);
|
|
|
|
if (qsetmode == 200) // In 3D mode
|
|
{
|
|
Keys3D();
|
|
|
|
if (KEY_PRESSED(KEYSC_W))
|
|
{
|
|
KEY_PRESSED(KEYSC_W) = 0;
|
|
|
|
switch (searchstat)
|
|
{
|
|
case 0:
|
|
case 4:
|
|
wall[searchwall].picnum = temppicnum;
|
|
break;
|
|
case 1:
|
|
sector[searchsector].ceilingpicnum = temppicnum;
|
|
break;
|
|
case 2:
|
|
sector[searchsector].floorpicnum = temppicnum;
|
|
break;
|
|
case 3:
|
|
sprite[searchwall].picnum = temppicnum;
|
|
break;
|
|
}
|
|
}
|
|
|
|
// calling this twice seems to speed up the movement
|
|
editinput();
|
|
editinput();
|
|
}
|
|
else
|
|
{
|
|
|
|
if (KEY_PRESSED(KEYSC_QUOTE) && KEY_PRESSED(KEYSC_M))
|
|
{
|
|
KEY_PRESSED(KEYSC_M) = FALSE;
|
|
ShadeMenu();
|
|
}
|
|
|
|
// greater than & less than keys
|
|
// if (KEY_PRESSED(KEYSC_COMMA) || KEY_PRESSED(KEYSC_PERIOD))
|
|
// {
|
|
// KEY_PRESSED(KEYSC_COMMA) = KEY_PRESSED(KEYSC_PERIOD) = FALSE;
|
|
// }
|
|
|
|
// c for clip boxes
|
|
// will find out
|
|
if (KEY_PRESSED(KEYSC_QUOTE) && KEY_PRESSED(KEYSC_V))
|
|
{
|
|
KEY_PRESSED(KEYSC_V) = FALSE;
|
|
CaptionMode++;
|
|
if (CaptionMode >= CAPTION_MAX)
|
|
CaptionMode = 0;
|
|
}
|
|
|
|
if (keystatus[KEYSC_QUOTE] && keystatus[KEYSC_D])
|
|
{
|
|
keystatus[KEYSC_D] = 0;
|
|
SetClipdist2D();
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
void
|
|
ExtLoadMap(const char *mapname)
|
|
{
|
|
SPRITEp sp;
|
|
int i;
|
|
|
|
BuildStagTable();
|
|
|
|
SetSpriteExtra();
|
|
|
|
|
|
#if 0
|
|
Old visibility New visibility
|
|
8->16384
|
|
9->8192
|
|
10->4096
|
|
11->2048
|
|
12->1024
|
|
13->512
|
|
14->256
|
|
15->128
|
|
#endif
|
|
|
|
// if in valid range set visiblity for the map
|
|
if (sector[0].extra != -1 && sector[0].extra > 0 && sector[0].extra < 16384)
|
|
visibility = sector[0].extra;
|
|
|
|
else
|
|
// if NOT in valid range set a default
|
|
visibility = 2;
|
|
|
|
// Load up voxel sprites from voxel script file
|
|
//LoadKVXFromScript("swvoxfil.txt");
|
|
loaded_numwalls = numwalls;
|
|
}
|
|
|
|
void
|
|
ExtSaveMap(const char *mapname)
|
|
{
|
|
SPRITEp sp;
|
|
int i;
|
|
|
|
SetSpriteExtra();
|
|
ResetSpriteFound();
|
|
|
|
for (i = 0; i < MAXWALLS; i++)
|
|
{
|
|
if (wall[i].extra != 0)
|
|
wall[i].extra = 0;
|
|
}
|
|
}
|
|
|
|
const char *
|
|
ExtGetSectorCaption(short sectnum)
|
|
{
|
|
if ((sector[sectnum].lotag | sector[sectnum].hitag) == 0)
|
|
{
|
|
tempbuf[0] = 0;
|
|
}
|
|
else
|
|
{
|
|
sprintf(tempbuf, "%d,%d", sector[sectnum].hitag,
|
|
sector[sectnum].lotag);
|
|
}
|
|
return tempbuf;
|
|
}
|
|
|
|
const char *
|
|
ExtGetWallCaption(short wallnum)
|
|
{
|
|
if ((wall[wallnum].lotag | wall[wallnum].hitag) == 0)
|
|
{
|
|
tempbuf[0] = 0;
|
|
}
|
|
else
|
|
{
|
|
sprintf(tempbuf, "%d,%d", wall[wallnum].hitag,
|
|
wall[wallnum].lotag);
|
|
}
|
|
return tempbuf;
|
|
}
|
|
|
|
const char *
|
|
ExtGetSpriteCaption(short spritenum)
|
|
{
|
|
SPRITEp sp = &sprite[spritenum];
|
|
char *p = "";
|
|
char name[64];
|
|
char tp[30];
|
|
char multi_str[30] = "";
|
|
int16_t data;
|
|
|
|
data = TEST(sp->extra, SPRX_SKILL);
|
|
|
|
// Non ST1 sprites that are tagged like them
|
|
if (TEST_BOOL1(sp) && sp->picnum != ST1)
|
|
{
|
|
if (SP_TAG1(sp) < 0 || SP_TAG1(sp) > 1006)
|
|
sprintf(name, "Invalid Tag");
|
|
else
|
|
sprintf(name, "%s,", StagInfo[SP_TAG1(sp)].name); // This page faults if
|
|
// invalid #
|
|
|
|
p = name;
|
|
}
|
|
else
|
|
switch (sp->picnum)
|
|
{
|
|
case ST1:
|
|
if (SP_TAG1(sp) < 0 || SP_TAG1(sp) > 1006)
|
|
sprintf(name, "Invalid Tag");
|
|
else
|
|
sprintf(name, "*%s,", StagInfo[SP_TAG1(sp)].name);
|
|
p = name;
|
|
break;
|
|
case ST_QUICK_JUMP:
|
|
p = "QJ,";
|
|
break;
|
|
case ST_QUICK_JUMP_DOWN:
|
|
p = "QJD,";
|
|
break;
|
|
case ST_QUICK_SUPER_JUMP:
|
|
p = "QSJ,";
|
|
break;
|
|
case ST_QUICK_EXIT:
|
|
p = "QEXIT,";
|
|
break;
|
|
case ST_QUICK_SCAN:
|
|
p = "QSCAN,";
|
|
break;
|
|
case ST_QUICK_OPERATE:
|
|
p = "QOPERATE,";
|
|
break;
|
|
case ST_QUICK_DUCK:
|
|
p = "QDUCK,";
|
|
break;
|
|
case ST_QUICK_DEFEND:
|
|
p = "QDEFEND,";
|
|
break;
|
|
case NINJA_RUN_R0:
|
|
p = "NINJA,";
|
|
break;
|
|
case GORO_RUN_R0:
|
|
p = "GAURD,";
|
|
break;
|
|
case COOLIE_RUN_R0:
|
|
p = "COOLIE,";
|
|
break;
|
|
case COOLG_RUN_R0:
|
|
p = "GHOST,";
|
|
break;
|
|
case RIPPER_RUN_R0:
|
|
p = "RIPPER,";
|
|
break;
|
|
case SKEL_RUN_R0:
|
|
p = "SKEL,";
|
|
break;
|
|
case HORNET_RUN_R0:
|
|
p = "HORNET,";
|
|
break;
|
|
case SERP_RUN_R0:
|
|
p = "SERP,";
|
|
break;
|
|
case SKULL_R0:
|
|
p = "SKULL,";
|
|
break;
|
|
|
|
case ICON_STAR:
|
|
p = "STAR,";
|
|
break;
|
|
case ICON_LG_MINE:
|
|
p = "LG_MINE,";
|
|
break;
|
|
case ICON_GRENADE_LAUNCHER:
|
|
p = "GRENADE_LAUNCHER,";
|
|
break;
|
|
case ICON_LG_GRENADE:
|
|
p = "LG_GRENADE,";
|
|
break;
|
|
case ICON_MICRO_GUN:
|
|
p = "MICRO_GUN,";
|
|
break;
|
|
case ICON_MICRO_BATTERY:
|
|
p = "MICRO_BATTERY,";
|
|
break;
|
|
case ICON_SHOTGUN:
|
|
p = "RIOT_GUN,";
|
|
break;
|
|
case ICON_LG_SHOTSHELL:
|
|
p = "LG_SHOTSHELL,";
|
|
break;
|
|
case ICON_ROCKET:
|
|
p = "ROCKET,";
|
|
break;
|
|
case ICON_LG_ROCKET:
|
|
p = "LG_ROCKET,";
|
|
break;
|
|
case ICON_UZI:
|
|
p = "UZI,";
|
|
break;
|
|
case ICON_UZIFLOOR:
|
|
p = "UZI_FLOOR,";
|
|
break;
|
|
case ICON_LG_UZI_AMMO:
|
|
p = "LG_UZI_AMMO,";
|
|
break;
|
|
case ICON_GUARD_HEAD:
|
|
p = "FIRE,";
|
|
break;
|
|
case ICON_HEART:
|
|
p = "HEART,";
|
|
break;
|
|
case ICON_HEART_LG_AMMO:
|
|
p = "HEART_LG_AMMO,";
|
|
break;
|
|
|
|
case ICON_SPELL:
|
|
p = "SPELL,";
|
|
break;
|
|
case ICON_EXPLOSIVE_BOX:
|
|
p = "CRATE,";
|
|
break;
|
|
case ICON_SM_MEDKIT:
|
|
p = "FIRST_AID,";
|
|
break;
|
|
case ICON_MEDKIT:
|
|
p = "MEDKIT,";
|
|
break;
|
|
case ICON_CHEMBOMB:
|
|
p = "CHEM_BOMB,";
|
|
break;
|
|
case ICON_FLASHBOMB:
|
|
p = "FLASH_BOMB,";
|
|
break;
|
|
case ICON_NUKE:
|
|
p = "NUKE_BOMB,";
|
|
break;
|
|
case ICON_CALTROPS:
|
|
p = "CALTROPS,";
|
|
break;
|
|
case ICON_BOOSTER:
|
|
p = "BOT_HEALTH,";
|
|
break;
|
|
case ICON_HEAT_CARD:
|
|
p = "HEAT_SEEKERS,";
|
|
break;
|
|
// case ICON_ENVIRON_SUIT:
|
|
// p = "EVIRON_SUIT,";
|
|
// break;
|
|
case ICON_CLOAK:
|
|
p = "SMOKE_BOMB,";
|
|
break;
|
|
case ICON_FLY:
|
|
p = "FLY,";
|
|
break;
|
|
case ICON_GOROAMMO:
|
|
p = "GAURDAMMO,";
|
|
break;
|
|
case ICON_RAIL_GUN:
|
|
p = "RAIL_GUN,";
|
|
break;
|
|
case ICON_RAIL_AMMO:
|
|
p = "RAIL_AMMO,";
|
|
break;
|
|
case ICON_REPAIR_KIT:
|
|
p = "REPAIR_KIT,";
|
|
break;
|
|
/*
|
|
* case ICON_GAUNTAMMO: p = "GAUNTAMMO,"; break;
|
|
*/
|
|
case ICON_RINGAMMO:
|
|
p = "RINGAMMO,";
|
|
break;
|
|
case ICON_NAPALMAMMO:
|
|
p = "NAPALMAMMO,";
|
|
break;
|
|
case ICON_GRENADE:
|
|
p = "GRENADE,";
|
|
break;
|
|
case ICON_NIGHT_VISION:
|
|
p = "NIGHT_VISION,";
|
|
break;
|
|
case ICON_ARMOR:
|
|
p = "ARMOR,";
|
|
break;
|
|
case SKEL_LOCKED:
|
|
p = "SKELETON KEY LOCK,";
|
|
switch (sp->hitag)
|
|
{
|
|
case 1:
|
|
sp->pal = PALETTE_PLAYER9;
|
|
break;
|
|
case 2:
|
|
sp->pal = PALETTE_PLAYER7;
|
|
break;
|
|
case 3:
|
|
sp->pal = PALETTE_PLAYER6;
|
|
break;
|
|
case 4:
|
|
sp->pal = PALETTE_PLAYER4;
|
|
break;
|
|
case 5:
|
|
sp->pal = PALETTE_PLAYER4;
|
|
break;
|
|
case 6:
|
|
sp->pal = PALETTE_PLAYER1;
|
|
break;
|
|
case 7:
|
|
sp->pal = PALETTE_PLAYER8;
|
|
break;
|
|
case 8:
|
|
sp->pal = PALETTE_PLAYER9;
|
|
break;
|
|
}
|
|
break;
|
|
case RAMCARD_LOCKED:
|
|
p = "RAM CARD LOCK,";
|
|
switch (sp->hitag)
|
|
{
|
|
case 1:
|
|
sp->pal = PALETTE_PLAYER9;
|
|
break;
|
|
case 2:
|
|
sp->pal = PALETTE_PLAYER7;
|
|
break;
|
|
case 3:
|
|
sp->pal = PALETTE_PLAYER6;
|
|
break;
|
|
case 4:
|
|
sp->pal = PALETTE_PLAYER4;
|
|
break;
|
|
case 5:
|
|
sp->pal = PALETTE_PLAYER4;
|
|
break;
|
|
case 6:
|
|
sp->pal = PALETTE_PLAYER1;
|
|
break;
|
|
case 7:
|
|
sp->pal = PALETTE_PLAYER8;
|
|
break;
|
|
case 8:
|
|
sp->pal = PALETTE_PLAYER9;
|
|
break;
|
|
}
|
|
break;
|
|
case CARD_LOCKED:
|
|
p = "CARD KEY LOCK,";
|
|
switch (sp->hitag)
|
|
{
|
|
case 1:
|
|
sp->pal = PALETTE_PLAYER9;
|
|
break;
|
|
case 2:
|
|
sp->pal = PALETTE_PLAYER7;
|
|
break;
|
|
case 3:
|
|
sp->pal = PALETTE_PLAYER6;
|
|
break;
|
|
case 4:
|
|
sp->pal = PALETTE_PLAYER4;
|
|
break;
|
|
case 5:
|
|
sp->pal = PALETTE_PLAYER4;
|
|
break;
|
|
case 6:
|
|
sp->pal = PALETTE_PLAYER1;
|
|
break;
|
|
case 7:
|
|
sp->pal = PALETTE_PLAYER8;
|
|
break;
|
|
case 8:
|
|
sp->pal = PALETTE_PLAYER9;
|
|
break;
|
|
}
|
|
break;
|
|
case RED_KEY:
|
|
p = "RED KEY,";
|
|
sp->pal = PALETTE_PLAYER9; // Hard set the palette
|
|
break;
|
|
case BLUE_KEY:
|
|
p = "BLUE KEY,";
|
|
sp->pal = PALETTE_PLAYER7; // Hard set the palette
|
|
break;
|
|
case GREEN_KEY:
|
|
p = "GREEN KEY,";
|
|
sp->pal = PALETTE_PLAYER6; // Hard set the palette
|
|
break;
|
|
case YELLOW_KEY:
|
|
p = "YEL KEY,";
|
|
sp->pal = PALETTE_PLAYER4; // Hard set the palette
|
|
break;
|
|
case RED_CARD:
|
|
p = "RED CARD,";
|
|
sp->pal = PALETTE_PLAYER9; // Hard set the palette
|
|
break;
|
|
case BLUE_CARD:
|
|
p = "BLUE CARD,";
|
|
sp->pal = PALETTE_PLAYER7; // Hard set the palette
|
|
break;
|
|
case GREEN_CARD:
|
|
p = "GREEN CARD,";
|
|
sp->pal = PALETTE_PLAYER6; // Hard set the palette
|
|
break;
|
|
case YELLOW_CARD:
|
|
p = "YEL CARD,";
|
|
sp->pal = PALETTE_PLAYER4; // Hard set the palette
|
|
break;
|
|
case SILVER_SKELKEY:
|
|
p = "SILVER SKELKEY,";
|
|
sp->pal = PALETTE_PLAYER1; // Hard set the palette
|
|
break;
|
|
case GOLD_SKELKEY:
|
|
p = "GOLD SKELKEY,";
|
|
sp->pal = PALETTE_PLAYER4; // Hard set the palette
|
|
break;
|
|
case BRONZE_SKELKEY:
|
|
p = "BRONZE SKELKEY,";
|
|
sp->pal = PALETTE_PLAYER8; // Hard set the palette
|
|
break;
|
|
case RED_SKELKEY:
|
|
p = "RED SKELKEY,";
|
|
sp->pal = PALETTE_PLAYER9; // Hard set the palette
|
|
break;
|
|
case RED_KEY_STATUE:
|
|
p = "RED STAT,";
|
|
break;
|
|
case BLUE_KEY_STATUE:
|
|
p = "BLUE STAT,";
|
|
break;
|
|
case GREEN_KEY_STATUE:
|
|
p = "GREEN STAT,";
|
|
break;
|
|
case YELLOW_KEY_STATUE:
|
|
p = "YEL STAT,";
|
|
break;
|
|
default:
|
|
p = "";
|
|
break;
|
|
}
|
|
|
|
if (sp->picnum != ST1)
|
|
{
|
|
if (sp->lotag == TAG_SPRITE_HIT_MATCH)
|
|
{
|
|
p = "TAG_SPRITE_HIT_MATCH";
|
|
}
|
|
|
|
// multi
|
|
if (TEST(sp->extra, SPRX_MULTI_ITEM))
|
|
strcpy(multi_str, "MULTI,");
|
|
}
|
|
|
|
// track
|
|
if (sp->picnum >= TRACK_SPRITE && sp->picnum < TRACK_SPRITE + 100)
|
|
{
|
|
sprintf(tp, "T%d,", sp->picnum - TRACK_SPRITE);
|
|
p = tp;
|
|
}
|
|
|
|
switch (CaptionMode)
|
|
{
|
|
case CAPTION_NONE:
|
|
tempbuf[0] = 0;
|
|
break;
|
|
|
|
case CAPTION_DEFAULT:
|
|
if ((sprite[spritenum].lotag | sprite[spritenum].hitag) == 0)
|
|
//tempbuf[0] = NULL;
|
|
sprintf(tempbuf, "S:%d", data);
|
|
else
|
|
sprintf(tempbuf, "S:%d,%d,%d", data, sprite[spritenum].hitag, sprite[spritenum].lotag);
|
|
break;
|
|
|
|
|
|
case CAPTION_NAMES:
|
|
// Show clip boxes in default mode
|
|
if (sp->hitag == SO_CLIP_BOX)
|
|
DrawClipBox(spritenum);
|
|
if (sp->hitag == SECT_SO_CLIP_DIST)
|
|
DrawClipBox(spritenum);
|
|
|
|
if ((sprite[spritenum].lotag | sprite[spritenum].hitag) == 0)
|
|
sprintf(tempbuf, "S:%d,%s%s", data, p, multi_str);
|
|
else
|
|
// name and numbers - name only prints if not null string
|
|
sprintf(tempbuf, "%s%s%d,%d", p, multi_str, sprite[spritenum].hitag, sprite[spritenum].lotag);
|
|
|
|
break;
|
|
|
|
case CAPTION_MOST:
|
|
if ((sprite[spritenum].lotag | sprite[spritenum].hitag) == 0)
|
|
sprintf(tempbuf, "%s%s", p, multi_str);
|
|
else
|
|
sprintf(tempbuf, "%s%s%d,%d,%d,%d,%d,%d", p, multi_str,
|
|
SPRITE_TAG1(spritenum),
|
|
SPRITE_TAG2(spritenum),
|
|
SPRITE_TAG3(spritenum),
|
|
SPRITE_TAG4(spritenum),
|
|
SPRITE_TAG5(spritenum),
|
|
SPRITE_TAG6(spritenum));
|
|
break;
|
|
|
|
case CAPTION_ALL:
|
|
// if (sp->hitag == SO_CLIP_BOX)
|
|
// DrawClipBox(spritenum);
|
|
|
|
if ((sprite[spritenum].lotag | sprite[spritenum].hitag) == 0)
|
|
sprintf(tempbuf, "%s%s", p, multi_str);
|
|
else
|
|
sprintf(tempbuf, "%s%s%d,%d,%d,%d,%d,%d,%d,%d,%d,%d", p, multi_str,
|
|
SPRITE_TAG1(spritenum),
|
|
SPRITE_TAG2(spritenum),
|
|
SPRITE_TAG3(spritenum),
|
|
SPRITE_TAG4(spritenum),
|
|
SPRITE_TAG5(spritenum),
|
|
SPRITE_TAG6(spritenum),
|
|
SPRITE_TAG7(spritenum),
|
|
SPRITE_TAG8(spritenum),
|
|
SPRITE_TAG9(spritenum),
|
|
SPRITE_TAG10(spritenum));
|
|
break;
|
|
}
|
|
|
|
|
|
return tempbuf;
|
|
}
|
|
|
|
void
|
|
SectorMidPoint(short sectnum, int *xmid, int *ymid, int *zmid)
|
|
{
|
|
short startwall, endwall, j;
|
|
int xsum = 0, ysum = 0;
|
|
WALLp wp;
|
|
|
|
startwall = sector[sectnum].wallptr;
|
|
endwall = startwall + sector[sectnum].wallnum - 1;
|
|
|
|
for (wp = &wall[startwall], j = startwall; j <= endwall; wp++, j++)
|
|
{
|
|
xsum += wp->x;
|
|
ysum += wp->y;
|
|
}
|
|
|
|
*xmid = xsum / (endwall - startwall + 1);
|
|
*ymid = ysum / (endwall - startwall + 1);
|
|
|
|
*zmid = DIV2(sector[sectnum].floorz + sector[sectnum].ceilingz);
|
|
}
|
|
|
|
void
|
|
DrawClipBox(short spritenum)
|
|
{
|
|
int x, y, z;
|
|
int radius;
|
|
extern int zoom;
|
|
|
|
if (sprite[spritenum].hitag == SO_CLIP_BOX)
|
|
{
|
|
x = mulscale14(sprite[spritenum].x - posx, zoom);
|
|
y = mulscale14(sprite[spritenum].y - posy, zoom);
|
|
}
|
|
else if (sprite[spritenum].hitag == SECT_SO_CLIP_DIST)
|
|
{
|
|
SectorMidPoint(sprite[spritenum].sectnum,&x, &y, &z);
|
|
x = mulscale14(x - posx, zoom);
|
|
y = mulscale14(y - posy, zoom);
|
|
}
|
|
|
|
x += 320;
|
|
y += 200;
|
|
|
|
radius = mulscale14(sprite[spritenum].lotag, zoom);
|
|
|
|
#define BOX_COLOR 3
|
|
// upper
|
|
drawline16(x - radius, y - radius, x + radius, y - radius, BOX_COLOR);
|
|
// lower
|
|
drawline16(x - radius, y + radius, x + radius, y + radius, BOX_COLOR);
|
|
// left
|
|
drawline16(x - radius, y - radius, x - radius, y + radius, BOX_COLOR);
|
|
// right
|
|
drawline16(x + radius, y - radius, x + radius, y + radius, BOX_COLOR);
|
|
}
|
|
|
|
void
|
|
ExtShowSectorData(short sectnum) // F5
|
|
{
|
|
int i, x, y, x2;
|
|
|
|
if (qsetmode == 200) // In 3D mode
|
|
return;
|
|
|
|
clearmidstatbar16(); // Clear middle of status bar
|
|
|
|
|
|
// if (keystatus[KEYSC_F5] )
|
|
// {
|
|
KEY_PRESSED(KEYSC_F5) = 0;
|
|
for (i = 0; i < MAXSPRITES; i++)
|
|
numsprite[i] = 0;
|
|
for (i = 0; i < MAXSPRITES; i++)
|
|
multisprite[i] = 0;
|
|
for (i = 0; i < MAXSPRITES; i++)
|
|
{
|
|
if (sprite[i].statnum == 0)
|
|
{
|
|
if (TEST(sprite[i].extra, SPRX_MULTI_ITEM))
|
|
{
|
|
if (sprite[i].picnum == ICON_UZIFLOOR)
|
|
multisprite[ICON_UZI]++;
|
|
else
|
|
multisprite[sprite[i].picnum]++;
|
|
|
|
}
|
|
else
|
|
{
|
|
if (sprite[i].picnum == ICON_UZIFLOOR)
|
|
numsprite[ICON_UZI]++;
|
|
else
|
|
numsprite[sprite[i].picnum]++;
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
clearmidstatbar16(); // Clear middle of status bar
|
|
|
|
x = 1;
|
|
x2 = 14;
|
|
y = 4;
|
|
printext16(x * 8, ydim16+y * 8, 11, -1, "Item Count", 0);
|
|
PrintStatus("10%Health=", numsprite[ICON_SM_MEDKIT], x, y + 2, 11);
|
|
PrintStatus("", multisprite[ICON_SM_MEDKIT], x2, y + 2, 1);
|
|
PrintStatus("HealthBot=", numsprite[ICON_BOOSTER], x, y + 3, 11);
|
|
PrintStatus("", multisprite[ICON_BOOSTER], x2, y + 3, 1);
|
|
PrintStatus("Armor =", numsprite[ICON_ARMOR], x, y + 4, 11);
|
|
PrintStatus("", multisprite[ICON_ARMOR], x2, y + 4, 1);
|
|
|
|
x = 17;
|
|
x2 = 30;
|
|
y = 4;
|
|
printext16(x * 8, ydim16+y * 8, 11, -1, "Inventory", 0);
|
|
PrintStatus("Med-Kit =", numsprite[ICON_MEDKIT], x, y + 2, 11);
|
|
PrintStatus("", multisprite[ICON_MEDKIT], x2, y + 2, 1);
|
|
PrintStatus("Bio_Suit =", numsprite[ICON_ENVIRON_SUIT], x, y + 3, 11);
|
|
PrintStatus("", multisprite[ICON_ENVIRON_SUIT], x2, y + 3, 1);
|
|
PrintStatus("NightGogs=", numsprite[ICON_NIGHT_VISION], x, y + 4, 11);
|
|
PrintStatus("", multisprite[ICON_NIGHT_VISION], x2, y + 4, 1);
|
|
PrintStatus("SmokeBomb=", numsprite[ICON_CLOAK], x, y + 5, 11);
|
|
PrintStatus("", multisprite[ICON_CLOAK], x2, y + 5, 1);
|
|
PrintStatus("Tool_Box =", numsprite[ICON_REPAIR_KIT], x, y + 6, 11);
|
|
PrintStatus("", multisprite[ICON_REPAIR_KIT], x2, y + 6, 1);
|
|
PrintStatus("Heat_Card=", numsprite[ICON_HEAT_CARD], x, y + 7, 11);
|
|
PrintStatus("", multisprite[ICON_HEAT_CARD], x2, y + 7, 1);
|
|
PrintStatus("FlashBomb=", numsprite[ICON_FLASHBOMB], x, y + 8, 11);
|
|
PrintStatus("", multisprite[ICON_FLASHBOMB], x2, y + 8, 1);
|
|
PrintStatus("Caltrops =", numsprite[ICON_CALTROPS], x, y + 9, 11);
|
|
PrintStatus("", multisprite[ICON_CALTROPS], x2, y + 9, 1);
|
|
|
|
x = 33;
|
|
x2 = 46;
|
|
y = 4;
|
|
printext16(x * 8, ydim16+y * 8, 11, -1, "Weapon Count", 0);
|
|
PrintStatus("Shuriken =", numsprite[ICON_STAR], x, y + 2, 11);
|
|
PrintStatus("", multisprite[ICON_STAR], x2, y + 2, 1);
|
|
PrintStatus("Uzi =", numsprite[ICON_UZI], x, y + 3, 11);
|
|
PrintStatus("", multisprite[ICON_UZI], x2, y + 3, 1);
|
|
PrintStatus("Riot_Gun =", numsprite[ICON_SHOTGUN], x, y + 4, 11);
|
|
PrintStatus("", multisprite[ICON_SHOTGUN], x2, y + 4, 1);
|
|
PrintStatus("Misl_Bat =", numsprite[ICON_MICRO_GUN], x, y + 5, 11);
|
|
PrintStatus("", multisprite[ICON_MICRO_GUN], x2, y + 5, 1);
|
|
PrintStatus("40mm =", numsprite[ICON_GRENADE_LAUNCHER], x, y + 6, 11);
|
|
PrintStatus("", multisprite[ICON_GRENADE_LAUNCHER], x2, y + 6, 1);
|
|
PrintStatus("Mines =", numsprite[ICON_LG_MINE], x, y + 7, 11);
|
|
PrintStatus("", multisprite[ICON_LG_MINE], x2, y + 7, 1);
|
|
PrintStatus("Rail_Gun =", numsprite[ICON_RAIL_GUN], x, y + 8, 11);
|
|
PrintStatus("", multisprite[ICON_RAIL_GUN], x2, y + 8, 1);
|
|
PrintStatus("Evil Head=", numsprite[ICON_GUARD_HEAD], x, y + 9, 11);
|
|
PrintStatus("", multisprite[ICON_GUARD_HEAD], x2, y + 9, 1);
|
|
PrintStatus("Heart =", numsprite[ICON_HEART], x, y + 10, 11);
|
|
PrintStatus("", multisprite[ICON_HEART], x2, y + 10, 1);
|
|
|
|
x = 49;
|
|
x2 = 62;
|
|
y = 4;
|
|
printext16(x * 8, ydim16+y * 8, 11, -1, "Ammo Count", 0);
|
|
PrintStatus("Bullets =", numsprite[ICON_LG_UZI_AMMO], x, y + 2, 11);
|
|
PrintStatus("", multisprite[ICON_LG_UZI_AMMO], x2, y + 2, 1);
|
|
PrintStatus("ShotShell=", numsprite[ICON_LG_SHOTSHELL], x, y + 3, 11);
|
|
PrintStatus("", multisprite[ICON_LG_SHOTSHELL], x2, y + 3, 1);
|
|
PrintStatus("Rockets =", numsprite[ICON_MICRO_BATTERY], x, y + 4, 11);
|
|
PrintStatus("", multisprite[ICON_MICRO_BATTERY], x2, y + 4, 1);
|
|
PrintStatus("40mmShell=", numsprite[ICON_LG_GRENADE], x, y + 5, 11);
|
|
PrintStatus("", multisprite[ICON_LG_GRENADE], x2, y + 5, 1);
|
|
PrintStatus("Rail_Pack=", numsprite[ICON_RAIL_AMMO], x, y + 6, 11);
|
|
PrintStatus("", multisprite[ICON_RAIL_AMMO], x2, y + 6, 1);
|
|
|
|
|
|
// Show next tags
|
|
FindNextTag();
|
|
ShowNextTag();
|
|
/*
|
|
printext16(65*8,ydim16+4*8,11,-1,"MISC",0);
|
|
PrintStatus("Secrets =",secrets,65,6,11);
|
|
printext16(65*8,ydim16+7*8,11,-1,"ACTORS",0);
|
|
PrintStatus("Skill 1 =",totalactors1,65,8,11);
|
|
PrintStatus("Skill 2 =",totalactors2,65,9,11);
|
|
PrintStatus("Skill 3 =",totalactors3,65,10,11);
|
|
PrintStatus("Skill 4 =",totalactors4,65,11,11);
|
|
PrintStatus("Respawn =",totalrespawn,65,12,11);
|
|
*/
|
|
// }
|
|
|
|
#if 0
|
|
sprintf(tempbuf, "Sector %d", sectnum);
|
|
printext16(8, ydim16+32, 11, -1, tempbuf, 0);
|
|
|
|
printext16(8, ydim16+48, 11, -1, "8*8 font: ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz 0123456789", 0);
|
|
printext16(8, ydim16+56, 11, -1, "3*5 font: ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz 0123456789", 1);
|
|
|
|
drawline16(320, 68, 344, 80, 4); // Draw house
|
|
drawline16(344, 80, 344, 116, 4);
|
|
drawline16(344, 116, 296, 116, 4);
|
|
drawline16(296, 116, 296, 80, 4);
|
|
drawline16(296, 80, 320, 68, 4);
|
|
#endif
|
|
}
|
|
|
|
void
|
|
ExtShowWallData(short wallnum) // F6
|
|
{
|
|
if (qsetmode == 200) // In 3D mode
|
|
return;
|
|
|
|
|
|
clearmidstatbar16(); // Clear middle of status bar
|
|
sprintf(tempbuf, "Wall %d", wallnum);
|
|
printext16(8, ydim16+32, 11, -1, tempbuf, 0);
|
|
}
|
|
|
|
void
|
|
ExtShowSpriteData(short spritenum) // F6
|
|
{
|
|
if (qsetmode == 200) // In 3D mode
|
|
return;
|
|
|
|
while (KEY_PRESSED(KEYSC_F6)) ;
|
|
ResetKeys();
|
|
ContextHelp(spritenum); // Get context sensitive help
|
|
|
|
|
|
// OLD
|
|
// clearmidstatbar16();
|
|
// sprintf(tempbuf, "Sprite %d", spritenum);
|
|
// printext16(8, ydim16+32, 11, -1, tempbuf, 0);
|
|
}
|
|
|
|
void
|
|
ExtEditSectorData(short sectnum) // F7
|
|
{
|
|
short key_num;
|
|
SPRITEp sp;
|
|
|
|
if (qsetmode == 200) // In 3D mode
|
|
return;
|
|
|
|
|
|
sp = &sprite[FindSpriteNum]; // Set sprite to current spritenum
|
|
|
|
clearmidstatbar16(); // Clear middle of status bar
|
|
|
|
sprintf(tempbuf, "Current attributes for sprite being searched for:");
|
|
printext16(8, ydim16+32, 11, -1, tempbuf, 0);
|
|
|
|
sprintf(tempbuf, "PicNum = %d", FindPicNum);
|
|
printext16(8, ydim16+32 + 16, 11, -1, tempbuf, 0);
|
|
|
|
sprintf(tempbuf, "HiTag = %d", sp->hitag);
|
|
printext16(8, ydim16+32 + 24, 11, -1, tempbuf, 0);
|
|
|
|
sprintf(tempbuf, "LowTag = %d", sp->lotag);
|
|
printext16(8, ydim16+32 + 32, 11, -1, tempbuf, 0);
|
|
|
|
FindNextSprite(FindPicNum);
|
|
}
|
|
|
|
void
|
|
ExtEditWallData(short wallnum) // F8
|
|
{
|
|
// short nickdata;
|
|
|
|
if (qsetmode == 200) // In 3D mode
|
|
return;
|
|
|
|
// sprintf(tempbuf, "Wall (%ld): ", wallnum);
|
|
// nickdata = 0;
|
|
// nickdata = getnumber16(tempbuf, nickdata, 65536L);
|
|
|
|
// printmessage16(""); // Clear message box (top right of
|
|
// status bar)
|
|
// ExtShowWallData(wallnum);
|
|
}
|
|
|
|
void
|
|
ExtEditSpriteData(short spritenum) // F8
|
|
{
|
|
uint8_t* key;
|
|
short data;
|
|
SPRITEp sp;
|
|
|
|
SetSpriteExtra();
|
|
|
|
sp = &sprite[spritenum];
|
|
|
|
|
|
if (qsetmode == 200) // In 3D mode
|
|
return;
|
|
|
|
clearmidstatbar16(); // Clear middle of status bar
|
|
printext16(8, ydim16+32, 11, -1, "(1) Skill Level - 0=Easy 1=Normal 2=Hard 3=Crazy", 0);
|
|
printext16(8, ydim16+32 + 8, 11, -1, "(2) Multi-Player Item Toggle", 0);
|
|
printext16(8, ydim16+32 + 16, 11, -1, "(3) Find Sprite", 0);
|
|
printext16(8, ydim16+32 + 24, 11, -1, "(4) Dbug Toggle (* Programming use only *) ", 0);
|
|
showframe(1);
|
|
|
|
while (KEY_PRESSED(KEYSC_F8)) handleevents();
|
|
|
|
ResetKeys();
|
|
|
|
while ((key = BKeyPressed()) == NULL) handleevents();
|
|
|
|
if (key == (uint8_t*)&KEY_PRESSED(KEYSC_1) || key == (uint8_t*)&KEY_PRESSED(KEYSC_F8))
|
|
{
|
|
*key = FALSE;
|
|
|
|
sprintf(tempbuf, "Sprite (%d) Skill Level (0-3) : ", spritenum);
|
|
|
|
data = TEST(sp->extra, SPRX_SKILL);
|
|
|
|
data = getnumber16(tempbuf, data, 65536L, 1);
|
|
|
|
if (data > 3)
|
|
data = 3;
|
|
|
|
RESET(sp->extra, SPRX_SKILL);
|
|
SET(sp->extra, data);
|
|
}
|
|
else if (key == (uint8_t*)&KEY_PRESSED(KEYSC_2) || key == (uint8_t*)&KEY_PRESSED(KEYSC_F9))
|
|
{
|
|
*key = FALSE;
|
|
|
|
FLIP(sprite[spritenum].extra, SPRX_MULTI_ITEM);
|
|
}
|
|
else if (key == (uint8_t*)&KEY_PRESSED(KEYSC_3) || key == (uint8_t*)&KEY_PRESSED(KEYSC_F10))
|
|
{
|
|
*key = FALSE;
|
|
|
|
do
|
|
{
|
|
DISPLAY:
|
|
clearmidstatbar16();
|
|
printext16(8, ydim16+32, 11, -1, "Toggle Sprite Seach Criteria. ESC quits.", 0);
|
|
|
|
printext16(8, ydim16+32 + 16, 11, -1, "(1) Use PicNum in search: ", 0);
|
|
if (bFindPicNum)
|
|
printext16(8 + 240, ydim16+32 + 16, 11, -1, "TRUE", 0);
|
|
else
|
|
printext16(8 + 240, ydim16+32 + 16, 11, -1, "FALSE", 0);
|
|
|
|
printext16(8, ydim16+32 + 24, 11, -1, "(2) Use HiTag in search: ", 0);
|
|
if (bFindHiTag)
|
|
printext16(8 + 240, ydim16+32 + 24, 11, -1, "TRUE", 0);
|
|
else
|
|
printext16(8 + 240, ydim16+32 + 24, 11, -1, "FALSE", 0);
|
|
|
|
printext16(8, ydim16+32 + 32, 11, -1, "(3) Use LowTag in search: ", 0);
|
|
if (bFindLowTag)
|
|
printext16(8 + 240, ydim16+32 + 32, 11, -1, "TRUE", 0);
|
|
else
|
|
printext16(8 + 240, ydim16+32 + 32, 11, -1, "FALSE", 0);
|
|
showframe(1);
|
|
|
|
// Disallow invalid settings
|
|
if (!bFindPicNum && !bFindHiTag && !bFindLowTag)
|
|
{
|
|
bFindPicNum = TRUE;
|
|
goto DISPLAY;
|
|
}
|
|
|
|
while (KEY_PRESSED(KEYSC_1) || KEY_PRESSED(KEYSC_2) || KEY_PRESSED(KEYSC_3)
|
|
|| KEY_PRESSED(KEYSC_4)) handleevents();
|
|
|
|
ResetKeys();
|
|
|
|
while ((key = BKeyPressed()) == NULL) handleevents();
|
|
|
|
if (key == (uint8_t*)&KEY_PRESSED(KEYSC_1))
|
|
{
|
|
*key = FALSE;
|
|
bFindPicNum = !bFindPicNum;
|
|
}
|
|
else if (key == (uint8_t*)&KEY_PRESSED(KEYSC_2))
|
|
{
|
|
*key = FALSE;
|
|
bFindHiTag = !bFindHiTag;
|
|
}
|
|
else if (key == (uint8_t*)&KEY_PRESSED(KEYSC_3))
|
|
{
|
|
*key = FALSE;
|
|
bFindLowTag = !bFindLowTag;
|
|
}
|
|
|
|
}
|
|
while ((KEY_PRESSED(0x1c) == 0) && (KEY_PRESSED(0x1) == 0)); // Enter, ESC
|
|
KEY_PRESSED(0x1c) = 0;
|
|
KEY_PRESSED(0x1) = 0;
|
|
|
|
FindSprite(sprite[spritenum].picnum, spritenum);
|
|
}
|
|
else if (key == (uint8_t*)&KEY_PRESSED(KEYSC_4))
|
|
{
|
|
*key = FALSE;
|
|
FLIP(sprite[spritenum].extra, SPRX_BLOCK);
|
|
}
|
|
|
|
printmessage16("");
|
|
|
|
clearmidstatbar16(); // Clear middle of status bar
|
|
|
|
sprintf(tempbuf, "Current attributes for selected sprite:");
|
|
printext16(8, ydim16+32, 11, -1, tempbuf, 0);
|
|
|
|
sprintf(tempbuf, " Skill = %d", TEST(sp->extra, SPRX_SKILL));
|
|
printext16(8, ydim16+32 + 16, 11, -1, tempbuf, 0);
|
|
|
|
sprintf(tempbuf, " Multi Item = %d", !!TEST(sp->extra, SPRX_MULTI_ITEM));
|
|
printext16(8, ydim16+32 + 24, 11, -1, tempbuf, 0);
|
|
|
|
sprintf(tempbuf, " Debug = %d", !!TEST(sp->extra, SPRX_BLOCK));
|
|
printext16(8, ydim16+32 + 32, 11, -1, tempbuf, 0);
|
|
|
|
}
|
|
|
|
void
|
|
PlaxSetShade(void)
|
|
{
|
|
short data;
|
|
short shade;
|
|
int i, count = 0;
|
|
|
|
if (qsetmode == 200) // In 3D mode
|
|
return;
|
|
|
|
sprintf(tempbuf, "Plax Sky set shade to #: ");
|
|
shade = getnumber16(tempbuf, 0, 65536L, 1);
|
|
|
|
if (shade == 0)
|
|
return;
|
|
|
|
for (i = 0, count = 0; i < numsectors; i++)
|
|
{
|
|
if (TEST(sector[i].ceilingstat, CEILING_STAT_PLAX))
|
|
{
|
|
sector[i].ceilingshade = shade;
|
|
count++;
|
|
}
|
|
}
|
|
|
|
printmessage16("");
|
|
|
|
clearmidstatbar16(); // Clear middle of status bar
|
|
|
|
sprintf(tempbuf, "%d Plax Sky shades set.", count);
|
|
printext16(8, ydim16+32, 11, -1, tempbuf, 0);
|
|
}
|
|
|
|
void
|
|
PlaxAdjustShade(void)
|
|
{
|
|
short data;
|
|
short shade;
|
|
int i, count = 0;
|
|
|
|
if (qsetmode == 200) // In 3D mode
|
|
return;
|
|
|
|
sprintf(tempbuf, "Plax Sky adjust shade by (+10000 for negative): ");
|
|
shade = getnumber16(tempbuf, 0, 65536L, 1);
|
|
|
|
if (shade == 0)
|
|
return;
|
|
|
|
if (shade > 10000)
|
|
{
|
|
shade = -(shade - 10000);
|
|
}
|
|
|
|
|
|
for (i = 0; i < numsectors; i++)
|
|
{
|
|
if (TEST(sector[i].ceilingstat, CEILING_STAT_PLAX))
|
|
{
|
|
sector[i].ceilingshade += shade;
|
|
}
|
|
}
|
|
|
|
printmessage16("");
|
|
|
|
clearmidstatbar16(); // Clear middle of status bar
|
|
|
|
sprintf(tempbuf, "%d Plax Sky shades adjusted.", count);
|
|
printext16(8, ydim16+32, 11, -1, tempbuf, 0);
|
|
}
|
|
|
|
void
|
|
AdjustShade(void)
|
|
{
|
|
short data;
|
|
short shade;
|
|
int i, count;
|
|
short SpriteNum, NextSprite;
|
|
|
|
if (qsetmode == 200) // In 3D mode
|
|
return;
|
|
|
|
sprintf(tempbuf, "Adjust amount (+10000 for negative): ");
|
|
shade = getnumber16(tempbuf, 0, 65536L, 1);
|
|
|
|
if (shade == 0)
|
|
return;
|
|
|
|
if (shade > 10000)
|
|
{
|
|
shade = -(shade - 10000);
|
|
}
|
|
|
|
if (highlightsectorcnt > -1)
|
|
{
|
|
short startwall, endwall;
|
|
short i, j = 0;
|
|
|
|
for (i = 0; i < highlightsectorcnt; i++)
|
|
{
|
|
sector[highlightsector[i]].floorshade += shade;
|
|
sector[highlightsector[i]].ceilingshade += shade;
|
|
|
|
TRAVERSE_SPRITE_SECT(headspritesect[highlightsector[i]], SpriteNum, NextSprite)
|
|
{
|
|
sprite[SpriteNum].shade += shade;
|
|
}
|
|
|
|
startwall = sector[highlightsector[i]].wallptr;
|
|
endwall = startwall + sector[highlightsector[i]].wallnum - 1;
|
|
|
|
for (j = startwall; j <= endwall; j++)
|
|
{
|
|
if (!TEST(wall[j].extra, 0x1))
|
|
{
|
|
SET(wall[j].extra, 0x1);
|
|
wall[j].shade += shade;
|
|
}
|
|
|
|
if (!TEST(wall[wall[j].nextwall].extra, 0x1))
|
|
{
|
|
SET(wall[wall[j].nextwall].extra, 0x1);
|
|
wall[wall[j].nextwall].shade += shade;
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
for (i = 0; i < MAXWALLS; i++)
|
|
{
|
|
RESET(wall[j].extra, 0x1);
|
|
}
|
|
|
|
}
|
|
else
|
|
{
|
|
for (i = count = 0; i < numwalls; i++)
|
|
{
|
|
wall[i].shade += shade;
|
|
}
|
|
|
|
for (i = 0; i < numsectors; i++)
|
|
{
|
|
sector[i].floorshade += shade;
|
|
sector[i].ceilingshade += shade;
|
|
|
|
TRAVERSE_SPRITE_SECT(headspritesect[i], SpriteNum, NextSprite)
|
|
{
|
|
sprite[SpriteNum].shade += shade;
|
|
}
|
|
}
|
|
}
|
|
|
|
printmessage16("");
|
|
|
|
clearmidstatbar16(); // Clear middle of status bar
|
|
}
|
|
|
|
|
|
void
|
|
SetClipdist2D(void)
|
|
{
|
|
short dist;
|
|
int i;
|
|
short num;
|
|
|
|
if (qsetmode == 200) // In 3D mode
|
|
return;
|
|
|
|
if (highlightcnt <= -1)
|
|
return;
|
|
|
|
sprintf(tempbuf, "Sprite Clipdist: ");
|
|
dist = getnumber16(tempbuf, 0, 65536L, 1);
|
|
|
|
for (i = 0; i < highlightcnt; i++)
|
|
{
|
|
if (TEST(highlight[i], SPRITE_FLAG))
|
|
{
|
|
num = RESET(highlight[i], SPRITE_FLAG);
|
|
sprite[highlight[i]].clipdist = dist;
|
|
}
|
|
}
|
|
|
|
printmessage16("");
|
|
|
|
clearmidstatbar16(); // Clear middle of status bar
|
|
}
|
|
|
|
void
|
|
AdjustVisibility(void)
|
|
{
|
|
short data;
|
|
short vis;
|
|
int i, count = 0;
|
|
|
|
if (qsetmode == 200) // In 3D mode
|
|
return;
|
|
|
|
sprintf(tempbuf, "Adjust non-zero vis sectors by (+10000 for neg): ");
|
|
vis = getnumber16(tempbuf, 0, 65536L, 1);
|
|
|
|
if (vis == 0)
|
|
return;
|
|
|
|
if (vis > 10000)
|
|
{
|
|
vis = -(vis - 10000);
|
|
}
|
|
|
|
if (highlightsectorcnt > -1)
|
|
{
|
|
short i, j;
|
|
|
|
for (i = 0; i < highlightsectorcnt; i++)
|
|
{
|
|
if (sector[highlightsector[i]].visibility != 0)
|
|
{
|
|
count++;
|
|
sector[highlightsector[i]].visibility += vis;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
for (i = 0; i < numsectors; i++)
|
|
{
|
|
if (sector[i].visibility != 0)
|
|
{
|
|
count++;
|
|
sector[i].visibility += vis;
|
|
}
|
|
}
|
|
|
|
printmessage16("");
|
|
|
|
clearmidstatbar16(); // Clear middle of status bar
|
|
|
|
sprintf(tempbuf, "%d Vis adjusted.", count);
|
|
printext16(8, ydim16+32, 11, -1, tempbuf, 0);
|
|
}
|
|
|
|
void
|
|
FindSprite(short picnum, short findspritenum)
|
|
{
|
|
int i, count;
|
|
short SpriteNum, NextSprite;
|
|
SPRITEp sp;
|
|
|
|
SWBOOL bFoundPicNum, bFoundHiTag, bFoundLowTag, bFoundIt;
|
|
|
|
|
|
if (qsetmode == 200) // In 3D mode
|
|
return;
|
|
|
|
if (picnum == 0)
|
|
{
|
|
sprintf(tempbuf, "Find sprite (tile number): ");
|
|
picnum = getnumber16(tempbuf, 0, 65536L, 1);
|
|
}
|
|
|
|
FindPicNum = picnum;
|
|
FindSpriteNum = findspritenum;
|
|
|
|
ResetSpriteFound();
|
|
|
|
// go to the first one
|
|
for (i = 0; i < numsectors; i++)
|
|
{
|
|
TRAVERSE_SPRITE_SECT(headspritesect[i], SpriteNum, NextSprite)
|
|
{
|
|
sp = &sprite[SpriteNum];
|
|
|
|
// Reset search status
|
|
bFoundIt = TRUE;
|
|
bFoundPicNum = bFoundHiTag = bFoundLowTag = FALSE;
|
|
|
|
if (bFindPicNum)
|
|
{
|
|
if (sp->picnum == picnum)
|
|
bFoundPicNum = TRUE;
|
|
bFoundIt = bFoundIt & bFoundPicNum;
|
|
}
|
|
if (bFindHiTag)
|
|
{
|
|
if (sp->hitag == sprite[FindSpriteNum].hitag)
|
|
bFoundHiTag = TRUE;
|
|
bFoundIt = bFoundIt & bFoundHiTag;
|
|
}
|
|
if (bFindLowTag)
|
|
{
|
|
if (sp->lotag == sprite[FindSpriteNum].lotag)
|
|
bFoundLowTag = TRUE;
|
|
bFoundIt = bFoundIt & bFoundLowTag;
|
|
}
|
|
|
|
if (bFoundIt)
|
|
{
|
|
SET(sp->extra, SPRX_FOUND);
|
|
cursectnum = sp->sectnum;
|
|
posx = sp->x;
|
|
posy = sp->y;
|
|
posz = sp->z - kensplayerheight;
|
|
return;
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
printmessage16("");
|
|
|
|
clearmidstatbar16(); // Clear middle of status bar
|
|
}
|
|
|
|
void
|
|
FindNextSprite(short picnum)
|
|
{
|
|
int i, count;
|
|
short SpriteNum, NextSprite;
|
|
SPRITEp sp;
|
|
short animlen;
|
|
|
|
SWBOOL bFoundPicNum, bFoundHiTag, bFoundLowTag, bFoundIt;
|
|
|
|
if (qsetmode == 200) // In 3D mode
|
|
return;
|
|
|
|
for (i = 0; i < numsectors; i++)
|
|
{
|
|
TRAVERSE_SPRITE_SECT(headspritesect[i], SpriteNum, NextSprite)
|
|
{
|
|
sp = &sprite[SpriteNum];
|
|
|
|
// Reset search status
|
|
bFoundIt = TRUE;
|
|
bFoundPicNum = bFoundHiTag = bFoundLowTag = FALSE;
|
|
|
|
if (bFindPicNum)
|
|
{
|
|
if (sp->picnum == picnum)
|
|
bFoundPicNum = TRUE;
|
|
bFoundIt = bFoundIt & bFoundPicNum;
|
|
}
|
|
if (bFindHiTag)
|
|
{
|
|
if (sp->hitag == sprite[FindSpriteNum].hitag)
|
|
bFoundHiTag = TRUE;
|
|
bFoundIt = bFoundIt & bFoundHiTag;
|
|
}
|
|
if (bFindLowTag)
|
|
{
|
|
if (sp->lotag == sprite[FindSpriteNum].lotag)
|
|
bFoundLowTag = TRUE;
|
|
bFoundIt = bFoundIt & bFoundLowTag;
|
|
}
|
|
|
|
if (bFoundIt && !TEST(sp->extra, SPRX_FOUND))
|
|
{
|
|
SET(sp->extra, SPRX_FOUND);
|
|
cursectnum = sp->sectnum;
|
|
posx = sp->x;
|
|
posy = sp->y;
|
|
posz = sp->z - kensplayerheight;
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
// Array of no-no ST1 tags that should not be considered for match tags.
|
|
short tagcheck[] = {0, 1, 3, 5, 16, 23, 25, 27, 29, 30, 31, 32, 33, 34, 37, 38, 39, 42,
|
|
45, 46, 47, 48, 49, 50, 51, 52, 53, 55, 56, 62, 64, 65, 66, 68, 71,
|
|
72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 90, 94, 97, 98, 99, 100,
|
|
101, 102, 135, 110, 111, 112, 113, 114, 115, 9002};
|
|
|
|
SWBOOL
|
|
DoMatchCheck(SPRITEp sp)
|
|
{
|
|
unsigned i;
|
|
|
|
// Don't F up the next tag with weird tag 2 cases that aren't match tags!
|
|
for (i = 0; i < sizeof(tagcheck); i++)
|
|
if (tagcheck[i] == sp->hitag)
|
|
return TRUE; // This ST1 tag is evil! Don't
|
|
// consider it!
|
|
|
|
return FALSE; // This ST1 tag if fine.
|
|
}
|
|
|
|
void
|
|
ShowNextTag(void)
|
|
{
|
|
if (qsetmode == 200) // In 3D mode
|
|
return;
|
|
|
|
printmessage16("");
|
|
|
|
sprintf(tempbuf, "Next tag = %d", siNextEndTag);
|
|
printmessage16(tempbuf);
|
|
|
|
}
|
|
|
|
void
|
|
FindNextTag(void)
|
|
{
|
|
int i, count, j;
|
|
short SpriteNum, NextSprite;
|
|
short siNextFind; // Next tag that SHOULD be found
|
|
SPRITEp sp;
|
|
|
|
if (qsetmode == 200) // In 3D mode
|
|
return;
|
|
|
|
siNextTag = siNextEndTag = 0; // Reset tags for new search
|
|
siNextFind = 0;
|
|
|
|
// go to the first one
|
|
for (i = 0; i < numsectors; i++)
|
|
{
|
|
TRAVERSE_SPRITE_SECT(headspritesect[i], SpriteNum, NextSprite)
|
|
{
|
|
sp = &sprite[SpriteNum];
|
|
|
|
// If it's not an ST1 sprite, blow past it
|
|
if (sp->picnum != ST1)
|
|
continue;
|
|
|
|
// Check for evil tags
|
|
if (DoMatchCheck(sp))
|
|
continue;
|
|
|
|
// Show the highest possible next tag
|
|
if (sp->lotag >= siNextEndTag)
|
|
siNextEndTag = sp->lotag + 1;
|
|
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
void
|
|
ShadeMenu(void) // F8
|
|
{
|
|
uint8_t* key;
|
|
|
|
if (qsetmode == 200) // In 3D mode
|
|
return;
|
|
|
|
clearmidstatbar16(); // Clear middle of status bar
|
|
printext16(8, ydim16+32, 11, -1, "(1) Plax Set ", 0);
|
|
printext16(8, ydim16+32 + 8, 11, -1, "(2) Plax Adjust ", 0);
|
|
printext16(8, ydim16+32 + 16, 11, -1, "(3) Shade Adjust ", 0);
|
|
printext16(8, ydim16+32 + 24, 11, -1, "(4) Visibility ", 0);
|
|
|
|
ResetKeys();
|
|
|
|
while ((key = BKeyPressed()) == NULL) ;
|
|
|
|
if (key == (uint8_t*)&KEY_PRESSED(KEYSC_1))
|
|
{
|
|
*key = FALSE;
|
|
PlaxSetShade();
|
|
}
|
|
else if (key == (uint8_t*)&KEY_PRESSED(KEYSC_2))
|
|
{
|
|
*key = FALSE;
|
|
PlaxAdjustShade();
|
|
}
|
|
else if (key == (uint8_t*)&KEY_PRESSED(KEYSC_3))
|
|
{
|
|
*key = FALSE;
|
|
AdjustShade();
|
|
}
|
|
else if (key == (uint8_t*)&KEY_PRESSED(KEYSC_4))
|
|
{
|
|
*key = FALSE;
|
|
AdjustVisibility();
|
|
}
|
|
}
|
|
|
|
void faketimerhandler(void)
|
|
{
|
|
sampletimer();
|
|
}
|
|
|
|
//Just thought you might want my getnumber16 code
|
|
/*
|
|
getnumber16(char namestart[80], short num, int maxnumber)
|
|
{
|
|
char buffer[80];
|
|
int j, k, n, danum, oldnum;
|
|
|
|
danum = (int)num;
|
|
oldnum = danum;
|
|
while ((KEY_PRESSED(0x1c) != 2) && (KEY_PRESSED(0x1) == 0)) //Enter, ESC
|
|
{
|
|
sprintf(&buffer,"%s%ld_ ",namestart,danum);
|
|
printmessage16(buffer);
|
|
|
|
for(j=2;j<=11;j++) //Scan numbers 0-9
|
|
if (KEY_PRESSED(j) > 0)
|
|
{
|
|
KEY_PRESSED(j) = 0;
|
|
k = j-1;
|
|
if (k == 10) k = 0;
|
|
n = (danum*10)+k;
|
|
if (n < maxnumber) danum = n;
|
|
}
|
|
if (KEY_PRESSED(0xe) > 0) // backspace
|
|
{
|
|
danum /= 10;
|
|
KEY_PRESSED(0xe) = 0;
|
|
}
|
|
if (KEY_PRESSED(0x1c) == 1) //L. enter
|
|
{
|
|
oldnum = danum;
|
|
KEY_PRESSED(0x1c) = 2;
|
|
asksave = 1;
|
|
}
|
|
}
|
|
KEY_PRESSED(0x1c) = 0;
|
|
KEY_PRESSED(0x1) = 0;
|
|
return((short)oldnum);
|
|
}
|
|
*/
|
|
|
|
static char messagecolor = 31;
|
|
static unsigned short messagedelay = 0;
|
|
static char messagebuf[1024];
|
|
|
|
void
|
|
Message(char *string, char color)
|
|
{
|
|
sprintf(messagebuf, string, 0);
|
|
messagedelay = 512;
|
|
messagecolor = color;
|
|
}
|
|
|
|
void
|
|
ShowMessage(void)
|
|
{
|
|
if (messagedelay < 1)
|
|
return;
|
|
messagedelay--;
|
|
printext256(1 * 4, 1 * 8, 1, 0, messagebuf, 1);
|
|
}
|
|
|
|
void
|
|
ResetSprites()
|
|
{
|
|
short i;
|
|
spritetype *tspr;
|
|
|
|
DebugActorFreeze = 0;
|
|
|
|
for (i = 0, tspr = &sprite[0]; i < MAXSPRITES; i++, tspr++)
|
|
{
|
|
RESET(tspr->cstat, CSTAT_SPRITE_INVISIBLE);
|
|
// if (TEST(tspr->extra, SPRX_BLOCK))
|
|
// SET(tspr->cstat, CSTAT_SPRITE_BLOCK);
|
|
}
|
|
|
|
}
|
|
|
|
static char kvxloaded = 0;
|
|
void ExtPreLoadMap(void)
|
|
{
|
|
ResetSprites();
|
|
if (!kvxloaded) LoadKVXFromScript("swvoxfil.txt"), kvxloaded = 1;
|
|
}
|
|
|
|
|
|
void ExtPreSaveMap(void)
|
|
{
|
|
ResetBuildFAF();
|
|
ResetSprites();
|
|
}
|
|
|
|
void
|
|
dsprintf(char *str, char *format, ...)
|
|
{
|
|
va_list arglist;
|
|
|
|
va_start(arglist, format);
|
|
vsprintf(str, format, arglist);
|
|
va_end(arglist);
|
|
}
|
|
|
|
void
|
|
dsprintf_null(char *str, char *format, ...)
|
|
{
|
|
va_list arglist;
|
|
}
|
|
|
|
|
|
void
|
|
BuildStagTable(void)
|
|
{
|
|
#define MAKE_STAG_TABLE
|
|
#include "stag.h"
|
|
#undef MAKE_STAG_TABLE
|
|
}
|