2015-05-23 22:55:12 -06:00
|
|
|
// Copyright 2009 Dolphin Emulator Project
|
2015-05-17 17:08:10 -06:00
|
|
|
// Licensed under GPLv2+
|
2013-04-17 21:09:55 -06:00
|
|
|
// Refer to the license.txt file included.
|
2009-02-22 23:17:57 -07:00
|
|
|
|
2014-02-10 11:54:46 -07:00
|
|
|
#pragma once
|
2009-02-22 23:17:57 -07:00
|
|
|
|
2015-05-24 02:13:02 -06:00
|
|
|
#include <memory>
|
|
|
|
|
2014-02-17 03:18:15 -07:00
|
|
|
#include "AudioCommon/Mixer.h"
|
|
|
|
#include "AudioCommon/WaveFile.h"
|
2014-09-07 19:06:58 -06:00
|
|
|
#include "Common/CommonTypes.h"
|
2009-02-22 23:17:57 -07:00
|
|
|
|
|
|
|
class SoundStream
|
|
|
|
{
|
|
|
|
protected:
|
2015-05-24 02:13:02 -06:00
|
|
|
std::unique_ptr<CMixer> m_mixer;
|
2013-03-19 19:51:12 -06:00
|
|
|
bool m_logAudio;
|
2009-03-27 08:26:44 -06:00
|
|
|
WaveFileWriter g_wave_writer;
|
2009-12-13 04:51:29 -07:00
|
|
|
bool m_muted;
|
2009-03-27 08:26:44 -06:00
|
|
|
|
2013-10-28 23:23:17 -06:00
|
|
|
public:
|
2015-05-24 02:13:02 -06:00
|
|
|
SoundStream() : m_mixer(new CMixer(48000)), m_logAudio(false), m_muted(false) {}
|
|
|
|
virtual ~SoundStream() { }
|
2013-03-19 19:51:12 -06:00
|
|
|
|
2013-10-28 23:23:17 -06:00
|
|
|
static bool isValid() { return false; }
|
2015-05-24 03:03:14 -06:00
|
|
|
CMixer* GetMixer() const { return m_mixer.get(); }
|
2009-03-26 03:29:14 -06:00
|
|
|
virtual bool Start() { return false; }
|
2009-05-18 13:24:46 -06:00
|
|
|
virtual void SetVolume(int) {}
|
2009-03-26 03:29:14 -06:00
|
|
|
virtual void SoundLoop() {}
|
|
|
|
virtual void Stop() {}
|
|
|
|
virtual void Update() {}
|
2009-12-13 04:51:29 -07:00
|
|
|
virtual void Clear(bool mute) { m_muted = mute; }
|
2013-12-11 06:43:58 -07:00
|
|
|
bool IsMuted() const { return m_muted; }
|
2014-08-30 14:29:15 -06:00
|
|
|
|
2015-05-24 04:05:30 -06:00
|
|
|
void StartLogAudio(const std::string& filename)
|
2014-08-30 14:29:15 -06:00
|
|
|
{
|
2014-11-13 19:28:27 -07:00
|
|
|
if (!m_logAudio)
|
2014-08-30 14:29:15 -06:00
|
|
|
{
|
2009-03-27 08:26:44 -06:00
|
|
|
m_logAudio = true;
|
2011-02-12 22:05:53 -07:00
|
|
|
g_wave_writer.Start(filename, m_mixer->GetSampleRate());
|
2009-03-27 08:26:44 -06:00
|
|
|
g_wave_writer.SetSkipSilence(false);
|
|
|
|
NOTICE_LOG(DSPHLE, "Starting Audio logging");
|
2014-08-30 14:29:15 -06:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2009-03-27 08:26:44 -06:00
|
|
|
WARN_LOG(DSPHLE, "Audio logging already started");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-05-24 04:05:30 -06:00
|
|
|
void StopLogAudio()
|
2014-08-30 14:29:15 -06:00
|
|
|
{
|
|
|
|
if (m_logAudio)
|
|
|
|
{
|
2009-03-27 08:26:44 -06:00
|
|
|
m_logAudio = false;
|
|
|
|
g_wave_writer.Stop();
|
2009-03-30 00:32:58 -06:00
|
|
|
NOTICE_LOG(DSPHLE, "Stopping Audio logging");
|
2014-08-30 14:29:15 -06:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2009-03-27 08:26:44 -06:00
|
|
|
WARN_LOG(DSPHLE, "Audio logging already stopped");
|
|
|
|
}
|
|
|
|
}
|
2009-02-22 23:17:57 -07:00
|
|
|
};
|