2015-02-07 03:05:28 +00:00
|
|
|
#include <MyGUI_ScrollBar.h>
|
|
|
|
|
2017-07-03 12:45:21 +00:00
|
|
|
/*
|
|
|
|
Start of tes3mp addition
|
|
|
|
|
|
|
|
Include additional headers for multiplayer purposes
|
|
|
|
*/
|
|
|
|
#include "../mwmp/Main.hpp"
|
|
|
|
#include "../mwmp/LocalPlayer.hpp"
|
|
|
|
/*
|
|
|
|
End of tes3mp addition
|
|
|
|
*/
|
|
|
|
|
2015-04-22 15:58:55 +00:00
|
|
|
#include <components/misc/rng.hpp>
|
2015-03-15 01:07:47 +00:00
|
|
|
|
2015-02-07 03:05:28 +00:00
|
|
|
#include "../mwbase/windowmanager.hpp"
|
|
|
|
#include "../mwbase/mechanicsmanager.hpp"
|
|
|
|
#include "../mwbase/world.hpp"
|
|
|
|
#include "../mwbase/environment.hpp"
|
|
|
|
|
|
|
|
#include "../mwmechanics/npcstats.hpp"
|
2015-08-21 09:12:39 +00:00
|
|
|
#include "../mwmechanics/actorutil.hpp"
|
2015-02-07 03:05:28 +00:00
|
|
|
|
|
|
|
#include "../mwworld/esmstore.hpp"
|
|
|
|
#include "../mwworld/store.hpp"
|
|
|
|
#include "../mwworld/class.hpp"
|
|
|
|
|
|
|
|
#include "jailscreen.hpp"
|
|
|
|
|
|
|
|
namespace MWGui
|
|
|
|
{
|
|
|
|
JailScreen::JailScreen()
|
2015-02-07 17:38:41 +00:00
|
|
|
: WindowBase("openmw_jail_screen.layout"),
|
2015-02-07 03:05:28 +00:00
|
|
|
mDays(1),
|
2015-05-01 00:24:27 +00:00
|
|
|
mFadeTimeRemaining(0),
|
|
|
|
mTimeAdvancer(0.01f)
|
2015-02-07 03:05:28 +00:00
|
|
|
{
|
|
|
|
getWidget(mProgressBar, "ProgressBar");
|
|
|
|
|
|
|
|
setVisible(false);
|
|
|
|
|
|
|
|
mTimeAdvancer.eventProgressChanged += MyGUI::newDelegate(this, &JailScreen::onJailProgressChanged);
|
|
|
|
mTimeAdvancer.eventFinished += MyGUI::newDelegate(this, &JailScreen::onJailFinished);
|
|
|
|
|
|
|
|
center();
|
|
|
|
}
|
|
|
|
|
|
|
|
void JailScreen::goToJail(int days)
|
|
|
|
{
|
|
|
|
mDays = days;
|
|
|
|
|
|
|
|
MWBase::Environment::get().getWindowManager()->fadeScreenOut(0.5);
|
|
|
|
mFadeTimeRemaining = 0.5;
|
|
|
|
|
|
|
|
setVisible(false);
|
2015-02-22 23:23:09 +00:00
|
|
|
mProgressBar->setScrollRange(100+1);
|
2015-02-07 03:05:28 +00:00
|
|
|
mProgressBar->setScrollPosition(0);
|
|
|
|
mProgressBar->setTrackSize(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
void JailScreen::onFrame(float dt)
|
|
|
|
{
|
|
|
|
mTimeAdvancer.onFrame(dt);
|
|
|
|
|
|
|
|
if (mFadeTimeRemaining <= 0)
|
|
|
|
return;
|
|
|
|
|
|
|
|
mFadeTimeRemaining -= dt;
|
|
|
|
|
|
|
|
if (mFadeTimeRemaining <= 0)
|
|
|
|
{
|
2015-08-21 09:12:39 +00:00
|
|
|
MWWorld::Ptr player = MWMechanics::getPlayer();
|
2017-07-03 12:45:21 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
Start of tes3mp change (minor)
|
|
|
|
|
2017-07-11 10:34:09 +00:00
|
|
|
Prevent teleportation to jail if specified
|
2017-07-03 12:45:21 +00:00
|
|
|
*/
|
|
|
|
if (!mwmp::Main::get().getLocalPlayer()->ignoreJailTeleportation)
|
|
|
|
MWBase::Environment::get().getWorld()->teleportToClosestMarker(player, "prisonmarker");
|
|
|
|
/*
|
|
|
|
End of tes3mp change (minor)
|
|
|
|
*/
|
2015-02-07 03:05:28 +00:00
|
|
|
|
|
|
|
setVisible(true);
|
2015-02-22 23:23:09 +00:00
|
|
|
mTimeAdvancer.run(100);
|
2015-02-07 03:05:28 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void JailScreen::onJailProgressChanged(int cur, int /*total*/)
|
|
|
|
{
|
|
|
|
mProgressBar->setScrollPosition(0);
|
2015-03-08 00:07:29 +00:00
|
|
|
mProgressBar->setTrackSize(static_cast<int>(cur / (float)(mProgressBar->getScrollRange()) * mProgressBar->getLineSize()));
|
2015-02-07 03:05:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void JailScreen::onJailFinished()
|
|
|
|
{
|
2015-02-07 17:38:41 +00:00
|
|
|
MWBase::Environment::get().getWindowManager()->removeGuiMode(MWGui::GM_Jail);
|
2015-02-07 03:05:28 +00:00
|
|
|
MWBase::Environment::get().getWindowManager()->fadeScreenIn(0.5);
|
|
|
|
|
2015-08-21 09:12:39 +00:00
|
|
|
MWWorld::Ptr player = MWMechanics::getPlayer();
|
2015-02-07 03:05:28 +00:00
|
|
|
|
|
|
|
for (int i=0; i<mDays*24; ++i)
|
|
|
|
MWBase::Environment::get().getMechanicsManager()->rest(true);
|
2016-07-05 22:20:23 +00:00
|
|
|
MWBase::Environment::get().getWorld()->advanceTime(mDays * 24);
|
2015-02-07 03:05:28 +00:00
|
|
|
|
|
|
|
std::set<int> skills;
|
|
|
|
for (int day=0; day<mDays; ++day)
|
|
|
|
{
|
2015-04-22 15:58:55 +00:00
|
|
|
int skill = Misc::Rng::rollDice(ESM::Skill::Length);
|
2015-02-07 03:05:28 +00:00
|
|
|
skills.insert(skill);
|
|
|
|
|
|
|
|
MWMechanics::SkillValue& value = player.getClass().getNpcStats(player).getSkill(skill);
|
|
|
|
if (skill == ESM::Skill::Security || skill == ESM::Skill::Sneak)
|
|
|
|
value.setBase(std::min(100, value.getBase()+1));
|
|
|
|
else
|
|
|
|
value.setBase(value.getBase()-1);
|
|
|
|
}
|
|
|
|
|
|
|
|
const MWWorld::Store<ESM::GameSetting>& gmst = MWBase::Environment::get().getWorld()->getStore().get<ESM::GameSetting>();
|
|
|
|
|
|
|
|
std::string message;
|
|
|
|
if (mDays == 1)
|
|
|
|
message = gmst.find("sNotifyMessage42")->getString();
|
|
|
|
else
|
|
|
|
message = gmst.find("sNotifyMessage43")->getString();
|
|
|
|
|
2017-07-03 12:45:21 +00:00
|
|
|
/*
|
|
|
|
Start of tes3mp addition
|
|
|
|
|
2017-07-11 10:34:09 +00:00
|
|
|
If jail teleportation was ignored, reset its boolean here
|
2017-07-03 12:45:21 +00:00
|
|
|
*/
|
|
|
|
if (mwmp::Main::get().getLocalPlayer()->ignoreJailTeleportation)
|
|
|
|
{
|
|
|
|
mwmp::Main::get().getLocalPlayer()->ignoreJailTeleportation = false;
|
|
|
|
}
|
|
|
|
/*
|
|
|
|
End of tes3mp addition
|
|
|
|
*/
|
|
|
|
|
2015-02-07 03:05:28 +00:00
|
|
|
std::stringstream dayStr;
|
|
|
|
dayStr << mDays;
|
|
|
|
if (message.find("%d") != std::string::npos)
|
|
|
|
message.replace(message.find("%d"), 2, dayStr.str());
|
|
|
|
|
|
|
|
for (std::set<int>::iterator it = skills.begin(); it != skills.end(); ++it)
|
|
|
|
{
|
|
|
|
std::string skillName = gmst.find(ESM::Skill::sSkillNameIds[*it])->getString();
|
|
|
|
std::stringstream skillValue;
|
|
|
|
skillValue << player.getClass().getNpcStats(player).getSkill(*it).getBase();
|
|
|
|
std::string skillMsg = gmst.find("sNotifyMessage44")->getString();
|
|
|
|
if (*it == ESM::Skill::Sneak || *it == ESM::Skill::Security)
|
|
|
|
skillMsg = gmst.find("sNotifyMessage39")->getString();
|
|
|
|
|
|
|
|
if (skillMsg.find("%s") != std::string::npos)
|
|
|
|
skillMsg.replace(skillMsg.find("%s"), 2, skillName);
|
|
|
|
if (skillMsg.find("%d") != std::string::npos)
|
|
|
|
skillMsg.replace(skillMsg.find("%d"), 2, skillValue.str());
|
|
|
|
message += "\n" + skillMsg;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::vector<std::string> buttons;
|
|
|
|
buttons.push_back("#{sOk}");
|
|
|
|
MWBase::Environment::get().getWindowManager()->interactiveMessageBox(message, buttons);
|
|
|
|
}
|
|
|
|
}
|