File: SoundUtil.h

package info (click to toggle)
pinball 0.3.20201218-4
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye
  • size: 8,452 kB
  • sloc: cpp: 15,230; makefile: 840; sh: 381; xml: 24
file content (82 lines) | stat: -rw-r--r-- 2,320 bytes parent folder | download | duplicates (9)
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
/***************************************************************************
                          SoundUtil.h  -  description
                             -------------------
    begin                : Thu Jan 11 2001
    copyright            : (C) 2001 by Henrik Enqvist, GPL
    email                : henqvist@excite.com
 ***************************************************************************/


#ifndef SOUNDUTIL_H
#define SOUNDUTIL_H

#include <string>
#include <map>
#include <vector>

#ifndef PRIVATE_H
#error Must include Private.h before SoundUtil.h
#endif

#if EM_USE_SDL
#include <SDL.h>
#include <SDL_mixer.h>

#define EmSample Mix_Chunk
#define EmMusic Mix_Music

#define EM_AUDIO_FREQ 22050
#define EM_AUDIO_FORMAT AUDIO_S16
#define EM_AUDIO_CHANNELS 2
#endif // EM_USE_SDL

#if EM_USE_ALLEGRO
#include <allegro.h>
#define EmSample SAMPLE
#define EmMusic MIDI
#endif

/** Singleton class for loading and playing samples */
class SoundUtil {
 protected:
  SoundUtil();
 public:
  ~SoundUtil();
  static SoundUtil* getInstance();
  /** Initializes the sound system. Used by Engine constructor. 
   ** You don't need this use the Config class to turn on/off sound.
   ** @see Config */
  int initSound();
  /** Shuts down sound system. Used by Engine::stopEngine. 
   ** You don't need this use the Config class to turn on/off sound.
   ** @see Config */
  void stopSound();
  void applyConfigVolume();
  // TODO
  void freeSounds();
  /** Loads a wave file. Returns the identifier of the sound, used for playback.
   ** Returns -1 if it fails to load the wave file. */
  int loadSample(const char * filename);
  /** Loads a midi file. Returns the identifier of the sound, used for playback.
   ** Returns -1 if it fails to load the midi file. */
  int loadMusic(const char * filename);
  void playSample(int sound, bool loop);
  void playMusic(int sound, bool loop);
  void stopMusic();
  void pauseMusic();
  void resumeMusic();
  const char * getSoundName(int sound);
  const char * getMusicName(int music);
 private:
  bool m_bInited;
  int m_iLoopingMusic;
  vector<EmSample*> m_vEmSample;
  vector<EmMusic*> m_vEmMusic;
  map<string, int> m_hEmSample;
  map<string, int> m_hEmMusic;
  map<int, string> m_hSoundName;
  map<int, string> m_hMusicName;
  static SoundUtil* p_SoundUtil;
};

#endif