Handle UI modes open/close sounds in Lua

macos_ci_fix
Petr Mikheev 1 year ago
parent 36d22cff1c
commit c5ba289bc7

@ -119,9 +119,9 @@ namespace MWBase
virtual void pushGuiMode(MWGui::GuiMode mode, const MWWorld::Ptr& arg) = 0; virtual void pushGuiMode(MWGui::GuiMode mode, const MWWorld::Ptr& arg) = 0;
virtual void pushGuiMode(MWGui::GuiMode mode) = 0; virtual void pushGuiMode(MWGui::GuiMode mode) = 0;
virtual void popGuiMode(bool noSound = false) = 0; virtual void popGuiMode() = 0;
virtual void removeGuiMode(MWGui::GuiMode mode, bool noSound = false) = 0; virtual void removeGuiMode(MWGui::GuiMode mode) = 0;
///< can be anywhere in the stack ///< can be anywhere in the stack
virtual void goToJail(int days) = 0; virtual void goToJail(int days) = 0;

@ -107,6 +107,6 @@ namespace MWGui
MWWorld::ActionTake take(mScroll); MWWorld::ActionTake take(mScroll);
take.execute(MWMechanics::getPlayer()); take.execute(MWMechanics::getPlayer());
MWBase::Environment::get().getWindowManager()->removeGuiMode(GM_Scroll, true); MWBase::Environment::get().getWindowManager()->removeGuiMode(GM_Scroll);
} }
} }

@ -360,8 +360,6 @@ namespace MWGui
bool questList = mResourceSystem->getVFS()->exists("textures/tx_menubook_options_over.dds"); bool questList = mResourceSystem->getVFS()->exists("textures/tx_menubook_options_over.dds");
auto journal = JournalWindow::create(JournalViewModel::create(), questList, mEncoding); auto journal = JournalWindow::create(JournalViewModel::create(), questList, mEncoding);
mGuiModeStates[GM_Journal] = GuiModeState(journal.get()); mGuiModeStates[GM_Journal] = GuiModeState(journal.get());
mGuiModeStates[GM_Journal].mCloseSound = ESM::RefId::stringRefId("book close");
mGuiModeStates[GM_Journal].mOpenSound = ESM::RefId::stringRefId("book open");
mWindows.push_back(std::move(journal)); mWindows.push_back(std::move(journal));
mMessageBoxManager = std::make_unique<MessageBoxManager>( mMessageBoxManager = std::make_unique<MessageBoxManager>(
@ -398,15 +396,11 @@ namespace MWGui
mScrollWindow = scrollWindow.get(); mScrollWindow = scrollWindow.get();
mWindows.push_back(std::move(scrollWindow)); mWindows.push_back(std::move(scrollWindow));
mGuiModeStates[GM_Scroll] = GuiModeState(mScrollWindow); mGuiModeStates[GM_Scroll] = GuiModeState(mScrollWindow);
mGuiModeStates[GM_Scroll].mOpenSound = ESM::RefId::stringRefId("scroll");
mGuiModeStates[GM_Scroll].mCloseSound = ESM::RefId::stringRefId("scroll");
auto bookWindow = std::make_unique<BookWindow>(); auto bookWindow = std::make_unique<BookWindow>();
mBookWindow = bookWindow.get(); mBookWindow = bookWindow.get();
mWindows.push_back(std::move(bookWindow)); mWindows.push_back(std::move(bookWindow));
mGuiModeStates[GM_Book] = GuiModeState(mBookWindow); mGuiModeStates[GM_Book] = GuiModeState(mBookWindow);
mGuiModeStates[GM_Book].mOpenSound = ESM::RefId::stringRefId("book open");
mGuiModeStates[GM_Book].mCloseSound = ESM::RefId::stringRefId("book close");
auto countDialog = std::make_unique<CountDialog>(); auto countDialog = std::make_unique<CountDialog>();
mCountDialog = countDialog.get(); mCountDialog = countDialog.get();
@ -1274,7 +1268,6 @@ namespace MWGui
mGuiModes.push_back(mode); mGuiModes.push_back(mode);
mGuiModeStates[mode].update(true); mGuiModeStates[mode].update(true);
playSound(mGuiModeStates[mode].mOpenSound);
} }
if (force) if (force)
mContainerWindow->treatNextOpenAsLoot(); mContainerWindow->treatNextOpenAsLoot();
@ -1311,7 +1304,7 @@ namespace MWGui
return mViewer->getCamera()->getCullMask(); return mViewer->getCamera()->getCullMask();
} }
void WindowManager::popGuiMode(bool noSound) void WindowManager::popGuiMode()
{ {
if (mDragAndDrop && mDragAndDrop->mIsOnDragAndDrop) if (mDragAndDrop && mDragAndDrop->mIsOnDragAndDrop)
{ {
@ -1324,8 +1317,6 @@ namespace MWGui
mKeyboardNavigation->saveFocus(mode); mKeyboardNavigation->saveFocus(mode);
mGuiModes.pop_back(); mGuiModes.pop_back();
mGuiModeStates[mode].update(false); mGuiModeStates[mode].update(false);
if (!noSound)
playSound(mGuiModeStates[mode].mCloseSound);
MWBase::Environment::get().getLuaManager()->uiModeChanged(MWWorld::Ptr()); MWBase::Environment::get().getLuaManager()->uiModeChanged(MWWorld::Ptr());
} }
@ -1343,11 +1334,11 @@ namespace MWGui
mConsole->onOpen(); mConsole->onOpen();
} }
void WindowManager::removeGuiMode(GuiMode mode, bool noSound) void WindowManager::removeGuiMode(GuiMode mode)
{ {
if (!mGuiModes.empty() && mGuiModes.back() == mode) if (!mGuiModes.empty() && mGuiModes.back() == mode)
{ {
popGuiMode(noSound); popGuiMode();
return; return;
} }

@ -149,8 +149,8 @@ namespace MWGui
void pushGuiMode(GuiMode mode, const MWWorld::Ptr& arg) override; void pushGuiMode(GuiMode mode, const MWWorld::Ptr& arg) override;
void pushGuiMode(GuiMode mode) override; void pushGuiMode(GuiMode mode) override;
void popGuiMode(bool noSound = false) override; void popGuiMode() override;
void removeGuiMode(GuiMode mode, bool noSound = false) override; ///< can be anywhere in the stack void removeGuiMode(GuiMode mode) override; ///< can be anywhere in the stack
void goToJail(int days) override; void goToJail(int days) override;
@ -488,9 +488,6 @@ namespace MWGui
void update(bool visible); void update(bool visible);
std::vector<WindowBase*> mWindows; std::vector<WindowBase*> mWindows;
ESM::RefId mCloseSound;
ESM::RefId mOpenSound;
}; };
// Defines the windows that should be shown in a particular GUI mode. // Defines the windows that should be shown in a particular GUI mode.
std::map<GuiMode, GuiModeState> mGuiModeStates; std::map<GuiMode, GuiModeState> mGuiModeStates;

@ -17,13 +17,13 @@ Examples:
UI events UI events
--------- ---------
Every time UI mode is changed built-in scripts send to player the event ``UiModeChanged`` with arguments ``mode`` (same as ``I.UI.getMode()``) Every time UI mode is changed built-in scripts send to player the event ``UiModeChanged`` with arguments ``oldMode, ``newMode`` (same as ``I.UI.getMode()``)
and ``arg`` (for example in the mode ``Book`` the argument is the book the player is reading). and ``arg`` (for example in the mode ``Book`` the argument is the book the player is reading).
.. code-block:: Lua .. code-block:: Lua
eventHandlers = { eventHandlers = {
UiModeChanged = function(data) UiModeChanged = function(data)
print('UiModeChanged to', data.mode, '('..tostring(data.arg)..')') print('UiModeChanged from', data.oldMode , 'to', data.newMode, '('..tostring(data.arg)..')')
end end
} }

@ -1,6 +1,7 @@
local ui = require('openmw.ui') local ui = require('openmw.ui')
local util = require('openmw.util') local util = require('openmw.util')
local self = require('openmw.self') local self = require('openmw.self')
local ambient = require('openmw.ambient')
local MODE = ui._getAllUiModes() local MODE = ui._getAllUiModes()
local WINDOW = ui._getAllWindowIds() local WINDOW = ui._getAllWindowIds()
@ -91,6 +92,7 @@ local function removeMode(mode)
end end
end end
local oldMode = nil
local function onUiModeChanged(arg) local function onUiModeChanged(arg)
local newStack = ui._getUiModeStack() local newStack = ui._getUiModeStack()
for i = 1, math.max(#modeStack, #newStack) do for i = 1, math.max(#modeStack, #newStack) do
@ -112,7 +114,27 @@ local function onUiModeChanged(arg)
end end
end end
end end
self:sendEvent('UiModeChanged', {mode = mode, arg = arg}) self:sendEvent('UiModeChanged', {oldMode = oldMode, newMode = mode, arg = arg})
oldMode = mode
end
local function onUiModeChangedEvent(data)
if data.oldMode == data.newMode then
return
end
-- Sounds are processed in the event handler rather than in engine handler
-- in order to allow them to be overridden in mods.
if data.newMode == MODE.Journal or data.newMode == MODE.Book then
ambient.playSound('book open', {scale = false})
elseif data.oldMode == MODE.Journal or data.oldMode == MODE.Book then
if not ambient.isSoundPlaying('item book up') then
ambient.playSound('book close', {scale = false})
end
elseif data.newMode == MODE.Scroll or data.oldMode == MODE.Scroll then
if not ambient.isSoundPlaying('item book up') then
ambient.playSound('scroll', {scale = false})
end
end
end end
return { return {
@ -192,4 +214,7 @@ return {
engineHandlers = { engineHandlers = {
_onUiModeChanged = onUiModeChanged, _onUiModeChanged = onUiModeChanged,
}, },
eventHandlers = {
UiModeChanged = onUiModeChangedEvent,
},
} }

Loading…
Cancel
Save