2009-02-17 15:05:16 +00:00
|
|
|
/* ScummVM - Graphic Adventure Engine
|
|
|
|
*
|
|
|
|
* ScummVM is the legal property of its developers, whose names
|
|
|
|
* are too numerous to list here. Please refer to the COPYRIGHT
|
|
|
|
* file distributed with this source distribution.
|
|
|
|
*
|
|
|
|
* This program 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; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
|
|
|
|
* This program 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 this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*
|
|
|
|
* $URL$
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
*/
|
2009-02-15 06:10:59 +00:00
|
|
|
|
|
|
|
/* song player structure */
|
|
|
|
|
2009-02-24 15:33:40 +00:00
|
|
|
#ifndef SCI_SFX_SFX_PLAYER_H
|
|
|
|
#define SCI_SFX_SFX_PLAYER_H
|
2009-02-21 10:23:36 +00:00
|
|
|
|
2009-05-26 11:35:35 +00:00
|
|
|
#include "common/scummsys.h"
|
|
|
|
|
2009-05-15 14:07:45 +00:00
|
|
|
#include "sci/resource.h"
|
2009-03-10 02:42:22 +00:00
|
|
|
#include "sci/sfx/iterator.h"
|
2009-02-15 06:10:59 +00:00
|
|
|
|
2009-02-21 10:23:36 +00:00
|
|
|
namespace Sci {
|
2009-02-15 06:10:59 +00:00
|
|
|
|
2009-05-26 11:49:10 +00:00
|
|
|
class SfxPlayer {
|
|
|
|
public:
|
2009-02-15 06:10:59 +00:00
|
|
|
const char *name;
|
|
|
|
const char *version;
|
|
|
|
|
2009-05-26 11:49:10 +00:00
|
|
|
/** Number of voices that can play simultaneously */
|
|
|
|
int polyphony;
|
|
|
|
|
|
|
|
public:
|
|
|
|
SfxPlayer() : name(0), version(0), polyphony(0) {}
|
|
|
|
virtual ~SfxPlayer() {}
|
2009-02-15 06:10:59 +00:00
|
|
|
|
2009-05-26 11:49:10 +00:00
|
|
|
virtual Common::Error init(ResourceManager *resmgr, int expected_latency) = 0;
|
2009-02-15 06:10:59 +00:00
|
|
|
/* Initializes the player
|
2009-02-20 15:24:22 +00:00
|
|
|
** Parameters: (ResourceManager *) resmgr: A resource manager for driver initialization
|
2009-02-15 06:10:59 +00:00
|
|
|
** (int) expected_latency: Expected delay in between calls to 'maintenance'
|
|
|
|
** (in microseconds)
|
2009-05-12 23:31:55 +00:00
|
|
|
** Returns : (int) Common::kNoError on success, Common::kUnknownError on failure
|
2009-02-15 06:10:59 +00:00
|
|
|
*/
|
|
|
|
|
2009-05-26 11:49:10 +00:00
|
|
|
virtual Common::Error add_iterator(SongIterator *it, uint32 start_time) = 0;
|
2009-02-15 06:10:59 +00:00
|
|
|
/* Adds an iterator to the song player
|
|
|
|
** Parameters: (songx_iterator_t *) it: The iterator to play
|
2009-02-24 18:31:05 +00:00
|
|
|
** (uint32) start_time: The time to assume as the
|
2009-02-15 06:10:59 +00:00
|
|
|
** time the first MIDI command executes at
|
2009-05-12 23:31:55 +00:00
|
|
|
** Returns : (int) Common::kNoError on success, Common::kUnknownError on failure
|
2009-02-15 06:10:59 +00:00
|
|
|
** The iterator should not be cloned (to avoid memory leaks) and
|
|
|
|
** may be modified according to the needs of the player.
|
|
|
|
** Implementors may use the 'sfx_iterator_combine()' function
|
|
|
|
** to add iterators onto their already existing iterators
|
|
|
|
*/
|
|
|
|
|
2009-05-26 11:49:10 +00:00
|
|
|
virtual Common::Error stop() = 0;
|
2009-02-15 06:10:59 +00:00
|
|
|
/* Stops the currently playing song and deletes the associated iterator
|
2009-05-12 23:31:55 +00:00
|
|
|
** Returns : (int) Common::kNoError on success, Common::kUnknownError on failure
|
2009-02-15 06:10:59 +00:00
|
|
|
*/
|
|
|
|
|
2009-05-26 11:49:10 +00:00
|
|
|
virtual Common::Error iterator_message(const SongIterator::Message &msg) = 0;
|
2009-02-15 06:10:59 +00:00
|
|
|
/* Transmits a song iterator message to the active song
|
2009-03-10 02:42:22 +00:00
|
|
|
** Parameters: (SongIterator::Message) msg: The message to transmit
|
2009-05-12 23:31:55 +00:00
|
|
|
** Returns : (int) Common::kNoError on success, Common::kUnknownError on failure
|
2009-02-15 06:10:59 +00:00
|
|
|
** OPTIONAL -- may be NULL
|
|
|
|
** If this method is not present, sending messages will stop
|
|
|
|
** and re-start playing, so it is preferred that it is present
|
|
|
|
*/
|
|
|
|
|
2009-05-26 11:49:10 +00:00
|
|
|
virtual Common::Error pause() = 0;
|
2009-02-15 06:10:59 +00:00
|
|
|
/* Pauses song playing
|
2009-05-12 23:31:55 +00:00
|
|
|
** Returns : (int) Common::kNoError on success, Common::kUnknownError on failure
|
2009-02-15 06:10:59 +00:00
|
|
|
*/
|
|
|
|
|
2009-05-26 11:49:10 +00:00
|
|
|
virtual Common::Error resume() = 0;
|
2009-02-15 06:10:59 +00:00
|
|
|
/* Resumes song playing after a pause
|
2009-05-12 23:31:55 +00:00
|
|
|
** Returns : (int) Common::kNoError on success, Common::kUnknownError on failure
|
2009-02-15 06:10:59 +00:00
|
|
|
*/
|
|
|
|
|
2009-05-26 11:49:10 +00:00
|
|
|
virtual Common::Error exit() = 0;
|
2009-02-15 06:10:59 +00:00
|
|
|
/* Stops the player
|
2009-05-12 23:31:55 +00:00
|
|
|
** Returns : (int) Common::kNoError on success, Common::kUnknownError on failure
|
2009-02-15 06:10:59 +00:00
|
|
|
*/
|
|
|
|
|
2009-05-26 11:49:10 +00:00
|
|
|
virtual void maintenance() {}
|
2009-02-15 06:10:59 +00:00
|
|
|
/* Regularly called maintenance function
|
|
|
|
** This function is called frequently and regularly (if present), it can be
|
|
|
|
** used to emit sound.
|
|
|
|
*/
|
|
|
|
|
2009-05-26 11:49:10 +00:00
|
|
|
virtual void tell_synth(int buf_nr, byte *buf) = 0;
|
2009-02-15 22:32:57 +00:00
|
|
|
/* Pass a raw MIDI event to the synth
|
|
|
|
Parameters: (int) argc: Length of buffer holding the midi event
|
|
|
|
(byte *) argv: The buffer itself
|
2009-02-15 06:10:59 +00:00
|
|
|
*/
|
2009-02-21 22:06:42 +00:00
|
|
|
};
|
2009-02-15 06:10:59 +00:00
|
|
|
|
2009-02-21 17:29:03 +00:00
|
|
|
int sfx_get_player_polyphony();
|
2009-02-15 06:10:59 +00:00
|
|
|
/* Determines the polyphony of the player in use
|
|
|
|
** Returns : (int) Number of voices the active player can emit
|
|
|
|
*/
|
|
|
|
|
2009-02-21 17:29:03 +00:00
|
|
|
void sfx_reset_player();
|
2009-02-15 06:10:59 +00:00
|
|
|
/* Tells the player to stop its internal iterator
|
|
|
|
** Parameters: None.
|
|
|
|
** Returns: Nothing.
|
|
|
|
*/
|
|
|
|
|
2009-03-06 07:25:06 +00:00
|
|
|
SongIterator *sfx_iterator_combine(SongIterator *it1, SongIterator *it2);
|
2009-02-15 06:10:59 +00:00
|
|
|
/* Combines two song iterators into one
|
|
|
|
** Parameters: (sfx_iterator_t *) it1: One of the two iterators, or NULL
|
|
|
|
** (sfx_iterator_t *) it2: The other iterator, or NULL
|
|
|
|
** Returns : (sfx_iterator_t *) A combined iterator
|
|
|
|
** If a combined iterator is returned, it will be flagged to be allowed to
|
|
|
|
** dispose of 'it1' and 'it2', where applicable. This means that this
|
|
|
|
** call should be used by song players, but not by the core sound system
|
|
|
|
*/
|
|
|
|
|
2009-02-21 10:23:36 +00:00
|
|
|
} // End of namespace Sci
|
|
|
|
|
2009-02-24 15:33:40 +00:00
|
|
|
#endif // SCI_SFX_SFX_PLAYER_H
|