blob: 163c5b4ba2da3301dca18da2716d8b9389863397 (
plain)
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
|
#pragma once
#include <soloud.h>
#include <soloud_wav.h>
#include <memory>
#include "api/Resource.h"
namespace crepe {
class Sound {
public:
/**
* \brief Pause this sample
*
* Pauses this sound if it is playing, or does nothing if it is already
* paused. The playhead position is saved, such that calling \c play() after
* this function makes the sound resume.
*/
void pause();
/**
* \brief Play this sample
*
* Resume playback if this sound is paused, or start from the beginning of
* the sample.
*
* \note This class only saves a reference to the most recent 'voice' of this
* sound. Calling \c play() while the sound is already playing causes
* multiple instances of the sample to play simultaniously. The sample
* started last is the one that is controlled afterwards.
*/
void play();
/**
* \brief Reset playhead position
*
* Resets the playhead position so that calling \c play() after this function
* makes it play from the start of the sample. If the sound is not paused
* before calling this function, this function will stop playback.
*/
void rewind();
/**
* \brief Set playback volume / gain
*
* \param volume Volume (0 = muted, 1 = full volume)
*/
void set_volume(float volume);
/**
* \brief Set looping behavior for this sample
*
* \param looping Looping behavior (false = one-shot, true = loop)
*/
void set_looping(bool looping);
public:
Sound(const char * src);
Sound(std::unique_ptr<api::Resource> res);
private:
void load(std::unique_ptr<api::Resource> res);
private:
std::unique_ptr<api::Resource> res;
SoLoud::Wav sample;
SoLoud::handle handle;
};
}
|