1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
|
/* ScummVM - Graphic Adventure Engine
*
* ScummVM is the legal property of its developers, whose names
* are too numerous to list here. Please refer to the COPYRIGHT
* file distributed with this source distribution.
*
* This program 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.
*
*/
/*
* This code is based on original Soltys source code
* Copyright (c) 1994-1995 Janus B. Wisniewski and L.K. Avalon
*/
#ifndef __CGE_WAV__
#define __CGE_WAV__
#include "cge/general.h"
namespace CGE {
#define WAVE_FORMAT_PCM 0x0001
#define IBM_FORMAT_MULAW 0x0101
#define IBM_FORMAT_ALAW 0x0102
#define IBM_FORMAT_ADPCM 0x0103
typedef char FOURCC[4]; // Four-character code
typedef uint32 CKSIZE; // 32-bit unsigned size
class CKID { // Chunk type identifier
union {
FOURCC Tx;
uint32 Id;
};
protected:
static XFile *ckFile;
public:
CKID(FOURCC t) {
memcpy(Tx, t, sizeof(Tx));
}
CKID(uint32 d) {
Id = d;
}
CKID(XFile *xf) {
(ckFile = xf)->read(Tx, sizeof(Tx));
}
bool operator !=(CKID &X) {
return Id != X.Id;
}
bool operator ==(CKID &X) {
return Id == X.Id;
}
const char *Name(void);
};
class CKHEA : public CKID {
protected:
CKSIZE ckSize; // Chunk size field (size of ckData)
public:
CKHEA(XFile *xf) : CKID(xf) {
XRead(xf, &ckSize);
}
CKHEA(char id[]) : CKID(id), ckSize(0) { }
void Skip(void);
CKSIZE Size(void) {
return ckSize;
}
};
class FMTCK : public CKHEA {
struct WAV {
uint16 wFormatTag; // Format category
uint16 wChannels; // Number of channels
uint32 dwSamplesPerSec; // Sampling rate
uint32 dwAvgBytesPerSec; // For buffer estimation
uint16 wBlockAlign; // Data block size
} Wav;
union {
struct {
uint16 wBitsPerSample; // Sample size
} Pcm;
};
public:
FMTCK(CKHEA &hea);
inline uint16 Channels(void) {
return Wav.wChannels;
}
inline uint32 SmplRate(void) {
return Wav.dwSamplesPerSec;
}
inline uint32 ByteRate(void) {
return Wav.dwAvgBytesPerSec;
}
inline uint16 BlckSize(void) {
return Wav.wBlockAlign;
}
inline uint16 SmplSize(void) {
return Pcm.wBitsPerSample;
}
};
class DATACK : public CKHEA {
bool e;
union {
uint8 *Buf;
EMS *EBuf;
};
public:
DATACK(CKHEA &hea);
DATACK(CKHEA &hea, EMM *emm);
DATACK(int first, int last);
~DATACK(void);
inline uint8 *Addr(void) {
return Buf;
}
inline EMS *EAddr(void) {
return EBuf;
}
};
extern CKID RIFF;
extern CKID WAVE;
extern CKID FMT;
extern CKID DATA;
DATACK *LoadWave(XFile *file, EMM *emm = NULL);
} // End of namespace CGE
#endif
|