/* * Copyright 2008 Ben Boeckel * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program. If not, see . */ // Header include #include "MapWarpUI.h" // Sigmod includes #include "../sigmod/Map.h" #include "../sigmod/MapWarp.h" #include "../sigmod/Sigmod.h" Sigmodr::MapWarpUI::MapWarpUI(Sigmod::MapWarp* warp, QWidget* parent) : ObjectUI(parent), m_lastMap(-1) { setupUi(this); setObjects(warp, new Sigmod::MapWarp(*warp)); } Sigmodr::MapWarpUI::~MapWarpUI() { } void Sigmodr::MapWarpUI::initGui() { varType->addItem(Sigmod::MapWarp::TypeStr[Sigmod::MapWarp::Door], QVariant::fromValue(Sigmod::MapWarp::Door)); varType->addItem(Sigmod::MapWarp::TypeStr[Sigmod::MapWarp::Warp], QVariant::fromValue(Sigmod::MapWarp::Warp)); varType->addItem(Sigmod::MapWarp::TypeStr[Sigmod::MapWarp::Hole], QVariant::fromValue(Sigmod::MapWarp::Hole)); varType->addItem(Sigmod::MapWarp::TypeStr[Sigmod::MapWarp::Boundary], QVariant::fromValue(Sigmod::MapWarp::Boundary)); } void Sigmodr::MapWarpUI::refreshGui() { const bool blocked = varToMap->blockSignals(true); varToMap->clear(); for (int i = 0; i < sigmod()->mapCount(); ++i) { const Sigmod::Map* map = sigmod()->map(i); varToMap->addItem(map->name(), map->id()); } varToMap->blockSignals(blocked); } void Sigmodr::MapWarpUI::setGui() { const bool resetWarps = (qobject_cast(modified())->toMap() != m_lastMap); varName->setText(qobject_cast(modified())->name()); varType->setCurrentIndex(qobject_cast(modified())->type()); varToMap->setCurrentIndex(varToMap->findData(qobject_cast(modified())->toMap())); m_lastMap = qobject_cast(modified())->toMap(); if (resetWarps) { const bool blocked = varToWarp->blockSignals(true); varToWarp->clear(); const Sigmod::Map* map = sigmod()->mapById(qobject_cast(modified())->toMap()); if (map) { for (int i = 0; i < map->warpCount(); ++i) { const Sigmod::MapWarp* warp = map->warp(i); varToWarp->addItem(warp->name(), warp->id()); } } varToWarp->blockSignals(blocked); } varToWarp->setCurrentIndex(varToMap->findData(qobject_cast(modified())->toWarp())); varScript->setValue(qobject_cast(modified())->script()); } void Sigmodr::MapWarpUI::apply() { *qobject_cast(original()) = *qobject_cast(modified()); emit(changed(false)); } void Sigmodr::MapWarpUI::discard() { *qobject_cast(modified()) = *qobject_cast(original()); setGui(); emit(changed(false)); } void Sigmodr::MapWarpUI::on_varName_textChanged(const QString& name) { const int cursor = varName->cursorPosition(); qobject_cast(modified())->setName(name); varName->setCursorPosition(cursor); } void Sigmodr::MapWarpUI::on_varType_activated(const int type) { qobject_cast(modified())->setType(varType->itemData(type).value()); } void Sigmodr::MapWarpUI::on_varToMap_activated(const int toMap) { qobject_cast(modified())->setToMap(toMap); } void Sigmodr::MapWarpUI::on_varToWarp_activated(const int toWarp) { qobject_cast(modified())->setToWarp(toWarp); } void Sigmodr::MapWarpUI::on_varScript_valueChanged(const Sigcore::Script& script) { qobject_cast(modified())->setScript(script); }