2009-01-29 00:18:34 +08:00
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// SFML - Simple and Fast Multimedia Library
|
2009-02-13 01:48:35 +08:00
|
|
|
// Copyright (C) 2007-2009 Laurent Gomila (laurent.gom@gmail.com)
|
2009-01-29 00:18:34 +08:00
|
|
|
//
|
|
|
|
// This software is provided 'as-is', without any express or implied warranty.
|
|
|
|
// In no event will the authors be held liable for any damages arising from the use of this software.
|
|
|
|
//
|
|
|
|
// Permission is granted to anyone to use this software for any purpose,
|
|
|
|
// including commercial applications, and to alter it and redistribute it freely,
|
|
|
|
// subject to the following restrictions:
|
|
|
|
//
|
|
|
|
// 1. The origin of this software must not be misrepresented;
|
|
|
|
// you must not claim that you wrote the original software.
|
|
|
|
// If you use this software in a product, an acknowledgment
|
|
|
|
// in the product documentation would be appreciated but is not required.
|
|
|
|
//
|
|
|
|
// 2. Altered source versions must be plainly marked as such,
|
|
|
|
// and must not be misrepresented as being the original software.
|
|
|
|
//
|
|
|
|
// 3. This notice may not be removed or altered from any source distribution.
|
|
|
|
//
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef SFML_SOUNDBUFFER_HPP
|
|
|
|
#define SFML_SOUNDBUFFER_HPP
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
// Headers
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-07-12 06:17:24 +08:00
|
|
|
#include <SFML/Config.hpp>
|
2009-01-29 00:18:34 +08:00
|
|
|
#include <SFML/System/Resource.hpp>
|
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
|
|
|
|
namespace sf
|
|
|
|
{
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
/// SoundBuffer is the low-level for loading and manipulating
|
|
|
|
/// sound buffers
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-07-12 06:17:24 +08:00
|
|
|
class SFML_API SoundBuffer : public Resource<SoundBuffer>
|
2009-01-29 00:18:34 +08:00
|
|
|
{
|
|
|
|
public :
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
/// Default constructor
|
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
SoundBuffer();
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
/// Copy constructor
|
|
|
|
///
|
2009-07-12 06:17:24 +08:00
|
|
|
/// \param copy : Instance to copy
|
2009-01-29 00:18:34 +08:00
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-07-12 06:17:24 +08:00
|
|
|
SoundBuffer(const SoundBuffer& copy);
|
2009-01-29 00:18:34 +08:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
/// Destructor
|
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
~SoundBuffer();
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
/// Load the sound buffer from a file
|
|
|
|
///
|
2009-07-12 06:17:24 +08:00
|
|
|
/// \param filename : Path of the sound file to load
|
2009-01-29 00:18:34 +08:00
|
|
|
///
|
|
|
|
/// \return True if loading has been successful
|
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-07-12 06:17:24 +08:00
|
|
|
bool LoadFromFile(const std::string& filename);
|
2009-01-29 00:18:34 +08:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
/// Load the sound buffer from a file in memory
|
|
|
|
///
|
2009-07-12 06:17:24 +08:00
|
|
|
/// \param data : Pointer to the file data in memory
|
|
|
|
/// \param sizeInBytes : Size of the data to load, in bytes
|
2009-01-29 00:18:34 +08:00
|
|
|
///
|
|
|
|
/// \return True if loading has been successful
|
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-07-12 06:17:24 +08:00
|
|
|
bool LoadFromMemory(const char* data, std::size_t sizeInBytes);
|
2009-01-29 00:18:34 +08:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
/// Load the sound buffer from an array of samples - assumed format for
|
|
|
|
/// samples is 16 bits signed integer
|
|
|
|
///
|
2009-07-12 06:17:24 +08:00
|
|
|
/// \param samples : Pointer to the samples in memory
|
|
|
|
/// \param samplesCount : Number of samples pointed by Samples
|
|
|
|
/// \param channelsCount : Number of channels (1 = mono, 2 = stereo, ...)
|
|
|
|
/// \param sampleRate : Frequency (number of samples to play per second)
|
2009-01-29 00:18:34 +08:00
|
|
|
///
|
|
|
|
/// \return True if loading has been successful
|
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-07-12 06:17:24 +08:00
|
|
|
bool LoadFromSamples(const Int16* samples, std::size_t samplesCount, unsigned int channelsCount, unsigned int sampleRate);
|
2009-01-29 00:18:34 +08:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
/// Save the sound buffer to a file
|
|
|
|
///
|
2009-07-12 06:17:24 +08:00
|
|
|
/// \param filename : Path of the sound file to write
|
2009-01-29 00:18:34 +08:00
|
|
|
///
|
|
|
|
/// \return True if saving has been successful
|
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-07-12 06:17:24 +08:00
|
|
|
bool SaveToFile(const std::string& filename) const;
|
2009-01-29 00:18:34 +08:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
/// Return the sound samples
|
|
|
|
///
|
|
|
|
/// \return Pointer to the array of sound samples, in 16 bits signed integer format
|
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
const Int16* GetSamples() const;
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
/// Return the samples count
|
|
|
|
///
|
|
|
|
/// \return Number of samples
|
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
std::size_t GetSamplesCount() const;
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
/// Get the sample rate
|
|
|
|
///
|
|
|
|
/// \return Sound frequency (number of samples per second)
|
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
unsigned int GetSampleRate() const;
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
/// Return the number of channels (1 = mono, 2 = stereo, ...)
|
|
|
|
///
|
|
|
|
/// \return Number of channels
|
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
unsigned int GetChannelsCount() const;
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
/// Get the sound duration
|
|
|
|
///
|
|
|
|
/// \return Sound duration, in seconds
|
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
float GetDuration() const;
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
/// Assignment operator
|
|
|
|
///
|
2009-07-12 06:17:24 +08:00
|
|
|
/// \param other : Instance to assign
|
2009-01-29 00:18:34 +08:00
|
|
|
///
|
|
|
|
/// \return Reference to the sound buffer
|
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-07-12 06:17:24 +08:00
|
|
|
SoundBuffer& operator =(const SoundBuffer& other);
|
2009-01-29 00:18:34 +08:00
|
|
|
|
|
|
|
private :
|
|
|
|
|
|
|
|
friend class Sound;
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
/// Update the internal buffer with the audio samples
|
|
|
|
///
|
2009-07-12 06:17:24 +08:00
|
|
|
/// \param channelsCount : Number of channels
|
|
|
|
/// \param sampleRate : Sample rate
|
2009-01-29 00:18:34 +08:00
|
|
|
///
|
|
|
|
/// \return True on success
|
|
|
|
///
|
|
|
|
////////////////////////////////////////////////////////////
|
2009-07-12 06:17:24 +08:00
|
|
|
bool Update(unsigned int channelsCount, unsigned int sampleRate);
|
2009-01-29 00:18:34 +08:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
// Member data
|
|
|
|
////////////////////////////////////////////////////////////
|
|
|
|
unsigned int myBuffer; ///< OpenAL buffer identifier
|
|
|
|
std::vector<Int16> mySamples; ///< Samples buffer
|
|
|
|
float myDuration; ///< Sound duration, in seconds
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace sf
|
|
|
|
|
|
|
|
|
|
|
|
#endif // SFML_SOUNDBUFFER_HPP
|