# Conflicts: # src/articulated_vehicles.cpp # src/articulated_vehicles.h # src/autoreplace_cmd.cpp # src/build_vehicle_gui.cpp # src/company_gui.cpp # src/core/format.hpp # src/genworld_gui.cpp # src/gfx.cpp # src/group_gui.cpp # src/linkgraph/linkgraph_gui.cpp # src/misc/endian_buffer.hpp # src/music/music_driver.hpp # src/newgrf_gui.cpp # src/rail_cmd.cpp # src/road_gui.cpp # src/settings_type.h # src/strgen/strgen.cpp # src/strings.cpp # src/timetable_cmd.cpp # src/town.h # src/vehicle.cpp # src/vehicle_gui.cpp # src/vehicle_gui_base.h # src/widget.cpp # src/widgets/dropdown.cpp # src/widgets/road_widget.h
76 lines
2.1 KiB
C++
76 lines
2.1 KiB
C++
/*
|
|
* This file is part of OpenTTD.
|
|
* OpenTTD is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 2.
|
|
* OpenTTD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
* See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with OpenTTD. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
/** @file music_driver.hpp Base for all music playback. */
|
|
|
|
#ifndef MUSIC_MUSIC_DRIVER_HPP
|
|
#define MUSIC_MUSIC_DRIVER_HPP
|
|
|
|
#include "../driver.h"
|
|
|
|
#include <memory>
|
|
#include <mutex>
|
|
|
|
extern std::mutex _music_driver_mutex;
|
|
|
|
struct MusicSongInfo;
|
|
|
|
/** Driver for all music playback. */
|
|
class MusicDriver : public Driver {
|
|
public:
|
|
/**
|
|
* Play a particular song.
|
|
* @param song The information for the song to play.
|
|
*/
|
|
virtual void PlaySong(const MusicSongInfo &song) = 0;
|
|
|
|
/**
|
|
* Stop playing the current song.
|
|
*/
|
|
virtual void StopSong() = 0;
|
|
|
|
/**
|
|
* Are we currently playing a song?
|
|
* @return True if a song is being played.
|
|
*/
|
|
virtual bool IsSongPlaying() = 0;
|
|
|
|
/**
|
|
* Set the volume, if possible.
|
|
* @param vol The new volume.
|
|
*/
|
|
virtual void SetVolume(byte vol) = 0;
|
|
|
|
/**
|
|
* Is playback in a failed state?
|
|
* @return True if playback is in a failed state.
|
|
*/
|
|
virtual bool IsInFailedState() { return false; }
|
|
|
|
static std::unique_ptr<MusicDriver> ExtractDriver()
|
|
{
|
|
Driver **dptr = DriverFactoryBase::GetActiveDriver(Driver::DT_MUSIC);
|
|
Driver *driver = *dptr;
|
|
*dptr = nullptr;
|
|
return std::unique_ptr<MusicDriver>(static_cast<MusicDriver*>(driver));
|
|
}
|
|
|
|
/**
|
|
* Get the currently active instance of the music driver.
|
|
*/
|
|
static MusicDriver *GetInstance()
|
|
{
|
|
std::unique_lock<std::mutex> lock(_music_driver_mutex);
|
|
|
|
return static_cast<MusicDriver*>(*DriverFactoryBase::GetActiveDriver(Driver::DT_MUSIC));
|
|
}
|
|
};
|
|
|
|
extern std::string _ini_musicdriver;
|
|
|
|
#endif /* MUSIC_MUSIC_DRIVER_HPP */
|