mirror of
https://github.com/DrBeef/Raze.git
synced 2024-11-17 18:01:17 +00:00
38e55f1a8b
Typedef Voc3D_Flags and Voc_Flags to int, and turn typedef'd enums into normal enums. Patch from Striker. git-svn-id: https://svn.eduke32.com/eduke32@7504 1a8010ca-5511-0410-912e-c29ae57300e0
184 lines
6.3 KiB
C
184 lines
6.3 KiB
C
//-------------------------------------------------------------------------
|
|
/*
|
|
Copyright (C) 1997, 2005 - 3D Realms Entertainment
|
|
|
|
This file is part of Shadow Warrior version 1.2
|
|
|
|
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.
|
|
|
|
Original Source: 1997 - Frank Maddin and Jim Norwood
|
|
Prepared for public release: 03/28/2005 - Charlie Wiederhold, 3D Realms
|
|
*/
|
|
//-------------------------------------------------------------------------
|
|
|
|
//****************************************************************************
|
|
//
|
|
// sounds.h
|
|
//
|
|
//****************************************************************************
|
|
|
|
#include "mytypes.h"
|
|
|
|
|
|
#ifndef sounds_public_
|
|
#define sounds_public_
|
|
|
|
void SoundStartup(void);
|
|
void SoundShutdown(void);
|
|
void MusicStartup(void);
|
|
void MusicShutdown(void);
|
|
|
|
// 3D sound engine declarations //////////////////////////////////////////////
|
|
// Flag settings used to turn on and off 3d sound options
|
|
enum
|
|
{
|
|
v3df_none = 0, // Default, take no action, use all defaults
|
|
v3df_follow = 1, // 1 = Do coordinate updates on sound
|
|
// Use this only if the sprite won't be deleted soon
|
|
v3df_kill = 2, // 1 = Sound is to be deleted
|
|
v3df_doppler = 4, // 1 = Don't use doppler pitch variance
|
|
v3df_dontpan = 8, // 1 = Don't do panning of sound
|
|
v3df_ambient = 16, // 1 = Sound is ambient, use ambient struct info.
|
|
v3df_intermit = 32, // 1 = Intermittant sound
|
|
v3df_init = 64, // 1 = First pass of sound, don't play it.
|
|
// This is mainly used for intermittent sounds
|
|
v3df_nolookup = 128 // don't use ambient table lookup
|
|
};
|
|
typedef int Voc3D_Flags;
|
|
|
|
struct VOCstruct;
|
|
typedef struct VOCstruct VOC_INFO, *VOC_INFOp;
|
|
struct VOC3Dstruct;
|
|
typedef struct VOC3Dstruct VOC3D_INFO, *VOC3D_INFOp;
|
|
struct ambientstruct;
|
|
typedef struct ambientstruct AMB_INFO, *AMB_INFOp;
|
|
|
|
|
|
extern VOC3D_INFOp voc3dstart;
|
|
extern VOC3D_INFOp voc3dend;
|
|
|
|
void DoUpdateSounds3D(void);
|
|
void Terminate3DSounds(void);
|
|
|
|
void Set3DSoundOwner(short spritenum);
|
|
void PlaySpriteSound(short spritenum, int attrib_ndx, Voc3D_Flags flags);
|
|
void DeleteNoSoundOwner(short spritenum);
|
|
void DeleteNoFollowSoundOwner(short spritenum);
|
|
|
|
SWBOOL CacheSound(int num, int type);
|
|
void COVER_SetReverb(int amt);
|
|
void UnInitSound(void);
|
|
void InitFX(void);
|
|
void InitMusic(void);
|
|
void StopFX(void);
|
|
void FlipStereo(void);
|
|
void StopSong(void);
|
|
void PauseSong(SWBOOL pauseon);
|
|
void StopSound(void);
|
|
void StartAmbientSound(void);
|
|
void StopAmbientSound(void);
|
|
SWBOOL PlaySong(char *song_file_name, int cdaudio_track, SWBOOL loop, SWBOOL restart);
|
|
void SetSongVolume(int volume);
|
|
SWBOOL SongIsPlaying(void);
|
|
void PlaySoundRTS(int rts_num);
|
|
|
|
//
|
|
// Standard VOC format information - generally don't need this
|
|
//
|
|
|
|
typedef struct
|
|
{
|
|
uint8_t filler[0x1a];
|
|
uint8_t type;
|
|
uint32_t length;
|
|
uint8_t filler2;
|
|
uint8_t freq;
|
|
uint8_t pack;
|
|
uint8_t data[1];
|
|
} *VOC_HDRp;
|
|
|
|
// Ambient Sound Structure
|
|
struct ambientstruct
|
|
{
|
|
int16_t name;
|
|
int16_t diginame;
|
|
Voc3D_Flags ambient_flags;
|
|
int maxtics; // When tics reaches this number next
|
|
// sound happens
|
|
};
|
|
|
|
// VOC File flag settings for digi_entries.
|
|
enum
|
|
{
|
|
vf_normal = 0,
|
|
vf_loop = 1
|
|
};
|
|
typedef int Voc_Flags;
|
|
|
|
//
|
|
// Table that describes the voc file and how it will be played
|
|
// Can be easily extended, but you may need to change digi.h
|
|
//
|
|
|
|
//struct STATEstruct;
|
|
//typedef struct VOCstruct VOC_INFO, *VOC_INFOp;
|
|
|
|
struct VOCstruct
|
|
{
|
|
char name[14]; // name of voc file on disk
|
|
uint8_t* data; // pointer to voc data
|
|
int datalen; // length of voc data
|
|
int16_t pitch_lo; // lo pitch value
|
|
int16_t pitch_hi; // hi pitch value
|
|
uint8_t priority; // priority at which vocs are played
|
|
int16_t voc_num; // Backward reference to parent sound
|
|
int voc_distance; // Sound's distance effectiveness
|
|
Voc_Flags voc_flags; // Various allowable flag settings for voc
|
|
char lock; // locking byte for caching
|
|
uint8_t playing; // number of this type of sound currently playing
|
|
};
|
|
|
|
|
|
// JIMSOUND3D(tm) variables section //////////////////////////////////////////
|
|
|
|
struct VOC3Dstruct
|
|
{
|
|
VOC_INFOp vp; // Pointer to the sound
|
|
int *x; // Pointer to x coordinate
|
|
int *y; // Pointer to y coordinate
|
|
int *z; // Pointer to z coordinate
|
|
int fx, fy, fz; // Non-Follow literal values
|
|
Voc3D_Flags flags; // 3d voc sound flags
|
|
int handle; // Current handle to the voc
|
|
short doplr_delta; // Change in distance since last call
|
|
VOC3D_INFOp prev, next; // Linked voc list
|
|
short owner; // Hold index into user array to
|
|
// delete looping sounds
|
|
int num; // Digital Entry number used for
|
|
// callback of looping sounds
|
|
// If sound is active but user == 0, stop the sound
|
|
short dist; // Current distance of sound from player
|
|
uint8_t priority; // Used to force a higher priority based on distance
|
|
int tics; // Tics used to count to next sound occurance
|
|
int maxtics; // Tics until next sound occurance
|
|
// for intermittent sounds
|
|
SWBOOL deleted; // Has sound been marked for deletion?
|
|
SWBOOL FX_Ok; // Did this sound play ok?
|
|
};
|
|
|
|
extern VOC_INFO voc[];
|
|
|
|
#endif
|