aboutsummaryrefslogtreecommitdiff
path: root/src/aosfxplayer.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/aosfxplayer.cpp')
-rw-r--r--src/aosfxplayer.cpp66
1 files changed, 43 insertions, 23 deletions
diff --git a/src/aosfxplayer.cpp b/src/aosfxplayer.cpp
index 8d88667c..1b9be002 100644
--- a/src/aosfxplayer.cpp
+++ b/src/aosfxplayer.cpp
@@ -1,15 +1,15 @@
#include "aosfxplayer.h"
+
#include "file_functions.h"
-AOSfxPlayer::AOSfxPlayer(QWidget *parent, AOApplication *p_ao_app)
-{
- m_parent = parent;
- ao_app = p_ao_app;
-}
+AOSfxPlayer::AOSfxPlayer(AOApplication *p_ao_app)
+ : ao_app(p_ao_app)
+{}
void AOSfxPlayer::clear()
{
- for (int n_stream = 0; n_stream < m_channelmax; ++n_stream) {
+ for (int n_stream = 0; n_stream < CHANNEL_COUNT; ++n_stream)
+ {
BASS_ChannelStop(m_stream_list[n_stream]);
}
set_volume_internal(m_volume);
@@ -17,44 +17,51 @@ void AOSfxPlayer::clear()
void AOSfxPlayer::loop_clear()
{
- for (int n_stream = 0; n_stream < m_channelmax; ++n_stream) {
+ for (int n_stream = 0; n_stream < CHANNEL_COUNT; ++n_stream)
+ {
if ((BASS_ChannelFlags(m_stream_list[n_stream], 0, 0) & BASS_SAMPLE_LOOP))
+ {
BASS_ChannelStop(m_stream_list[n_stream]);
+ }
}
set_volume_internal(m_volume);
}
void AOSfxPlayer::play(QString p_sfx, QString p_character, QString p_misc)
{
- for (int i = 0; i < m_channelmax; ++i) {
+ for (int i = 0; i < CHANNEL_COUNT; ++i)
+ {
if (BASS_ChannelIsActive(m_stream_list[i]) == BASS_ACTIVE_PLAYING)
- m_channel = (i + 1) % m_channelmax;
- else {
+ {
+ m_channel = (i + 1) % CHANNEL_COUNT;
+ }
+ else
+ {
m_channel = i;
break;
}
}
QString path = ao_app->get_sfx(p_sfx, p_misc, p_character);
if (path.endsWith(".opus"))
- m_stream_list[m_channel] = BASS_OPUS_StreamCreateFile(
- FALSE, path.utf16(), 0, 0,
- BASS_STREAM_AUTOFREE | BASS_UNICODE | BASS_ASYNCFILE);
+ {
+ m_stream_list[m_channel] = BASS_OPUS_StreamCreateFile(FALSE, path.utf16(), 0, 0, BASS_STREAM_AUTOFREE | BASS_UNICODE | BASS_ASYNCFILE);
+ }
else
- m_stream_list[m_channel] = BASS_StreamCreateFile(
- FALSE, path.utf16(), 0, 0,
- BASS_STREAM_AUTOFREE | BASS_UNICODE | BASS_ASYNCFILE);
+ {
+ m_stream_list[m_channel] = BASS_StreamCreateFile(FALSE, path.utf16(), 0, 0, BASS_STREAM_AUTOFREE | BASS_UNICODE | BASS_ASYNCFILE);
+ }
set_volume_internal(m_volume);
BASS_ChannelSetDevice(m_stream_list[m_channel], BASS_GetDevice());
BASS_ChannelPlay(m_stream_list[m_channel], false);
- BASS_ChannelSetSync(m_stream_list[m_channel], BASS_SYNC_DEV_FAIL, 0,
- ao_app->BASSreset, 0);
+ BASS_ChannelSetSync(m_stream_list[m_channel], BASS_SYNC_DEV_FAIL, 0, ao_app->BASSreset, 0);
}
void AOSfxPlayer::stop(int channel)
{
- if (channel == -1) {
+ if (channel == -1)
+ {
channel = m_channel;
}
BASS_ChannelStop(m_stream_list[channel]);
@@ -67,6 +74,11 @@ void AOSfxPlayer::set_muted(bool toggle)
set_volume_internal(m_volume);
}
+int AOSfxPlayer::get_volume()
+{
+ return m_volume * 100;
+}
+
void AOSfxPlayer::set_volume(qreal p_value)
{
m_volume = p_value * 0.01;
@@ -77,25 +89,33 @@ void AOSfxPlayer::set_volume_internal(qreal p_value)
{
// If muted, volume will always be 0
float volume = static_cast<float>(p_value) * !m_muted;
- for (int n_stream = 0; n_stream < m_channelmax; ++n_stream) {
+ for (int n_stream = 0; n_stream < CHANNEL_COUNT; ++n_stream)
+ {
BASS_ChannelSetAttribute(m_stream_list[n_stream], BASS_ATTRIB_VOL, volume);
}
}
void AOSfxPlayer::set_looping(bool toggle, int channel)
{
- if (channel == -1) {
+ if (channel == -1)
+ {
channel = m_channel;
}
m_looping = toggle;
- if (BASS_ChannelFlags(m_stream_list[channel], 0, 0) & BASS_SAMPLE_LOOP) {
+ if (BASS_ChannelFlags(m_stream_list[channel], 0, 0) & BASS_SAMPLE_LOOP)
+ {
if (m_looping == false)
+ {
BASS_ChannelFlags(m_stream_list[channel], 0,
BASS_SAMPLE_LOOP); // remove the LOOP flag
+ }
}
- else {
+ else
+ {
if (m_looping == true)
+ {
BASS_ChannelFlags(m_stream_list[channel], BASS_SAMPLE_LOOP,
BASS_SAMPLE_LOOP); // set the LOOP flag
+ }
}
}