author | miham |
Wed, 17 Aug 2005 12:30:07 +0000 | |
changeset 2349 | df02d0ffb588 |
parent 2186 | 461a2aff3486 |
child 2371 | fafe059a4472 |
permissions | -rw-r--r-- |
2186 | 1 |
/* $Id$ */ |
2 |
||
0 | 3 |
#include "stdafx.h" |
1891
92a3b0aa0946
(svn r2397) - CodeChange: rename all "ttd" files to "openttd" files.
Darkvater
parents:
1498
diff
changeset
|
4 |
#include "openttd.h" |
2163
637ec3c361f5
(svn r2673) Include functions.h directly, not globally via openttd.h
tron
parents:
1891
diff
changeset
|
5 |
#include "functions.h" |
679
e959706a3e4d
(svn r1117) Move map arrays and some related macros into their own files map.c and map.h
tron
parents:
337
diff
changeset
|
6 |
#include "map.h" |
1496
3d0b86f5dcb8
(svn r2000) Split the sound system into backend (mixer.[ch]) and frontend (sound.[ch])
tron
parents:
1136
diff
changeset
|
7 |
#include "mixer.h" |
0 | 8 |
#include "sound.h" |
9 |
#include "vehicle.h" |
|
10 |
#include "window.h" |
|
11 |
#include "viewport.h" |
|
12 |
#include "fileio.h" |
|
13 |
||
337
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
14 |
typedef struct FileEntry { |
0 | 15 |
uint32 file_offset; |
16 |
uint32 file_size; |
|
17 |
uint16 rate; |
|
18 |
uint8 bits_per_sample; |
|
19 |
uint8 channels; |
|
337
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
20 |
} FileEntry; |
0 | 21 |
|
1496
3d0b86f5dcb8
(svn r2000) Split the sound system into backend (mixer.[ch]) and frontend (sound.[ch])
tron
parents:
1136
diff
changeset
|
22 |
static uint _file_count; |
3d0b86f5dcb8
(svn r2000) Split the sound system into backend (mixer.[ch]) and frontend (sound.[ch])
tron
parents:
1136
diff
changeset
|
23 |
static FileEntry* _files; |
0 | 24 |
|
25 |
#define SOUND_SLOT 31 |
|
26 |
||
27 |
||
1496
3d0b86f5dcb8
(svn r2000) Split the sound system into backend (mixer.[ch]) and frontend (sound.[ch])
tron
parents:
1136
diff
changeset
|
28 |
static void OpenBankFile(const char *filename) |
0 | 29 |
{ |
30 |
uint count, i; |
|
31 |
uint32 size, tag; |
|
32 |
FileEntry *fe; |
|
33 |
||
34 |
FioOpenFile(SOUND_SLOT, filename); |
|
1496
3d0b86f5dcb8
(svn r2000) Split the sound system into backend (mixer.[ch]) and frontend (sound.[ch])
tron
parents:
1136
diff
changeset
|
35 |
_file_count = count = FioReadDword() >> 3; |
3d0b86f5dcb8
(svn r2000) Split the sound system into backend (mixer.[ch]) and frontend (sound.[ch])
tron
parents:
1136
diff
changeset
|
36 |
fe = _files = calloc(sizeof(FileEntry), count); |
0 | 37 |
|
38 |
FioSeekTo(0, SEEK_SET); |
|
39 |
||
1496
3d0b86f5dcb8
(svn r2000) Split the sound system into backend (mixer.[ch]) and frontend (sound.[ch])
tron
parents:
1136
diff
changeset
|
40 |
for (i = 0; i != count; i++) { |
3d0b86f5dcb8
(svn r2000) Split the sound system into backend (mixer.[ch]) and frontend (sound.[ch])
tron
parents:
1136
diff
changeset
|
41 |
fe[i].file_offset = FioReadDword(); |
3d0b86f5dcb8
(svn r2000) Split the sound system into backend (mixer.[ch]) and frontend (sound.[ch])
tron
parents:
1136
diff
changeset
|
42 |
fe[i].file_size = FioReadDword(); |
0 | 43 |
} |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
0
diff
changeset
|
44 |
|
337
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
45 |
for (i = 0; i != count; i++, fe++) { |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
46 |
char name[255]; |
0 | 47 |
|
337
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
48 |
FioSeekTo(fe->file_offset, SEEK_SET); |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
49 |
|
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
50 |
// Check for special case, see else case |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
51 |
FioReadBlock(name, FioReadByte()); // Read the name of the sound |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
52 |
if (strcmp(name, "Corrupt sound") != 0) { |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
53 |
FioSeekTo(12, SEEK_CUR); // Skip past RIFF header |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
54 |
|
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
55 |
// Read riff tags |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
56 |
for (;;) { |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
57 |
tag = FioReadDword(); |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
58 |
size = FioReadDword(); |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
59 |
|
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
60 |
if (tag == ' tmf') { |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
61 |
FioReadWord(); // wFormatTag |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
62 |
fe->channels = FioReadWord(); // wChannels |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
63 |
FioReadDword(); // samples per second |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
64 |
fe->rate = 11025; // seems like all samples should be played at this rate. |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
65 |
FioReadDword(); // avg bytes per second |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
66 |
FioReadWord(); // alignment |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
67 |
fe->bits_per_sample = FioReadByte(); // bits per sample |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
68 |
FioSeekTo(size - (2 + 2 + 4 + 4 + 2 + 1), SEEK_CUR); |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
69 |
} else if (tag == 'atad') { |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
70 |
fe->file_size = size; |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
71 |
fe->file_offset = FioGetPos() | (SOUND_SLOT << 24); |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
72 |
break; |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
73 |
} else { |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
74 |
fe->file_size = 0; |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
75 |
break; |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
76 |
} |
0 | 77 |
} |
337
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
78 |
} else { |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
79 |
/* |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
80 |
* Special case for the jackhammer sound |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
81 |
* (name in sample.cat is "Corrupt sound") |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
82 |
* It's no RIFF file, but raw PCM data |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
83 |
*/ |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
84 |
fe->channels = 1; |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
85 |
fe->rate = 11025; |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
86 |
fe->bits_per_sample = 8; |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
87 |
fe->file_offset = FioGetPos() | (SOUND_SLOT << 24); |
0 | 88 |
} |
89 |
} |
|
90 |
} |
|
91 |
||
1496
3d0b86f5dcb8
(svn r2000) Split the sound system into backend (mixer.[ch]) and frontend (sound.[ch])
tron
parents:
1136
diff
changeset
|
92 |
static bool SetBankSource(MixerChannel *mc, uint bank) |
0 | 93 |
{ |
1496
3d0b86f5dcb8
(svn r2000) Split the sound system into backend (mixer.[ch]) and frontend (sound.[ch])
tron
parents:
1136
diff
changeset
|
94 |
FileEntry *fe = &_files[bank]; |
337
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
95 |
int8 *mem; |
0 | 96 |
uint i; |
97 |
||
98 |
if (fe->file_size == 0) |
|
99 |
return false; |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
0
diff
changeset
|
100 |
|
337
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
101 |
mem = malloc(fe->file_size); /* XXX unchecked malloc */ |
0 | 102 |
FioSeekToFile(fe->file_offset); |
103 |
FioReadBlock(mem, fe->file_size); |
|
104 |
||
337
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
105 |
for (i = 0; i != fe->file_size; i++) |
1136 | 106 |
mem[i] += -128; // Convert unsigned sound data to signed |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
0
diff
changeset
|
107 |
|
0 | 108 |
assert(fe->bits_per_sample == 8 && fe->channels == 1 && fe->file_size != 0 && fe->rate != 0); |
109 |
||
1496
3d0b86f5dcb8
(svn r2000) Split the sound system into backend (mixer.[ch]) and frontend (sound.[ch])
tron
parents:
1136
diff
changeset
|
110 |
MxSetChannelRawSrc(mc, mem, fe->file_size, fe->rate, MX_AUTOFREE); |
0 | 111 |
|
112 |
return true; |
|
113 |
} |
|
114 |
||
1496
3d0b86f5dcb8
(svn r2000) Split the sound system into backend (mixer.[ch]) and frontend (sound.[ch])
tron
parents:
1136
diff
changeset
|
115 |
bool SoundInitialize(const char *filename) |
0 | 116 |
{ |
1496
3d0b86f5dcb8
(svn r2000) Split the sound system into backend (mixer.[ch]) and frontend (sound.[ch])
tron
parents:
1136
diff
changeset
|
117 |
OpenBankFile(filename); |
0 | 118 |
return true; |
119 |
} |
|
120 |
||
121 |
// Low level sound player |
|
122 |
static void StartSound(uint sound, uint panning, uint volume) |
|
123 |
{ |
|
124 |
if (volume != 0) { |
|
125 |
MixerChannel *mc = MxAllocateChannel(_mixer); |
|
126 |
if (mc == NULL) |
|
127 |
return; |
|
1496
3d0b86f5dcb8
(svn r2000) Split the sound system into backend (mixer.[ch]) and frontend (sound.[ch])
tron
parents:
1136
diff
changeset
|
128 |
if (SetBankSource(mc, sound)) { |
0 | 129 |
MxSetChannelVolume(mc, volume << 8, volume << 8); |
1498
cbe7edba0316
(svn r2002) Rename MxActivate to MxActivateChannel, which is more appropriate
tron
parents:
1496
diff
changeset
|
130 |
MxActivateChannel(mc); |
0 | 131 |
} |
132 |
} |
|
133 |
} |
|
134 |
||
135 |
||
136 |
static const byte _vol_factor_by_zoom[] = {255, 190, 134}; |
|
137 |
||
138 |
static const byte _sound_base_vol[] = { |
|
139 |
128, 90, 128, 128, 128, 128, 128, 128, |
|
140 |
128, 90, 90, 128, 128, 128, 128, 128, |
|
141 |
128, 128, 128, 80, 128, 128, 128, 128, |
|
142 |
128, 128, 128, 128, 128, 128, 128, 128, |
|
143 |
128, 128, 90, 90, 90, 128, 90, 128, |
|
144 |
128, 90, 128, 128, 128, 90, 128, 128, |
|
145 |
128, 128, 128, 128, 90, 128, 128, 128, |
|
146 |
128, 90, 128, 128, 128, 128, 128, 128, |
|
147 |
128, 128, 90, 90, 90, 128, 128, 128, |
|
148 |
90, |
|
149 |
}; |
|
150 |
||
151 |
static const byte _sound_idx[] = { |
|
152 |
2, 3, 4, 5, 6, 7, 8, 9, |
|
153 |
10, 11, 12, 13, 14, 15, 16, 17, |
|
154 |
18, 19, 20, 21, 22, 23, 24, 25, |
|
155 |
26, 27, 28, 29, 30, 31, 32, 33, |
|
156 |
34, 35, 36, 37, 38, 39, 40, 0, |
|
157 |
1, 41, 42, 43, 44, 45, 46, 47, |
|
158 |
48, 49, 50, 51, 52, 53, 54, 55, |
|
159 |
56, 57, 58, 59, 60, 61, 62, 63, |
|
160 |
64, 65, 66, 67, 68, 69, 70, 71, |
|
161 |
72, |
|
162 |
}; |
|
163 |
||
337
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
164 |
static void SndPlayScreenCoordFx(SoundFx sound, int x, int y) |
0 | 165 |
{ |
166 |
Window *w; |
|
167 |
ViewPort *vp; |
|
168 |
int left; |
|
169 |
||
170 |
if (msf.effect_vol == 0) |
|
171 |
return; |
|
172 |
||
337
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
173 |
for (w = _windows; w != _last_window; w++) { |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
174 |
if ((vp = w->viewport) != NULL && |
0 | 175 |
IS_INSIDE_1D(x, vp->virtual_left, vp->virtual_width) && |
176 |
IS_INSIDE_1D(y, vp->virtual_top, vp->virtual_height)) { |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
0
diff
changeset
|
177 |
|
0 | 178 |
left = ((x - vp->virtual_left) >> vp->zoom) + vp->left; |
179 |
StartSound( |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
0
diff
changeset
|
180 |
_sound_idx[sound], |
0 | 181 |
clamp(left / 71, 0, 8), |
182 |
(_sound_base_vol[sound] * msf.effect_vol * _vol_factor_by_zoom[vp->zoom]) >> 15 |
|
183 |
); |
|
184 |
return; |
|
185 |
} |
|
186 |
} |
|
187 |
||
188 |
} |
|
189 |
||
337
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
190 |
void SndPlayTileFx(SoundFx sound, TileIndex tile) |
0 | 191 |
{ |
337
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
192 |
/* emits sound from center (+ 8) of the tile */ |
926
bd4312619522
(svn r1414) Move TileIndex, TILE_MASK and GET_TILE_[XY] to map.h and turn the latter into inline functions names Tile[XY]
tron
parents:
679
diff
changeset
|
193 |
int x = TileX(tile) * 16 + 8; |
bd4312619522
(svn r1414) Move TileIndex, TILE_MASK and GET_TILE_[XY] to map.h and turn the latter into inline functions names Tile[XY]
tron
parents:
679
diff
changeset
|
194 |
int y = TileY(tile) * 16 + 8; |
337
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
195 |
Point pt = RemapCoords(x, y, GetSlopeZ(x, y)); |
0 | 196 |
SndPlayScreenCoordFx(sound, pt.x, pt.y); |
197 |
} |
|
198 |
||
337
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
199 |
void SndPlayVehicleFx(SoundFx sound, const Vehicle *v) |
0 | 200 |
{ |
201 |
SndPlayScreenCoordFx(sound, |
|
337
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
202 |
(v->left_coord + v->right_coord) / 2, |
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
203 |
(v->top_coord + v->bottom_coord) / 2 |
0 | 204 |
); |
205 |
} |
|
206 |
||
337
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
207 |
void SndPlayFx(SoundFx sound) |
0 | 208 |
{ |
209 |
StartSound( |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
0
diff
changeset
|
210 |
_sound_idx[sound], |
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
0
diff
changeset
|
211 |
4, |
0 | 212 |
(_sound_base_vol[sound] * msf.effect_vol) >> 7 |
213 |
); |
|
214 |
} |