Make per-material sounds always positional
git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/main/trunk@8428 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
parent
4229c14341
commit
16158e434f
@ -85,17 +85,19 @@ public:
|
|||||||
void unload();
|
void unload();
|
||||||
|
|
||||||
/** \return whether this buffer was loaded from disk */
|
/** \return whether this buffer was loaded from disk */
|
||||||
bool isLoaded() const { return m_loaded; }
|
bool isLoaded() const { return m_loaded; }
|
||||||
|
|
||||||
/** Only returns a valid buffer if isLoaded() returned true */
|
/** Only returns a valid buffer if isLoaded() returned true */
|
||||||
ALuint getBuffer() const { return m_buffer; }
|
ALuint getBuffer() const { return m_buffer; }
|
||||||
|
|
||||||
bool isPositional() const { return m_positional; }
|
|
||||||
float getRolloff() const { return m_rolloff; }
|
|
||||||
float getGain() const { return m_gain; }
|
|
||||||
|
|
||||||
|
bool isPositional() const { return m_positional; }
|
||||||
|
float getRolloff() const { return m_rolloff; }
|
||||||
|
float getGain() const { return m_gain; }
|
||||||
std::string getFileName() const { return m_file; }
|
std::string getFileName() const { return m_file; }
|
||||||
|
|
||||||
|
void setPositional(bool positional) { m_positional = positional; }
|
||||||
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -178,11 +178,11 @@ void SFXManager::loadSfx()
|
|||||||
* \return whether loading this sound effect was successful
|
* \return whether loading this sound effect was successful
|
||||||
|
|
||||||
*/
|
*/
|
||||||
bool SFXManager::addSingleSfx(const std::string &sfx_name,
|
SFXBuffer* SFXManager::addSingleSfx(const std::string &sfx_name,
|
||||||
const std::string &sfx_file,
|
const std::string &sfx_file,
|
||||||
bool positional,
|
bool positional,
|
||||||
float rolloff,
|
float rolloff,
|
||||||
float gain)
|
float gain)
|
||||||
{
|
{
|
||||||
|
|
||||||
SFXBuffer* buffer = new SFXBuffer(sfx_file, positional, rolloff, gain);
|
SFXBuffer* buffer = new SFXBuffer(sfx_file, positional, rolloff, gain);
|
||||||
@ -193,22 +193,23 @@ bool SFXManager::addSingleSfx(const std::string &sfx_name,
|
|||||||
{
|
{
|
||||||
// Keep the buffer even if SFX is disabled, in case
|
// Keep the buffer even if SFX is disabled, in case
|
||||||
// SFX is enabled back later
|
// SFX is enabled back later
|
||||||
return false;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (UserConfigParams::m_verbosity>=5)
|
if (UserConfigParams::m_verbosity>=5)
|
||||||
printf("Loading SFX %s\n", sfx_file.c_str());
|
printf("Loading SFX %s\n", sfx_file.c_str());
|
||||||
|
|
||||||
return buffer->load();
|
if (buffer->load()) return buffer;
|
||||||
|
|
||||||
|
return NULL;
|
||||||
} // addSingleSFX
|
} // addSingleSFX
|
||||||
|
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
/** Loads a single sfx from the XML specification.
|
/** Loads a single sfx from the XML specification.
|
||||||
* \param node The XML node with the data for this sfx.
|
* \param node The XML node with the data for this sfx.
|
||||||
*/
|
*/
|
||||||
void SFXManager::loadSingleSfx(const XMLNode* node,
|
SFXBuffer* SFXManager::loadSingleSfx(const XMLNode* node,
|
||||||
const std::string &path)
|
const std::string &path)
|
||||||
{
|
{
|
||||||
std::string filename;
|
std::string filename;
|
||||||
|
|
||||||
@ -216,7 +217,7 @@ void SFXManager::loadSingleSfx(const XMLNode* node,
|
|||||||
{
|
{
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"/!\\ The 'filename' attribute is mandatory in the SFX XML file!\n");
|
"/!\\ The 'filename' attribute is mandatory in the SFX XML file!\n");
|
||||||
return;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string sfx_name = StringUtils::removeExtension(filename);
|
std::string sfx_name = StringUtils::removeExtension(filename);
|
||||||
@ -233,7 +234,7 @@ void SFXManager::loadSingleSfx(const XMLNode* node,
|
|||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"There is already a sfx named '%s' installed - new one is ignored.\n",
|
"There is already a sfx named '%s' installed - new one is ignored.\n",
|
||||||
sfx_name.c_str());
|
sfx_name.c_str());
|
||||||
return;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Only use the filename if no full path is specified. This is used
|
// Only use the filename if no full path is specified. This is used
|
||||||
@ -243,10 +244,10 @@ void SFXManager::loadSingleSfx(const XMLNode* node,
|
|||||||
|
|
||||||
SFXBuffer tmpbuffer(full_path, node);
|
SFXBuffer tmpbuffer(full_path, node);
|
||||||
|
|
||||||
addSingleSfx(sfx_name, full_path,
|
return addSingleSfx(sfx_name, full_path,
|
||||||
tmpbuffer.isPositional(),
|
tmpbuffer.isPositional(),
|
||||||
tmpbuffer.getRolloff(),
|
tmpbuffer.getRolloff(),
|
||||||
tmpbuffer.getGain());
|
tmpbuffer.getGain());
|
||||||
|
|
||||||
} // loadSingleSfx
|
} // loadSingleSfx
|
||||||
|
|
||||||
|
@ -100,9 +100,9 @@ public:
|
|||||||
SFXManager();
|
SFXManager();
|
||||||
virtual ~SFXManager();
|
virtual ~SFXManager();
|
||||||
bool sfxAllowed();
|
bool sfxAllowed();
|
||||||
void loadSingleSfx(const XMLNode* node,
|
SFXBuffer* loadSingleSfx(const XMLNode* node,
|
||||||
const std::string &path=std::string(""));
|
const std::string &path=std::string(""));
|
||||||
bool addSingleSfx(const std::string &sfx_name,
|
SFXBuffer* addSingleSfx(const std::string &sfx_name,
|
||||||
const std::string &filename,
|
const std::string &filename,
|
||||||
bool positional,
|
bool positional,
|
||||||
float rolloff,
|
float rolloff,
|
||||||
|
@ -23,6 +23,7 @@
|
|||||||
#include <stdexcept>
|
#include <stdexcept>
|
||||||
|
|
||||||
#include "audio/sfx_base.hpp"
|
#include "audio/sfx_base.hpp"
|
||||||
|
#include "audio/sfx_buffer.hpp"
|
||||||
#include "config/user_config.hpp"
|
#include "config/user_config.hpp"
|
||||||
#include "config/stk_config.hpp"
|
#include "config/stk_config.hpp"
|
||||||
#include "graphics/irr_driver.hpp"
|
#include "graphics/irr_driver.hpp"
|
||||||
@ -312,7 +313,12 @@ void Material::initCustomSFX(const XMLNode *sfx)
|
|||||||
// The directory for the track was added to the model search path
|
// The directory for the track was added to the model search path
|
||||||
// so just misuse the getModelFile function
|
// so just misuse the getModelFile function
|
||||||
const std::string full_path = file_manager->getModelFile(filename);
|
const std::string full_path = file_manager->getModelFile(filename);
|
||||||
sfx_manager->loadSingleSfx(sfx, full_path);
|
SFXBuffer* buffer = sfx_manager->loadSingleSfx(sfx, full_path);
|
||||||
|
|
||||||
|
if (buffer != NULL)
|
||||||
|
{
|
||||||
|
buffer->setPositional(true);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} // initCustomSFX
|
} // initCustomSFX
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user