|
|
|
@ -30,11 +30,13 @@ namespace MWGui
|
|
|
|
|
getWidget(mInfoText, "InfoText");
|
|
|
|
|
getWidget(mOkButton, "OkButton");
|
|
|
|
|
getWidget(mCancelButton, "CancelButton");
|
|
|
|
|
getWidget(mDeleteButton, "DeleteButton");
|
|
|
|
|
getWidget(mSaveList, "SaveList");
|
|
|
|
|
getWidget(mSaveNameEdit, "SaveNameEdit");
|
|
|
|
|
getWidget(mSpacer, "Spacer");
|
|
|
|
|
mOkButton->eventMouseButtonClick += MyGUI::newDelegate(this, &SaveGameDialog::onOkButtonClicked);
|
|
|
|
|
mCancelButton->eventMouseButtonClick += MyGUI::newDelegate(this, &SaveGameDialog::onCancelButtonClicked);
|
|
|
|
|
mDeleteButton->eventMouseButtonClick += MyGUI::newDelegate(this, &SaveGameDialog::onDeleteButtonClicked);
|
|
|
|
|
mCharacterSelection->eventComboChangePosition += MyGUI::newDelegate(this, &SaveGameDialog::onCharacterSelected);
|
|
|
|
|
mSaveList->eventListChangePosition += MyGUI::newDelegate(this, &SaveGameDialog::onSlotSelected);
|
|
|
|
|
mSaveList->eventListMouseItemActivate += MyGUI::newDelegate(this, &SaveGameDialog::onSlotMouseClick);
|
|
|
|
@ -54,6 +56,10 @@ namespace MWGui
|
|
|
|
|
onSlotSelected(sender, pos);
|
|
|
|
|
|
|
|
|
|
if (pos != MyGUI::ITEM_NONE && MyGUI::InputManager::getInstance().isShiftPressed())
|
|
|
|
|
confirmDeleteSave();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void SaveGameDialog::confirmDeleteSave()
|
|
|
|
|
{
|
|
|
|
|
ConfirmationDialog* dialog = MWBase::Environment::get().getWindowManager()->getConfirmationDialog();
|
|
|
|
|
dialog->open("#{sMessage3}");
|
|
|
|
@ -61,7 +67,6 @@ namespace MWGui
|
|
|
|
|
dialog->eventOkClicked += MyGUI::newDelegate(this, &SaveGameDialog::onDeleteSlotConfirmed);
|
|
|
|
|
dialog->eventCancelClicked.clear();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void SaveGameDialog::onDeleteSlotConfirmed()
|
|
|
|
|
{
|
|
|
|
@ -107,6 +112,7 @@ namespace MWGui
|
|
|
|
|
mCurrentCharacter = NULL;
|
|
|
|
|
mCurrentSlot = NULL;
|
|
|
|
|
mSaveList->removeAllItems();
|
|
|
|
|
onSlotSelected(mSaveList, MyGUI::ITEM_NONE);
|
|
|
|
|
|
|
|
|
|
MWBase::StateManager* mgr = MWBase::Environment::get().getStateManager();
|
|
|
|
|
if (mgr->characterBegin() == mgr->characterEnd())
|
|
|
|
@ -157,6 +163,8 @@ namespace MWGui
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
mCharacterSelection->setIndexSelected(selectedIndex);
|
|
|
|
|
if (selectedIndex == MyGUI::ITEM_NONE)
|
|
|
|
|
mCharacterSelection->setCaption("Select Character ...");
|
|
|
|
|
|
|
|
|
|
fillSaveList();
|
|
|
|
|
|
|
|
|
@ -175,6 +183,9 @@ namespace MWGui
|
|
|
|
|
mCharacterSelection->setVisible(load);
|
|
|
|
|
mSpacer->setUserString("Hidden", load ? "false" : "true");
|
|
|
|
|
|
|
|
|
|
mDeleteButton->setUserString("Hidden", load ? "false" : "true");
|
|
|
|
|
mDeleteButton->setVisible(load);
|
|
|
|
|
|
|
|
|
|
if (!load)
|
|
|
|
|
{
|
|
|
|
|
mCurrentCharacter = MWBase::Environment::get().getStateManager()->getCurrentCharacter (false);
|
|
|
|
@ -188,6 +199,12 @@ namespace MWGui
|
|
|
|
|
exit();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void SaveGameDialog::onDeleteButtonClicked(MyGUI::Widget *sender)
|
|
|
|
|
{
|
|
|
|
|
if (mCurrentSlot)
|
|
|
|
|
confirmDeleteSave();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void SaveGameDialog::onConfirmationGiven()
|
|
|
|
|
{
|
|
|
|
|
accept(true);
|
|
|
|
@ -225,12 +242,10 @@ namespace MWGui
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if (mCurrentCharacter && mCurrentSlot)
|
|
|
|
|
{
|
|
|
|
|
assert (mCurrentCharacter && mCurrentSlot);
|
|
|
|
|
MWBase::Environment::get().getStateManager()->loadGame (mCurrentCharacter, mCurrentSlot);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void SaveGameDialog::onOkButtonClicked(MyGUI::Widget *sender)
|
|
|
|
|
{
|
|
|
|
@ -278,6 +293,9 @@ namespace MWGui
|
|
|
|
|
|
|
|
|
|
void SaveGameDialog::onSlotSelected(MyGUI::ListBox *sender, size_t pos)
|
|
|
|
|
{
|
|
|
|
|
mOkButton->setEnabled(pos != MyGUI::ITEM_NONE || mSaving);
|
|
|
|
|
mDeleteButton->setEnabled(pos != MyGUI::ITEM_NONE);
|
|
|
|
|
|
|
|
|
|
if (pos == MyGUI::ITEM_NONE)
|
|
|
|
|
{
|
|
|
|
|
mCurrentSlot = NULL;
|
|
|
|
|