git-svn-id: https://svn.eduke32.com/eduke32@734 1a8010ca-5511-0410-912e-c29ae57300e0

This commit is contained in:
terminx 2008-05-18 21:09:30 +00:00
parent 4e3faa9c00
commit b0ceecbdee
4 changed files with 85 additions and 29 deletions

View File

@ -46,6 +46,8 @@ extern unsigned char buildkeys[NUMBUILDKEYS];
extern int ydim16, xdimgame, ydimgame, bppgame, xdim2d, ydim2d, forcesetup; extern int ydim16, xdimgame, ydimgame, bppgame, xdim2d, ydim2d, forcesetup;
extern char unrealedlook, quickmapcycling; extern char unrealedlook, quickmapcycling;
extern int pk_turnaccel,pk_turndecel,pk_uedaccel;
extern int revertCTRL,scrollamount;
extern int ExtInit(void); extern int ExtInit(void);

View File

@ -130,6 +130,7 @@ signed char tempshade;
unsigned char somethingintab = 255; unsigned char somethingintab = 255;
char mlook = 0,mskip=0; char mlook = 0,mskip=0;
int revertCTRL=0,scrollamount=3;
char unrealedlook=0, quickmapcycling=0; //PK char unrealedlook=0, quickmapcycling=0; //PK
static char boardfilename[BMAX_PATH], selectedboardfilename[BMAX_PATH]; static char boardfilename[BMAX_PATH], selectedboardfilename[BMAX_PATH];
@ -482,9 +483,10 @@ CANCEL:
} }
idle(); idle();
if (keystatus[0x15]) if (keystatus[0x15]||keystatus[0x1c]) // Y or ENTER
{ {
keystatus[0x15] = 0; keystatus[0x15] = 0;
keystatus[0x1c] = 0;
quitflag = 1; break; quitflag = 1; break;
} }
} }
@ -508,10 +510,11 @@ CANCEL:
if (handleevents()) { if (quitevent) break; } // like saying no if (handleevents()) { if (quitevent) break; } // like saying no
idle(); idle();
if (keystatus[0x15]) if (keystatus[0x15] || keystatus[0x1c]) // Y or ENTER
{ {
char *f; char *f;
keystatus[0x15] = 0; keystatus[0x15] = 0;
keystatus[0x1c] = 0;
fixspritesectors(); fixspritesectors();
updatesector(startposx,startposy,&startsectnum); updatesector(startposx,startposy,&startsectnum);
ExtPreSaveMap(); ExtPreSaveMap();

View File

@ -201,8 +201,18 @@ int loadsetup(const char *fn)
if (readconfig(fp, "mousenavigation", val, VL) > 0) unrealedlook = Batoi(val); if (readconfig(fp, "mousenavigation", val, VL) > 0) unrealedlook = Batoi(val);
if (readconfig(fp, "mousenavigationaccel", val, VL) > 0) pk_uedaccel = Batoi(val);
if (readconfig(fp, "quickmapcycling", val, VL) > 0) quickmapcycling = Batoi(val); if (readconfig(fp, "quickmapcycling", val, VL) > 0) quickmapcycling = Batoi(val);
if (readconfig(fp, "revertCTRL", val, VL) > 0) revertCTRL = Batoi(val);
if (readconfig(fp, "scrollamount", val, VL) > 0) scrollamount = Batoi(val);
if (readconfig(fp, "turnaccel", val, VL) > 0) pk_turnaccel = Batoi(val);
if (readconfig(fp, "turndecel", val, VL) > 0) pk_turndecel = Batoi(val);
for (i=0;i<256;i++)remap[i]=i; for (i=0;i<256;i++)remap[i]=i;
remapinit=1; remapinit=1;
if (readconfig(fp, "remap", val, VL) > 0) if (readconfig(fp, "remap", val, VL) > 0)
@ -304,11 +314,32 @@ int writesetup(const char *fn)
"mousesensitivity = %g\n" "mousesensitivity = %g\n"
"\n" "\n"
"; Mouse navigation\n" "; Mouse navigation\n"
"; 0 - No\n"
"; 1 - Yes\n"
"mousenavigation = %d\n" "mousenavigation = %d\n"
"; Mouse navigation acceleration\n"
"\n" "\n"
"; Quick map cycling\n" "mousenavigationaccel = %d\n"
"\n"
"; Quick map cycling (SHIFT)+CTRL+X\n"
"; 0 - No\n"
"; 1 - Yes\n"
"quickmapcycling = %d\n" "quickmapcycling = %d\n"
"\n" "\n"
"; Revert CTRL for tile selction\n"
"; 0 - WHEEL:scrolling, CTRL+WHEEL:zooming\n"
"; 1 - CTRL+WHEEL:scrolling, WHEEL:zooming\n"
"revertCTRL = %d\n"
"\n"
"; Scroll amount for WHEEL in the tile selcetion\n"
"scrollamount = %d\n"
"\n"
"; Turning acceleration+declaration\n"
"turnaccel = %d\n"
"\n"
"; Turning deceleration\n"
"turndecel = %d\n"
"\n"
#if 1 #if 1
"; Key Settings\n" "; Key Settings\n"
"; Here's a map of all the keyboard scan codes: NOTE: values are listed in hex!\n" "; Here's a map of all the keyboard scan codes: NOTE: values are listed in hex!\n"
@ -368,7 +399,8 @@ int writesetup(const char *fn)
#if 0 #if 0
option[7]>>4, option[2], option[7]>>4, option[2],
#endif #endif
option[3], msens, unrealedlook, quickmapcycling, option[3], msens, unrealedlook, pk_uedaccel, quickmapcycling,
revertCTRL,scrollamount,pk_turnaccel,pk_turndecel,
#if 1 #if 1
keys[0], keys[1], keys[2], keys[3], keys[4], keys[5], keys[0], keys[1], keys[2], keys[3], keys[4], keys[5],
keys[6], keys[7], keys[8], keys[9], keys[10], keys[11], keys[6], keys[7], keys[8], keys[9], keys[10], keys[11],

View File

@ -48,6 +48,7 @@ static char defaultduke3dgrp[BMAX_PATH] = "duke3d.grp";
static char *duke3dgrp = defaultduke3dgrp; static char *duke3dgrp = defaultduke3dgrp;
static int fixmapbeforesaving = 1; static int fixmapbeforesaving = 1;
static int lastsave = -180*60; static int lastsave = -180*60;
static int spnoclip=0;
static int NoAutoLoad = 0; static int NoAutoLoad = 0;
#if !defined(_WIN32) #if !defined(_WIN32)
@ -1693,9 +1694,10 @@ static int AskIfSure(char *text)
} }
} }
idle(); idle();
if (keystatus[KEYSC_Y]) if (keystatus[KEYSC_Y]||keystatus[KEYSC_ENTER])
{ {
keystatus[KEYSC_Y] = 0; keystatus[KEYSC_Y] = 0;
keystatus[KEYSC_ENTER] = 0;
retval = 0; retval = 0;
break; break;
} }
@ -1763,6 +1765,7 @@ static int m32gettile(int idInitialTile)
int i; int i;
int iTile, iTopLeftTile; int iTile, iTopLeftTile;
int idSelectedTile; int idSelectedTile;
int scrollmode;
int mousedx, mousedy, mtile, omousex=searchx, omousey=searchy, moffset=0; int mousedx, mousedy, mtile, omousex=searchx, omousey=searchy, moffset=0;
// Enable following line for testing. I couldn't work out how to change vidmode on the fly // Enable following line for testing. I couldn't work out how to change vidmode on the fly
@ -1946,7 +1949,12 @@ static int m32gettile(int idInitialTile)
moffset+=mousedy*2; moffset+=mousedy*2;
searchy += mousedy; searchy += mousedy;
searchx -= mousedx; searchx -= mousedx;
if (iTopLeftTile==0 && moffset>0)moffset=0; if ((moffset < 0 && iTopLeftTile > localartlookupnum-nDisplayedTiles-1)
|| (moffset > 0 && iTopLeftTile==0))
{
moffset=0;
searchy -= mousedy*2;
}
while (moffset>ZoomToThumbSize[s_Zoom]) while (moffset>ZoomToThumbSize[s_Zoom])
{ {
iTopLeftTile-=nXTiles; iTopLeftTile-=nXTiles;
@ -1963,15 +1971,16 @@ static int m32gettile(int idInitialTile)
if (searchx > xdim-13) searchx = xdim-13; if (searchx > xdim-13) searchx = xdim-13;
if (searchy > ydim-23) searchy = ydim-23; if (searchy > ydim-23) searchy = ydim-23;
if (bstatus&16 && !eitherCTRL && iTopLeftTile > 0) scrollmode=!(eitherCTRL^revertCTRL);
if (bstatus&16 && scrollmode && iTopLeftTile > 0)
{ {
mouseb &= ~16; mouseb &= ~16;
iTopLeftTile -= (nXTiles*3); iTopLeftTile -= (nXTiles*scrollamount);
} }
if (bstatus&32 && !eitherCTRL && iTopLeftTile < MAXTILES-1) if (bstatus&32 && scrollmode && iTopLeftTile < localartlookupnum-nDisplayedTiles-1)
{ {
mouseb &= ~32; mouseb &= ~32;
iTopLeftTile += (nXTiles*3); iTopLeftTile += (nXTiles*scrollamount);
} }
mtile=iTile=(searchx/ZoomToThumbSize[s_Zoom])+((searchy-moffset)/ZoomToThumbSize[s_Zoom])*nXTiles+iTopLeftTile; mtile=iTile=(searchx/ZoomToThumbSize[s_Zoom])+((searchy-moffset)/ZoomToThumbSize[s_Zoom])*nXTiles+iTopLeftTile;
while (iTile >= iTopLeftTile + nDisplayedTiles) while (iTile >= iTopLeftTile + nDisplayedTiles)
@ -1991,10 +2000,10 @@ static int m32gettile(int idInitialTile)
lockclock += synctics; lockclock += synctics;
// Zoom in / out using numeric key pad's / and * keys // Zoom in / out using numeric key pad's / and * keys
if (((keystatus[KEYSC_gSLASH] || (eitherCTRL && bstatus&16)) && s_Zoom<(signed)(NUM_ZOOMS-1)) if (((keystatus[KEYSC_gSLASH] || (!scrollmode && bstatus&16)) && s_Zoom<(signed)(NUM_ZOOMS-1))
|| ((keystatus[KEYSC_gSTAR] || (eitherCTRL && bstatus&32)) && s_Zoom>0)) || ((keystatus[KEYSC_gSTAR] || (!scrollmode && bstatus&32)) && s_Zoom>0))
{ {
if (keystatus[KEYSC_gSLASH] || (eitherCTRL && bstatus&16)) if (keystatus[KEYSC_gSLASH] || (!scrollmode && bstatus&16))
{ {
keystatus[KEYSC_gSLASH] = 0; keystatus[KEYSC_gSLASH] = 0;
mouseb &= ~16; mouseb &= ~16;
@ -3886,7 +3895,7 @@ static void Keys3d(void)
if (k == 0) if (k == 0)
{ {
sprite[searchwall].z -= updownunits; sprite[searchwall].z -= updownunits;
if (!noclip)sprite[searchwall].z = max(sprite[searchwall].z,spriteonceilingz(searchwall)); if (!spnoclip)sprite[searchwall].z = max(sprite[searchwall].z,spriteonceilingz(searchwall));
sprintf(getmessage,"Sprite %d z = %d",searchwall,sprite[searchwall].z); sprintf(getmessage,"Sprite %d z = %d",searchwall,sprite[searchwall].z);
message(getmessage); message(getmessage);
@ -3897,7 +3906,7 @@ static void Keys3d(void)
if ((highlight[i]&0xc000) == 16384) if ((highlight[i]&0xc000) == 16384)
{ {
sprite[highlight[i]&16383].z -= updownunits; sprite[highlight[i]&16383].z -= updownunits;
if (!noclip)sprite[highlight[i]&16383].z = max(sprite[highlight[i]&16383].z,spriteonceilingz(highlight[i]&16383)); if (!spnoclip)sprite[highlight[i]&16383].z = max(sprite[highlight[i]&16383].z,spriteonceilingz(highlight[i]&16383));
} }
sprintf(getmessage,"Sprite %d z = %d",highlight[i]&16383,sprite[highlight[i]&16383].z); sprintf(getmessage,"Sprite %d z = %d",highlight[i]&16383,sprite[highlight[i]&16383].z);
message(getmessage); message(getmessage);
@ -4033,7 +4042,7 @@ static void Keys3d(void)
if (k == 0) if (k == 0)
{ {
sprite[searchwall].z += updownunits; sprite[searchwall].z += updownunits;
if (!noclip)sprite[searchwall].z = min(sprite[searchwall].z,spriteongroundz(searchwall)); if (!spnoclip)sprite[searchwall].z = min(sprite[searchwall].z,spriteongroundz(searchwall));
sprintf(getmessage,"Sprite %d z = %d",searchwall,sprite[searchwall].z); sprintf(getmessage,"Sprite %d z = %d",searchwall,sprite[searchwall].z);
message(getmessage); message(getmessage);
@ -4044,7 +4053,7 @@ static void Keys3d(void)
if ((highlight[i]&0xc000) == 16384) if ((highlight[i]&0xc000) == 16384)
{ {
sprite[highlight[i]&16383].z += updownunits; sprite[highlight[i]&16383].z += updownunits;
if (!noclip)sprite[highlight[i]&16383].z = min(sprite[highlight[i]&16383].z,spriteongroundz(highlight[i]&16383)); if (!spnoclip)sprite[highlight[i]&16383].z = min(sprite[highlight[i]&16383].z,spriteongroundz(highlight[i]&16383));
} }
sprintf(getmessage,"Sprite %d z = %d",highlight[i]&16383,sprite[highlight[i]&16383].z); sprintf(getmessage,"Sprite %d z = %d",highlight[i]&16383,sprite[highlight[i]&16383].z);
message(getmessage); message(getmessage);
@ -4937,7 +4946,7 @@ static void Keys3d(void)
xvect = -((mousex*(int)sintable[(ang+2048)&2047])<<3); xvect = -((mousex*(int)sintable[(ang+2048)&2047])<<3);
yvect = -((mousex*(int)sintable[(ang+1536)&2047])<<3); yvect = -((mousex*(int)sintable[(ang+1536)&2047])<<3);
clipmove(&sprite[searchwall].x,&sprite[searchwall].y,&sprite[searchwall].z, clipmove(&sprite[searchwall].x,&sprite[searchwall].y,&sprite[searchwall].z,
&cursectnum,xvect,yvect,128L,4L<<8,4L<<8,CLIPMASK1); &cursectnum,xvect,yvect,128L,4L<<8,4L<<8,spnoclip?1:CLIPMASK0);
setsprite(searchwall,sprite[searchwall].x,sprite[searchwall].y,sprite[searchwall].z); setsprite(searchwall,sprite[searchwall].x,sprite[searchwall].y,sprite[searchwall].z);
} }
else else
@ -5042,7 +5051,7 @@ static void Keys3d(void)
xvect = -((mousey*(int)sintable[(ang+2560)&2047])<<3); xvect = -((mousey*(int)sintable[(ang+2560)&2047])<<3);
yvect = -((mousey*(int)sintable[(ang+2048)&2047])<<3); yvect = -((mousey*(int)sintable[(ang+2048)&2047])<<3);
clipmove(&sprite[searchwall].x,&sprite[searchwall].y,&sprite[searchwall].z, clipmove(&sprite[searchwall].x,&sprite[searchwall].y,&sprite[searchwall].z,
&cursectnum,xvect,yvect,128L,4L<<8,4L<<8,CLIPMASK1); &cursectnum,xvect,yvect,128L,4L<<8,4L<<8,spnoclip?1:CLIPMASK0);
setsprite(searchwall,sprite[searchwall].x,sprite[searchwall].y,sprite[searchwall].z); setsprite(searchwall,sprite[searchwall].x,sprite[searchwall].y,sprite[searchwall].z);
} }
else else
@ -7290,11 +7299,12 @@ int ExtInit(void)
#if defined(_WIN32) && defined(DUKEOSD) #if defined(_WIN32) && defined(DUKEOSD)
OSD_SetFunctions( OSD_SetFunctions(
GAME_drawosdchar, /* GAME_drawosdchar,
GAME_drawosdstr, GAME_drawosdstr,
GAME_drawosdcursor, GAME_drawosdcursor,
GAME_getcolumnwidth, GAME_getcolumnwidth,
GAME_getrowheight, GAME_getrowheight,*/
0,0,0,0,0,
GAME_clearbackground, GAME_clearbackground,
(int(*)(void))GetTime, (int(*)(void))GetTime,
NULL NULL
@ -7527,6 +7537,14 @@ static void Keys2d3d(void)
else message("Clipping enabled"); else message("Clipping enabled");
} }
if (eitherCTRL && keystatus[KEYSC_N]) // CTRL+N
{
keystatus[KEYSC_N] = 0;
spnoclip=!spnoclip;
if (noclip) message("Sprite clipping disabled");
else message("Sprite clipping enabled");
}
if ((totalclock > autosavetimer) && (autosave)) if ((totalclock > autosavetimer) && (autosave))
{ {
if (asksave) if (asksave)
@ -7636,11 +7654,12 @@ static void Keys2d3d(void)
else else
{ {
OSD_SetFunctions( OSD_SetFunctions(
GAME_drawosdchar, /* GAME_drawosdchar,
GAME_drawosdstr, GAME_drawosdstr,
GAME_drawosdcursor, GAME_drawosdcursor,
GAME_getcolumnwidth, GAME_getcolumnwidth,
GAME_getrowheight, GAME_getrowheight,*/
0,0,0,0,0,
GAME_clearbackground, GAME_clearbackground,
(int(*)(void))GetTime, (int(*)(void))GetTime,
NULL NULL