From 004541f5cf0d398bf1193662e7aa9c0941bc1b85 Mon Sep 17 00:00:00 2001 From: Nicolay Korslund Date: Tue, 14 Sep 2010 13:27:20 +0200 Subject: [PATCH 1/3] Tested and applied Chris' sound patch. --- apps/openmw/mwsound/soundmanager.cpp | 44 +++++++++++++++++++--------- libs/mangle | 2 +- 2 files changed, 31 insertions(+), 15 deletions(-) diff --git a/apps/openmw/mwsound/soundmanager.cpp b/apps/openmw/mwsound/soundmanager.cpp index 2bac0da591..88f62e112f 100644 --- a/apps/openmw/mwsound/soundmanager.cpp +++ b/apps/openmw/mwsound/soundmanager.cpp @@ -110,20 +110,21 @@ namespace MWSound cameraTracker.unfollowCamera(); } - std::string toMp3(const std::string &str) + static std::string toMp3(std::string str) { - std::string wav = str; - int i = str.size()-3; - wav[i++] = 'm'; - wav[i++] = 'p'; - wav[i++] = '3'; - return wav; + std::string::size_type i = str.rfind('.'); + if(str.find('/', i) == std::string::npos && + str.find('\\', i) == std::string::npos) + str = str.substr(0, i) + ".mp3"; + else + str += ".mp3"; + return str; } bool hasFile(const std::string &str) { if(files.has(str)) return true; - // Not found? Try exchanging .wav with .mp3 + // Not found? Try with .mp3 return files.has(toMp3(str)); } @@ -153,10 +154,24 @@ namespace MWSound const ESM::Sound *snd = store.sounds.search(soundId); if(snd == NULL) return ""; - volume *= snd->data.volume / 255.0f; - // These factors are not very fine tuned. - min = snd->data.minRange * 7.0f; - max = snd->data.maxRange * 2000.0f; + if(snd->data.volume == 0) + volume = 0.0f; + else + volume *= pow(10.0, (snd->data.volume/255.0f*3348.0 - 3348.0) / 2000.0); + + if(snd->data.minRange == 0 && snd->data.maxRange == 0) + { + min = 100.0f; + max = 2000.0f; + } + else + { + min = snd->data.minRange * 20.0f; + max = snd->data.maxRange * 50.0f; + min = std::max(min, 1.0f); + max = std::max(min, max); + } + return convertPath(snd->sound); } @@ -309,7 +324,7 @@ namespace MWSound // The range values are not tested if(!mData) return; if(mData->hasFile(filename)) - mData->add(mData->convertPath(filename), ptr, "_say_sound", 1, 1, 100, 10000, false); + mData->add(mData->convertPath(filename), ptr, "_say_sound", 1, 1, 100, 20000, false); else cout << "Sound file " << filename << " not found, skipping.\n"; } @@ -342,10 +357,11 @@ namespace MWSound const std::string &file = mData->lookup(soundId, volume, min, max); if(file != "") { - SoundPtr snd = mData->mgr->play(file); + SoundPtr snd = mData->mgr->load(file); snd->setVolume(volume); snd->setRange(min,max); snd->setPitch(pitch); + snd->play(); } } diff --git a/libs/mangle b/libs/mangle index 7a22068da6..7345f2307f 160000 --- a/libs/mangle +++ b/libs/mangle @@ -1 +1 @@ -Subproject commit 7a22068da611235190fa7343ca3f8c1d1944a68c +Subproject commit 7345f2307f3ce6682a4044b98a811fac2cb7c4f0 From 4416e71a0acc17310dc690e88a49739264139ccf Mon Sep 17 00:00:00 2001 From: Jan Borsodi Date: Tue, 14 Sep 2010 12:29:26 +0200 Subject: [PATCH 2/3] Fix for linker warnings on windows, this makes sure headers of MyGUI does not use dllexport for windows as we are supposed to link statically to the library. --- CMakeLists.txt | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/CMakeLists.txt b/CMakeLists.txt index 742b562876..cb591089ed 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -225,6 +225,13 @@ link_directories(${Boost_LIBRARY_DIRS} ${OGRE_LIB_DIR}) add_subdirectory( extern/caelum ) add_subdirectory( extern/mygui_3.0.1 ) +# Make sure that certain libraries are used as static libraries +# This is in effect turns off __declspec (dllexport) for windows +# Each library will also need to be configured to build as a static lib + +# MyGUI: extern/mygui_3.0.0/ +add_definitions(-DMYGUI_STATIC) + # Specify build paths set(CMAKE_RUNTIME_OUTPUT_DIRECTORY "${OpenMW_BINARY_DIR}") From e34b86e5c2f36f94adf4fbcdd014990a87e1866c Mon Sep 17 00:00:00 2001 From: Jan Borsodi Date: Tue, 14 Sep 2010 12:34:02 +0200 Subject: [PATCH 3/3] Added new define CAELUM_STATIC which will disable all dllexport for the caelum project. Made sure the define is set for both openmw and caelum. --- CMakeLists.txt | 3 +++ extern/caelum/CMakeLists.txt | 2 +- extern/caelum/include/CaelumPrerequisites.h | 5 ++++- 3 files changed, 8 insertions(+), 2 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index cb591089ed..01ca185403 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -232,6 +232,9 @@ add_subdirectory( extern/mygui_3.0.1 ) # MyGUI: extern/mygui_3.0.0/ add_definitions(-DMYGUI_STATIC) +# Caelum: extern/caelum/ +add_definitions(-DCAELUM_STATIC) + # Specify build paths set(CMAKE_RUNTIME_OUTPUT_DIRECTORY "${OpenMW_BINARY_DIR}") diff --git a/extern/caelum/CMakeLists.txt b/extern/caelum/CMakeLists.txt index b95b3fd8c5..c1854904c7 100755 --- a/extern/caelum/CMakeLists.txt +++ b/extern/caelum/CMakeLists.txt @@ -4,7 +4,7 @@ IF(MSVC) add_definitions("-D_SCL_SECURE_NO_WARNINGS /wd4305 /wd4244" ) ENDIF(MSVC) -ADD_DEFINITIONS(-DCAELUM_LIB) +ADD_DEFINITIONS(-DCAELUM_STATIC) INCLUDE_DIRECTORIES( ${CMAKE_HOME_DIRECTORY}/extern/caelum/include ${OGRE_INCLUDE_DIR}/Ogre diff --git a/extern/caelum/include/CaelumPrerequisites.h b/extern/caelum/include/CaelumPrerequisites.h index 901901c2eb..093b3ab5a1 100644 --- a/extern/caelum/include/CaelumPrerequisites.h +++ b/extern/caelum/include/CaelumPrerequisites.h @@ -32,7 +32,10 @@ along with Caelum. If not, see . // Define the dll export qualifier if compiling for Windows #if OGRE_PLATFORM == OGRE_PLATFORM_WIN32 - #ifdef CAELUM_LIB + #ifdef CAELUM_STATIC + // Don't use dll export qualifier when built as a static lib + #define CAELUM_EXPORT + #elif CAELUM_LIB #define CAELUM_EXPORT __declspec (dllexport) #else #ifdef __MINGW32__