|
|
@ -124,6 +124,8 @@
|
|
|
|
#include "../mwvr/vrenvironment.hpp"
|
|
|
|
#include "../mwvr/vrenvironment.hpp"
|
|
|
|
#include "../mwvr/vrgui.hpp"
|
|
|
|
#include "../mwvr/vrgui.hpp"
|
|
|
|
#include "../mwvr/vrvirtualkeyboard.hpp"
|
|
|
|
#include "../mwvr/vrvirtualkeyboard.hpp"
|
|
|
|
|
|
|
|
#include "../mwvr/vrviewer.hpp"
|
|
|
|
|
|
|
|
#include "../mwvr/vrsession.hpp"
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
namespace MWGui
|
|
|
|
namespace MWGui
|
|
|
@ -770,11 +772,7 @@ namespace MWGui
|
|
|
|
if (!mWindowVisible)
|
|
|
|
if (!mWindowVisible)
|
|
|
|
std::this_thread::sleep_for(std::chrono::milliseconds(5));
|
|
|
|
std::this_thread::sleep_for(std::chrono::milliseconds(5));
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
viewerTraversals(false);
|
|
|
|
mViewer->eventTraversal();
|
|
|
|
|
|
|
|
mViewer->updateTraversal();
|
|
|
|
|
|
|
|
mViewer->renderingTraversals();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
// at the time this function is called we are in the middle of a frame,
|
|
|
|
// at the time this function is called we are in the middle of a frame,
|
|
|
|
// so out of order calls are necessary to get a correct frameNumber for the next frame.
|
|
|
|
// so out of order calls are necessary to get a correct frameNumber for the next frame.
|
|
|
|
// refer to the advance() and frame() order in Engine::go()
|
|
|
|
// refer to the advance() and frame() order in Engine::go()
|
|
|
@ -1829,9 +1827,7 @@ namespace MWGui
|
|
|
|
if (mVideoWidget->isPaused())
|
|
|
|
if (mVideoWidget->isPaused())
|
|
|
|
mVideoWidget->resume();
|
|
|
|
mVideoWidget->resume();
|
|
|
|
|
|
|
|
|
|
|
|
mViewer->eventTraversal();
|
|
|
|
viewerTraversals(false);
|
|
|
|
mViewer->updateTraversal();
|
|
|
|
|
|
|
|
mViewer->renderingTraversals();
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// at the time this function is called we are in the middle of a frame,
|
|
|
|
// at the time this function is called we are in the middle of a frame,
|
|
|
|
// so out of order calls are necessary to get a correct frameNumber for the next frame.
|
|
|
|
// so out of order calls are necessary to get a correct frameNumber for the next frame.
|
|
|
@ -2248,6 +2244,25 @@ namespace MWGui
|
|
|
|
return MyGUI::InputManager::getInstance().injectKeyRelease(key);
|
|
|
|
return MyGUI::InputManager::getInstance().injectKeyRelease(key);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void WindowManager::viewerTraversals(bool updateWindowManager)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
#ifdef USE_OPENXR
|
|
|
|
|
|
|
|
if (MWBase::Environment::get().getVrMode())
|
|
|
|
|
|
|
|
MWVR::Environment::get().getSession()->beginFrame();
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
mViewer->eventTraversal();
|
|
|
|
|
|
|
|
mViewer->updateTraversal();
|
|
|
|
|
|
|
|
if (updateWindowManager)
|
|
|
|
|
|
|
|
MWBase::Environment::get().getWorld()->updateWindowManager();
|
|
|
|
|
|
|
|
mViewer->renderingTraversals();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef USE_OPENXR
|
|
|
|
|
|
|
|
if (MWBase::Environment::get().getVrMode())
|
|
|
|
|
|
|
|
MWVR::Environment::get().getSession()->endFrame();
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void WindowManager::GuiModeState::update(bool visible)
|
|
|
|
void WindowManager::GuiModeState::update(bool visible)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
for (unsigned int i=0; i<mWindows.size(); ++i)
|
|
|
|
for (unsigned int i=0; i<mWindows.size(); ++i)
|
|
|
|