/* * ORXONOX - the hottest 3D action shooter ever to exist * > www.orxonox.net < * * * License notice: * * 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 2 * 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, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * * Author: * Reto Grieder * Co-authors: * ... * */ #include "OverlayText.h" #include #include #include "util/String.h" #include "core/CoreIncludes.h" #include "core/XMLPort.h" namespace orxonox { CreateFactory(OverlayText); OverlayText::OverlayText(BaseObject* creator) : OrxonoxOverlay(creator) { RegisterObject(OverlayText); this->text_ = static_cast(Ogre::OverlayManager::getSingleton() .createOverlayElement("TextArea", "OverlayText_text_" + getUniqueNumberString())); this->text_->setCharHeight(1.0); this->setFont("Monofur"); this->setColour(ColourValue(1.0, 1.0, 1.0, 1.0)); this->setCaption(""); this->setTextSize(1.0f); this->setAlignmentString("left"); this->background_->addChild(this->text_); } OverlayText::~OverlayText() { if (this->isInitialized()) Ogre::OverlayManager::getSingleton().destroyOverlayElement(this->text_); } void OverlayText::XMLPort(Element& xmlElement, XMLPort::Mode mode) { SUPER(OverlayText, XMLPort, xmlElement, mode); XMLPortParam(OverlayText, "font", setFont, getFont, xmlElement, mode); XMLPortParam(OverlayText, "colour", setColour, getColour, xmlElement, mode); XMLPortParam(OverlayText, "caption", setCaption, getCaption, xmlElement, mode); XMLPortParam(OverlayText, "textsize", setTextSize, getTextSize, xmlElement, mode); XMLPortParam(OverlayText, "align", setAlignmentString, getAlignmentString, xmlElement, mode); XMLPortParam(OverlayText, "spacewidth", setSpaceWidth, getSpaceWidth, xmlElement, mode); } void OverlayText::setFont(const std::string& font) { if (font != "") this->text_->setFontName(font); } void OverlayText::setAlignmentString(const std::string& alignment) { if (alignment == "right") this->setAlignment(Ogre::TextAreaOverlayElement::Right); else if (alignment == "center") this->setAlignment(Ogre::TextAreaOverlayElement::Center); else // "left" and default this->setAlignment(Ogre::TextAreaOverlayElement::Left); } std::string OverlayText::getAlignmentString() const { Ogre::TextAreaOverlayElement::Alignment alignment = this->text_->getAlignment(); switch (alignment) { case Ogre::TextAreaOverlayElement::Right: return "right"; case Ogre::TextAreaOverlayElement::Center: return "center"; case Ogre::TextAreaOverlayElement::Left: return "left"; default: assert(false); return ""; } } void OverlayText::sizeChanged() { if (this->rotState_ == Horizontal) this->overlay_->setScale(size_.y * sizeCorrection_.y, size_.y * sizeCorrection_.y); else if (this->rotState_ == Vertical) this->overlay_->setScale(size_.y / (sizeCorrection_.y * sizeCorrection_.y), size_.y * sizeCorrection_.y); else this->overlay_->setScale(size_.y, size_.y); positionChanged(); } }