mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-11 18:50:46 +00:00
git-svn-id: https://svn.eduke32.com/eduke32@219 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
c120d9f915
commit
c8589f5b9a
7 changed files with 132 additions and 44 deletions
|
@ -7212,7 +7212,7 @@ long setgamemode(char davidoption, long daxdim, long daydim, long dabpp)
|
||||||
|
|
||||||
setview(0L,0L,xdim-1,ydim-1);
|
setview(0L,0L,xdim-1,ydim-1);
|
||||||
clearallviews(0L);
|
clearallviews(0L);
|
||||||
setbrightness(curbrightness,palette,0);
|
setbrightness(curbrightness,&palette[0],0);
|
||||||
|
|
||||||
if (searchx < 0) { searchx = halfxdimen; searchy = (ydimen>>1); }
|
if (searchx < 0) { searchx = halfxdimen; searchy = (ydimen>>1); }
|
||||||
|
|
||||||
|
|
|
@ -521,14 +521,6 @@ int handleevents(void)
|
||||||
|
|
||||||
ProcessInputDevices();
|
ProcessInputDevices();
|
||||||
|
|
||||||
#ifdef DEBUGGINGAIDS
|
|
||||||
// break to the debugger if KP- is pressed
|
|
||||||
if (IsDebuggerPresent() && keystatus[0x4a]) {
|
|
||||||
keystatus[0x4a] = 0;
|
|
||||||
DebugBreak();
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (!appactive || quitevent) rv = -1;
|
if (!appactive || quitevent) rv = -1;
|
||||||
|
|
||||||
sampletimer();
|
sampletimer();
|
||||||
|
@ -1341,6 +1333,8 @@ static void ProcessInputDevices(void)
|
||||||
|
|
||||||
if (k == DIK_PAUSE) continue; // fucking pause
|
if (k == DIK_PAUSE) continue; // fucking pause
|
||||||
|
|
||||||
|
//if (IsDebuggerPresent() && k == DIK_F12) continue;
|
||||||
|
|
||||||
// hook in the osd
|
// hook in the osd
|
||||||
if (OSD_HandleKey(k, (didod[i].dwData & 0x80)) != 0) {
|
if (OSD_HandleKey(k, (didod[i].dwData & 0x80)) != 0) {
|
||||||
SetKey(k, (didod[i].dwData & 0x80) == 0x80);
|
SetKey(k, (didod[i].dwData & 0x80) == 0x80);
|
||||||
|
|
|
@ -86,7 +86,7 @@ AUDIOLIBOBJ=$(AUDIOLIB_JFAUD)
|
||||||
$(OBJ)osdcmds.$o \
|
$(OBJ)osdcmds.$o \
|
||||||
$(JMACTOBJ) \
|
$(JMACTOBJ) \
|
||||||
$(AUDIOLIBOBJ) \
|
$(AUDIOLIBOBJ) \
|
||||||
$(OBJ)winbits.$o $(OBJ)gameres.res $(OBJ)startwin.game.$o
|
$(OBJ)winbits.$o $(OBJ)gameres.res $(OBJ)startwin.game.$o $(OBJ)startdlg.$o
|
||||||
|
|
||||||
EDITOROBJS=$(OBJ)astub.$o \
|
EDITOROBJS=$(OBJ)astub.$o \
|
||||||
$(OBJ)buildres.res
|
$(OBJ)buildres.res
|
||||||
|
|
|
@ -140,6 +140,7 @@ typedef struct {
|
||||||
JFAudMixerChannel *chan;
|
JFAudMixerChannel *chan;
|
||||||
int owner; // sprite number
|
int owner; // sprite number
|
||||||
int soundnum; // sound number
|
int soundnum; // sound number
|
||||||
|
bool done;
|
||||||
} SoundChannel;
|
} SoundChannel;
|
||||||
|
|
||||||
static SoundChannel *chans = NULL;
|
static SoundChannel *chans = NULL;
|
||||||
|
@ -150,9 +151,10 @@ static bool havemidi = false, havewave = false;
|
||||||
|
|
||||||
static void stopcallback(int r)
|
static void stopcallback(int r)
|
||||||
{
|
{
|
||||||
jfaud->FreeSound(chans[r].chan);
|
chans[r].done = true;
|
||||||
chans[r].chan = NULL;
|
// jfaud->FreeSound(chans[r].chan);
|
||||||
chans[r].owner = -1;
|
// chans[r].chan = NULL;
|
||||||
|
// chans[r].owner = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void testcallback(unsigned long num)
|
void testcallback(unsigned long num)
|
||||||
|
@ -163,7 +165,7 @@ static int keephandle(JFAudMixerChannel *handle, int soundnum, int owner)
|
||||||
{
|
{
|
||||||
int i, freeh=-1;
|
int i, freeh=-1;
|
||||||
for (i=NumVoices-1;i>=0;i--) {
|
for (i=NumVoices-1;i>=0;i--) {
|
||||||
if ((!chans[i].chan || !jfaud->IsValidSound(chans[i].chan)) && freeh<0) freeh=i;
|
if (!chans[i].chan && freeh<0) freeh=i;
|
||||||
else if (chans[i].chan == handle) { freeh=i; break; }
|
else if (chans[i].chan == handle) { freeh=i; break; }
|
||||||
}
|
}
|
||||||
if (freeh<0) {
|
if (freeh<0) {
|
||||||
|
@ -174,6 +176,7 @@ static int keephandle(JFAudMixerChannel *handle, int soundnum, int owner)
|
||||||
chans[freeh].chan = handle;
|
chans[freeh].chan = handle;
|
||||||
chans[freeh].soundnum = soundnum;
|
chans[freeh].soundnum = soundnum;
|
||||||
chans[freeh].owner = owner;
|
chans[freeh].owner = owner;
|
||||||
|
chans[freeh].done = false;
|
||||||
|
|
||||||
return freeh;
|
return freeh;
|
||||||
}
|
}
|
||||||
|
@ -227,10 +230,6 @@ void SoundStartup(void)
|
||||||
|
|
||||||
havewave = true;
|
havewave = true;
|
||||||
|
|
||||||
for (i=NumVoices-1; i>=0; i--) {
|
|
||||||
chans[i].owner = -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (jfaud->InitMIDI(NULL)) havemidi = true;
|
if (jfaud->InitMIDI(NULL)) havemidi = true;
|
||||||
|
|
||||||
OSD_RegisterFunction("setsoundfilter","setsoundfilter: 0=nearest 1=linear 2=4point",osdcmd_setsoundfilter);
|
OSD_RegisterFunction("setsoundfilter","setsoundfilter: 0=nearest 1=linear 2=4point",osdcmd_setsoundfilter);
|
||||||
|
@ -260,8 +259,10 @@ void AudioUpdate(void)
|
||||||
if (!jfaud) return;
|
if (!jfaud) return;
|
||||||
if (havewave)
|
if (havewave)
|
||||||
for (i=NumVoices-1; i>=0; i--) {
|
for (i=NumVoices-1; i>=0; i--) {
|
||||||
if (chans[i].chan && !jfaud->IsValidSound(chans[i].chan))
|
if (!chans[i].done) continue;
|
||||||
|
if (chans[i].chan) jfaud->FreeSound(chans[i].chan);
|
||||||
chans[i].chan = NULL;
|
chans[i].chan = NULL;
|
||||||
|
chans[i].done = false;
|
||||||
}
|
}
|
||||||
jfaud->Update(false); // don't age the cache here
|
jfaud->Update(false); // don't age the cache here
|
||||||
}
|
}
|
||||||
|
@ -316,8 +317,8 @@ int isspritemakingsound(short i, int num) // if num<0, check if making any sound
|
||||||
|
|
||||||
if (!jfaud || !havewave) return 0;
|
if (!jfaud || !havewave) return 0;
|
||||||
for (j=NumVoices-1; j>=0; j--) {
|
for (j=NumVoices-1; j>=0; j--) {
|
||||||
if (!chans[j].chan || !jfaud->IsValidSound(chans[j].chan)) continue;
|
if (chans[j].done || !chans[j].chan) continue;
|
||||||
if (chans[j].owner == i)
|
if (chans[j].owner != i) continue;
|
||||||
if (num < 0 || chans[j].soundnum == num) n++;
|
if (num < 0 || chans[j].soundnum == num) n++;
|
||||||
}
|
}
|
||||||
return n;
|
return n;
|
||||||
|
@ -329,7 +330,7 @@ int issoundplaying(short i, int num)
|
||||||
|
|
||||||
if (!jfaud || !havewave) return 0;
|
if (!jfaud || !havewave) return 0;
|
||||||
for (j=NumVoices-1; j>=0; j--) {
|
for (j=NumVoices-1; j>=0; j--) {
|
||||||
if (!chans[j].chan || !jfaud->IsValidSound(chans[j].chan)) continue;
|
if (chans[j].done || !chans[j].chan) continue;
|
||||||
if (chans[j].soundnum == num) n++;
|
if (chans[j].soundnum == num) n++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -364,7 +365,7 @@ int xyzsound(short num, short i, long x, long y, long z)
|
||||||
) return -1;
|
) return -1;
|
||||||
|
|
||||||
for (j=NumVoices-1; j>=0; j--) {
|
for (j=NumVoices-1; j>=0; j--) {
|
||||||
if (!chans[j].chan || chans[j].owner < 0) continue;
|
if (chans[j].done || !chans[j].chan || chans[j].owner < 0) continue;
|
||||||
if (soundm[ chans[j].soundnum ] & SOUNDM_DUKE) return -1;
|
if (soundm[ chans[j].soundnum ] & SOUNDM_DUKE) return -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -502,11 +503,11 @@ void stopsound(short num)
|
||||||
|
|
||||||
if (!jfaud || !havewave) return;
|
if (!jfaud || !havewave) return;
|
||||||
for (j=NumVoices-1;j>=0;j--) {
|
for (j=NumVoices-1;j>=0;j--) {
|
||||||
if (!chans[j].chan || !jfaud->IsValidSound(chans[j].chan) || chans[j].soundnum != num) continue;
|
if (chans[j].done || !chans[j].chan || chans[j].soundnum != num) continue;
|
||||||
|
|
||||||
jfaud->FreeSound(chans[j].chan);
|
jfaud->FreeSound(chans[j].chan);
|
||||||
chans[j].chan = NULL;
|
chans[j].chan = NULL;
|
||||||
chans[j].owner = -1;
|
chans[j].done = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -516,11 +517,11 @@ void stopspritesound(short num, short i)
|
||||||
|
|
||||||
if (!jfaud || !havewave) return;
|
if (!jfaud || !havewave) return;
|
||||||
for (j=NumVoices-1;j>=0;j--) {
|
for (j=NumVoices-1;j>=0;j--) {
|
||||||
if (!chans[j].chan || !jfaud->IsValidSound(chans[j].chan) || chans[j].owner != i || chans[j].soundnum != num) continue;
|
if (chans[j].done || !chans[j].chan || chans[j].owner != i || chans[j].soundnum != num) continue;
|
||||||
|
|
||||||
jfaud->FreeSound(chans[j].chan);
|
jfaud->FreeSound(chans[j].chan);
|
||||||
chans[j].chan = NULL;
|
chans[j].chan = NULL;
|
||||||
chans[j].owner = -1;
|
chans[j].done = false;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -531,11 +532,11 @@ void stopenvsound(short num, short i)
|
||||||
|
|
||||||
if (!jfaud || !havewave) return;
|
if (!jfaud || !havewave) return;
|
||||||
for (j=NumVoices-1;j>=0;j--) {
|
for (j=NumVoices-1;j>=0;j--) {
|
||||||
if (!chans[j].chan || !jfaud->IsValidSound(chans[j].chan) || chans[j].owner != i) continue;
|
if (chans[j].done || !chans[j].chan || chans[j].owner != i) continue;
|
||||||
|
|
||||||
jfaud->FreeSound(chans[j].chan);
|
jfaud->FreeSound(chans[j].chan);
|
||||||
chans[j].chan = NULL;
|
chans[j].chan = NULL;
|
||||||
chans[j].owner = -1;
|
chans[j].done = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -574,7 +575,7 @@ void pan3dsound(void)
|
||||||
0.0, 1.0, 0.0);
|
0.0, 1.0, 0.0);
|
||||||
|
|
||||||
for (j=NumVoices-1; j>=0; j--) {
|
for (j=NumVoices-1; j>=0; j--) {
|
||||||
if (!chans[j].chan || !jfaud->IsValidSound(chans[j].chan) || chans[j].owner < 0) continue;
|
if (chans[j].done || !chans[j].chan || chans[j].owner < 0) continue;
|
||||||
|
|
||||||
global = 0;
|
global = 0;
|
||||||
gain = 1.0;
|
gain = 1.0;
|
||||||
|
@ -726,3 +727,32 @@ static int osdcmd_setsoundfilter(const osdfuncparm_t *parm)
|
||||||
DefaultFilter = (JFAudMixerChannel::Filter)filt;
|
DefaultFilter = (JFAudMixerChannel::Filter)filt;
|
||||||
return OSDCMD_OK;
|
return OSDCMD_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int EnumAudioDevs(struct audioenumdrv **wave, struct audioenumdev **midi, struct audioenumdev **cda)
|
||||||
|
{
|
||||||
|
char **enumerdrv, *defdrv;
|
||||||
|
int i;
|
||||||
|
bool isdefdrv, isdefdev;
|
||||||
|
struct audioenumdev **d;
|
||||||
|
|
||||||
|
*wave = NULL;
|
||||||
|
//*midi = *cda = NULL;
|
||||||
|
|
||||||
|
enumerdrv = JFAud::EnumerateWaveDevices(NULL, &defdrv);
|
||||||
|
if (enumerdrv) {
|
||||||
|
*wave = (struct audioenumdrv *)calloc(1,sizeof(struct audioenumdrv));
|
||||||
|
(*wave)->def = defdrv;
|
||||||
|
(*wave)->drvs = enumerdrv;
|
||||||
|
(*wave)->devs = NULL;
|
||||||
|
d = &(*wave)->devs;
|
||||||
|
for (i=0; enumerdrv[i]; i++) {
|
||||||
|
*d = (struct audioenumdev *)calloc(1,sizeof(struct audioenumdev));
|
||||||
|
(*d)->devs = JFAud::EnumerateWaveDevices(enumerdrv[i], &(*d)->def);
|
||||||
|
(*d)->next = NULL;
|
||||||
|
d = &(*d)->next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -29,16 +29,16 @@ char haltsoundhack;
|
||||||
short callsound(short sn,short whatsprite)
|
short callsound(short sn,short whatsprite)
|
||||||
{
|
{
|
||||||
short i;
|
short i;
|
||||||
|
|
||||||
if(haltsoundhack)
|
if(haltsoundhack)
|
||||||
{
|
{
|
||||||
haltsoundhack = 0;
|
haltsoundhack = 0;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
// initprintf("begin callsound(%d,%d)\n",sn,whatsprite);
|
||||||
i = headspritesect[sn];
|
i = headspritesect[sn];
|
||||||
while(i >= 0)
|
while(i >= 0)
|
||||||
{
|
{
|
||||||
|
// initprintf("callsound(%d,%d) i=%d T1-6=%d,%d,%d,%d,%d,%d PN=%d SLT=%d SHT=%d\n",sn,whatsprite,i,T1,T2,T3,T4,T5,T6,PN,SLT,SHT);
|
||||||
if( PN == MUSICANDSFX && SLT < 1000 )
|
if( PN == MUSICANDSFX && SLT < 1000 )
|
||||||
{
|
{
|
||||||
if(whatsprite == -1) whatsprite = i;
|
if(whatsprite == -1) whatsprite = i;
|
||||||
|
@ -51,7 +51,8 @@ short callsound(short sn,short whatsprite)
|
||||||
{
|
{
|
||||||
spritesound(SLT,whatsprite);
|
spritesound(SLT,whatsprite);
|
||||||
if(SHT && SLT != SHT && SHT < NUM_SOUNDS)
|
if(SHT && SLT != SHT && SHT < NUM_SOUNDS)
|
||||||
stopspritesound(SHT,whatsprite);
|
stopspritesound(SHT,T6);
|
||||||
|
T6 = whatsprite;
|
||||||
}
|
}
|
||||||
|
|
||||||
if( (sector[SECT].lotag&0xff) != 22)
|
if( (sector[SECT].lotag&0xff) != 22)
|
||||||
|
@ -62,13 +63,16 @@ short callsound(short sn,short whatsprite)
|
||||||
{
|
{
|
||||||
if(SHT) spritesound(SHT,whatsprite);
|
if(SHT) spritesound(SHT,whatsprite);
|
||||||
if( (soundm[SLT]&1) || ( SHT && SHT != SLT ) )
|
if( (soundm[SLT]&1) || ( SHT && SHT != SLT ) )
|
||||||
stopspritesound(SLT,whatsprite);
|
stopspritesound(SLT,T6);
|
||||||
|
T6 = whatsprite;
|
||||||
T1 = 0;
|
T1 = 0;
|
||||||
}
|
}
|
||||||
|
// initprintf("end callsound(%d,%d)\n",sn,whatsprite);
|
||||||
return SLT;
|
return SLT;
|
||||||
}
|
}
|
||||||
i = nextspritesect[i];
|
i = nextspritesect[i];
|
||||||
}
|
}
|
||||||
|
// initprintf("end callsound(%d,%d) -1\n",sn,whatsprite);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -52,4 +52,16 @@ void MusicStartup( void );
|
||||||
void MusicShutdown( void );
|
void MusicShutdown( void );
|
||||||
void AudioUpdate(void);
|
void AudioUpdate(void);
|
||||||
|
|
||||||
|
struct audioenumdev {
|
||||||
|
char *def;
|
||||||
|
char **devs;
|
||||||
|
struct audioenumdev *next;
|
||||||
|
};
|
||||||
|
struct audioenumdrv {
|
||||||
|
char *def;
|
||||||
|
char **drvs;
|
||||||
|
struct audioenumdev *devs;
|
||||||
|
};
|
||||||
|
int EnumAudioDevs(struct audioenumdrv **wave, struct audioenumdev **midi, struct audioenumdev **cda);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "duke3d.h"
|
#include "duke3d.h"
|
||||||
|
#include "sounds.h"
|
||||||
|
|
||||||
#include "build.h"
|
#include "build.h"
|
||||||
#include "winlayer.h"
|
#include "winlayer.h"
|
||||||
|
@ -23,6 +24,8 @@
|
||||||
#define TAB_GAME 1
|
#define TAB_GAME 1
|
||||||
#define TAB_MESSAGES 2
|
#define TAB_MESSAGES 2
|
||||||
|
|
||||||
|
static struct audioenumdrv *wavedevs = NULL;
|
||||||
|
|
||||||
static struct {
|
static struct {
|
||||||
int fullscreen;
|
int fullscreen;
|
||||||
int xdim, ydim, bpp;
|
int xdim, ydim, bpp;
|
||||||
|
@ -35,12 +38,17 @@ static HWND startupdlg = NULL;
|
||||||
static HWND pages[3] = { NULL, NULL, NULL };
|
static HWND pages[3] = { NULL, NULL, NULL };
|
||||||
static int done = -1, mode = TAB_CONFIG;
|
static int done = -1, mode = TAB_CONFIG;
|
||||||
|
|
||||||
|
#define POPULATE_VIDEO 1
|
||||||
|
#define POPULATE_CONFIG 2
|
||||||
|
#define POPULATE_GAME 4
|
||||||
|
|
||||||
static void PopulateForm(int pgs)
|
static void PopulateForm(int pgs)
|
||||||
{
|
{
|
||||||
HWND hwnd;
|
HWND hwnd;
|
||||||
if (pgs & (1<<TAB_CONFIG)) {
|
char buf[256];
|
||||||
int i,j;
|
int i,j;
|
||||||
char buf[64];
|
|
||||||
|
if (pgs & POPULATE_VIDEO) {
|
||||||
int mode;
|
int mode;
|
||||||
|
|
||||||
hwnd = GetDlgItem(pages[TAB_CONFIG], IDCVMODE);
|
hwnd = GetDlgItem(pages[TAB_CONFIG], IDCVMODE);
|
||||||
|
@ -58,8 +66,6 @@ static void PopulateForm(int pgs)
|
||||||
}
|
}
|
||||||
|
|
||||||
Button_SetCheck(GetDlgItem(pages[TAB_CONFIG], IDCFULLSCREEN), (settings.fullscreen ? BST_CHECKED : BST_UNCHECKED));
|
Button_SetCheck(GetDlgItem(pages[TAB_CONFIG], IDCFULLSCREEN), (settings.fullscreen ? BST_CHECKED : BST_UNCHECKED));
|
||||||
Button_SetCheck(GetDlgItem(pages[TAB_CONFIG], IDCALWAYSSHOW), (settings.forcesetup ? BST_CHECKED : BST_UNCHECKED));
|
|
||||||
|
|
||||||
ComboBox_ResetContent(hwnd);
|
ComboBox_ResetContent(hwnd);
|
||||||
for (i=0; i<validmodecnt; i++) {
|
for (i=0; i<validmodecnt; i++) {
|
||||||
if (validmode[i].fs != settings.fullscreen) continue;
|
if (validmode[i].fs != settings.fullscreen) continue;
|
||||||
|
@ -70,12 +76,39 @@ static void PopulateForm(int pgs)
|
||||||
ComboBox_SetItemData(hwnd, j, i);
|
ComboBox_SetItemData(hwnd, j, i);
|
||||||
if (i == mode) ComboBox_SetCurSel(hwnd, j);
|
if (i == mode) ComboBox_SetCurSel(hwnd, j);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (pgs & POPULATE_CONFIG) {
|
||||||
|
struct audioenumdev *d;
|
||||||
|
char *n;
|
||||||
|
|
||||||
|
hwnd = GetDlgItem(pages[TAB_CONFIG], IDCSOUNDDRV);
|
||||||
|
ComboBox_ResetContent(hwnd);
|
||||||
|
if (wavedevs) {
|
||||||
|
d = wavedevs->devs;
|
||||||
|
for (i=0; wavedevs->drvs[i]; i++) {
|
||||||
|
strcpy(buf, wavedevs->drvs[i]);
|
||||||
|
if (d->devs) {
|
||||||
|
strcat(buf, ":");
|
||||||
|
n = buf + strlen(buf);
|
||||||
|
for (j=0; d->devs[j]; j++) {
|
||||||
|
strcpy(n, d->devs[j]);
|
||||||
|
ComboBox_AddString(hwnd, buf);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
ComboBox_AddString(hwnd, buf);
|
||||||
|
}
|
||||||
|
d = d->next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Button_SetCheck(GetDlgItem(pages[TAB_CONFIG], IDCALWAYSSHOW), (settings.forcesetup ? BST_CHECKED : BST_UNCHECKED));
|
||||||
|
|
||||||
Button_SetCheck(GetDlgItem(pages[TAB_CONFIG], IDCINPUTMOUSE), (settings.usemouse ? BST_CHECKED : BST_UNCHECKED));
|
Button_SetCheck(GetDlgItem(pages[TAB_CONFIG], IDCINPUTMOUSE), (settings.usemouse ? BST_CHECKED : BST_UNCHECKED));
|
||||||
Button_SetCheck(GetDlgItem(pages[TAB_CONFIG], IDCINPUTJOY), (settings.usejoy ? BST_CHECKED : BST_UNCHECKED));
|
Button_SetCheck(GetDlgItem(pages[TAB_CONFIG], IDCINPUTJOY), (settings.usejoy ? BST_CHECKED : BST_UNCHECKED));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pgs & (1<<TAB_GAME)) {
|
if (pgs & POPULATE_GAME) {
|
||||||
struct grpfile *fg;
|
struct grpfile *fg;
|
||||||
int i, j;
|
int i, j;
|
||||||
char buf[128+BMAX_PATH];
|
char buf[128+BMAX_PATH];
|
||||||
|
@ -102,7 +135,7 @@ static INT_PTR CALLBACK ConfigPageProc(HWND hwndDlg, UINT uMsg, WPARAM wParam, L
|
||||||
switch (LOWORD(wParam)) {
|
switch (LOWORD(wParam)) {
|
||||||
case IDCFULLSCREEN:
|
case IDCFULLSCREEN:
|
||||||
settings.fullscreen = !settings.fullscreen;
|
settings.fullscreen = !settings.fullscreen;
|
||||||
PopulateForm(1<<TAB_CONFIG);
|
PopulateForm(POPULATE_VIDEO);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
case IDCVMODE:
|
case IDCVMODE:
|
||||||
if (HIWORD(wParam) == CBN_SELCHANGE) {
|
if (HIWORD(wParam) == CBN_SELCHANGE) {
|
||||||
|
@ -465,7 +498,9 @@ int startwin_run(void)
|
||||||
done = -1;
|
done = -1;
|
||||||
|
|
||||||
ScanGroups();
|
ScanGroups();
|
||||||
|
#ifdef JFAUD
|
||||||
|
EnumAudioDevs(&wavedevs, NULL, NULL);
|
||||||
|
#endif
|
||||||
SetPage(TAB_CONFIG);
|
SetPage(TAB_CONFIG);
|
||||||
EnableConfig(1);
|
EnableConfig(1);
|
||||||
|
|
||||||
|
@ -504,6 +539,19 @@ int startwin_run(void)
|
||||||
duke3dgrp = settings.selectedgrp;
|
duke3dgrp = settings.selectedgrp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef JFAUD
|
||||||
|
if (wavedevs) {
|
||||||
|
struct audioenumdev *d, *e;
|
||||||
|
free(wavedevs->drvs);
|
||||||
|
for (e=wavedevs->devs; e; e=d) {
|
||||||
|
d = e->next;
|
||||||
|
if (e->devs) free(e->devs);
|
||||||
|
free(e);
|
||||||
|
}
|
||||||
|
free(wavedevs);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
return done;
|
return done;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue