fix qt music player
This commit is contained in:
parent
f0a0ecb983
commit
8a4fc4516c
@ -8,13 +8,13 @@
|
|||||||
#elif defined(QTAUDIO)
|
#elif defined(QTAUDIO)
|
||||||
#include <QMediaPlayer>
|
#include <QMediaPlayer>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "aoapplication.h"
|
#include "aoapplication.h"
|
||||||
|
|
||||||
#include <QDebug>
|
#include <QDebug>
|
||||||
#include <QWidget>
|
#include <QWidget>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#if defined(BASSAUDIO)
|
|
||||||
class AOMusicPlayer {
|
class AOMusicPlayer {
|
||||||
public:
|
public:
|
||||||
AOMusicPlayer(QWidget *parent, AOApplication *p_ao_app);
|
AOMusicPlayer(QWidget *parent, AOApplication *p_ao_app);
|
||||||
@ -25,8 +25,8 @@ public:
|
|||||||
const int m_channelmax = 4;
|
const int m_channelmax = 4;
|
||||||
|
|
||||||
// These have to be public for the stupid sync thing
|
// These have to be public for the stupid sync thing
|
||||||
QWORD loop_start = 0;
|
int loop_start = 0;
|
||||||
QWORD loop_end = 0;
|
int loop_end = 0;
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
void play(QString p_song, int channel = 0, bool loop = false,
|
void play(QString p_song, int channel = 0, bool loop = false,
|
||||||
@ -44,52 +44,12 @@ private:
|
|||||||
// Channel 1 = ambience
|
// Channel 1 = ambience
|
||||||
// Channel 2 = extra
|
// Channel 2 = extra
|
||||||
// Channel 3 = extra
|
// Channel 3 = extra
|
||||||
|
#if defined(BASSAUDIO)
|
||||||
HSTREAM m_stream_list[4];
|
HSTREAM m_stream_list[4];
|
||||||
HSYNC loop_sync[4];
|
HSYNC loop_sync[4];
|
||||||
};
|
|
||||||
#elif defined(QTAUDIO)
|
#elif defined(QTAUDIO)
|
||||||
class AOMusicPlayer {
|
QMediaPlayer m_stream_list[4];
|
||||||
public:
|
|
||||||
AOMusicPlayer(QWidget *parent, AOApplication *p_ao_app);
|
|
||||||
~AOMusicPlayer();
|
|
||||||
|
|
||||||
void play(QString p_song);
|
|
||||||
void set_volume(int p_value);
|
|
||||||
|
|
||||||
private:
|
|
||||||
QMediaPlayer m_player;
|
|
||||||
QWidget *m_parent;
|
|
||||||
AOApplication *ao_app;
|
|
||||||
|
|
||||||
int m_volume = 0;
|
|
||||||
};
|
|
||||||
#else
|
|
||||||
class AOMusicPlayer {
|
|
||||||
public:
|
|
||||||
AOMusicPlayer(QWidget *parent, AOApplication *p_ao_app);
|
|
||||||
virtual ~AOMusicPlayer();
|
|
||||||
void set_volume(int p_value, int channel = -1);
|
|
||||||
void set_looping(bool toggle, int channel = 0);
|
|
||||||
|
|
||||||
const int m_channelmax = 4;
|
|
||||||
|
|
||||||
public slots:
|
|
||||||
void play(QString p_song, int channel = 0, bool loop = false,
|
|
||||||
int effect_flags = 0);
|
|
||||||
void stop(int channel = 0);
|
|
||||||
|
|
||||||
private:
|
|
||||||
QWidget *m_parent;
|
|
||||||
AOApplication *ao_app;
|
|
||||||
|
|
||||||
bool m_looping = false;
|
|
||||||
int m_volume[4] = {0, 0, 0, 0};
|
|
||||||
|
|
||||||
// Channel 0 = music
|
|
||||||
// Channel 1 = ambience
|
|
||||||
// Channel 2 = extra
|
|
||||||
// Channel 3 = extra
|
|
||||||
};
|
|
||||||
#endif
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
#endif // AOMUSICPLAYER_H
|
#endif // AOMUSICPLAYER_H
|
||||||
|
@ -176,26 +176,40 @@ AOMusicPlayer::AOMusicPlayer(QWidget *parent, AOApplication *p_ao_app)
|
|||||||
ao_app = p_ao_app;
|
ao_app = p_ao_app;
|
||||||
}
|
}
|
||||||
|
|
||||||
AOMusicPlayer::~AOMusicPlayer() { m_player.stop(); }
|
AOMusicPlayer::~AOMusicPlayer() {
|
||||||
|
for (int n_stream = 0; n_stream < m_channelmax; ++n_stream) {
|
||||||
|
m_stream_list[n_stream].stop();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void AOMusicPlayer::play(QString p_song)
|
void AOMusicPlayer::play(QString p_song, int channel, bool loop,
|
||||||
|
int effect_flags)
|
||||||
{
|
{
|
||||||
m_player.stop();
|
channel = channel % m_channelmax;
|
||||||
|
if (channel < 0) // wtf?
|
||||||
|
return;
|
||||||
QString f_path = ao_app->get_music_path(p_song);
|
QString f_path = ao_app->get_music_path(p_song);
|
||||||
|
|
||||||
m_player.setMedia(QUrl::fromLocalFile(f_path));
|
m_stream_list[channel].stop();
|
||||||
|
|
||||||
this->set_volume(m_volume);
|
m_stream_list[channel].setMedia(QUrl::fromLocalFile(f_path));
|
||||||
|
|
||||||
m_player.play();
|
this->set_volume(m_volume[channel], channel);
|
||||||
|
|
||||||
|
m_stream_list[channel].play();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AOMusicPlayer::set_volume(int p_value)
|
void AOMusicPlayer::stop(int channel)
|
||||||
{
|
{
|
||||||
m_volume = p_value;
|
m_stream_list[channel].stop();
|
||||||
m_player.setVolume(m_volume);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AOMusicPlayer::set_volume(int p_value, int channel)
|
||||||
|
{
|
||||||
|
m_volume[channel] = p_value;
|
||||||
|
m_stream_list[channel].setVolume(m_volume[channel]);
|
||||||
|
}
|
||||||
|
|
||||||
#else
|
#else
|
||||||
AOMusicPlayer::AOMusicPlayer(QWidget *parent, AOApplication *p_ao_app)
|
AOMusicPlayer::AOMusicPlayer(QWidget *parent, AOApplication *p_ao_app)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user