diff options
Diffstat (limited to 'src/gui/skin.h')
-rw-r--r-- | src/gui/skin.h | 136 |
1 files changed, 136 insertions, 0 deletions
diff --git a/src/gui/skin.h b/src/gui/skin.h new file mode 100644 index 000000000..7cafd7601 --- /dev/null +++ b/src/gui/skin.h @@ -0,0 +1,136 @@ +/* + * Gui Skinning + * Copyright (C) 2008 The Legend of Mazzeroth Development Team + * Copyright (C) 2009 Aethyra Development Team + * Copyright (C) 2009 The Mana World Development Team + * Copyright (C) 2009-2010 The Mana Developers + * Copyright (C) 2011-2014 The ManaPlus Developers + * + * This file is part of The ManaPlus Client. + * + * 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 + * 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 <http://www.gnu.org/licenses/>. + */ + +#ifndef GUI_SKIN_H +#define GUI_SKIN_H + +#include <map> +#include <string> + +#include "localconsts.h" + +class Image; +class ImageRect; + +class Skin final +{ + public: + Skin(ImageRect *const restrict skin, + const ImageRect *const restrict images, + const std::string &filePath, + const std::string &name = "", + const int padding = 3, + const int titlePadding = 4, + std::map<std::string, int> *restrict const options = nullptr); + + A_DELETE_COPY(Skin) + + ~Skin(); + + /** + * Returns the skin's name. Useful for giving a human friendly skin + * name if a dialog for skin selection for a specific window type is + * done. + */ + const std::string &getName() const A_WARN_UNUSED + { return mName; } + + /** + * Returns the skin's xml file path. + */ + const std::string &getFilePath() const A_WARN_UNUSED + { return mFilePath; } + + /** + * Returns the background skin. + */ + const ImageRect &getBorder() const A_WARN_UNUSED + { return *mBorder; } + + /** + * Returns the image used by a close button for this skin. + */ + const Image *getCloseImage(const bool state) const A_WARN_UNUSED + { return state ? mCloseImageHighlighted : mCloseImage; } + + /** + * Returns the image used by a sticky button for this skin. + */ + const Image *getStickyImage(const bool state) const A_WARN_UNUSED + { return state ? mStickyImageDown : mStickyImageUp; } + + /** + * Returns the minimum width which can be used with this skin. + */ + int getMinWidth() const A_WARN_UNUSED; + + /** + * Returns the minimum height which can be used with this skin. + */ + int getMinHeight() const A_WARN_UNUSED; + + /** + * Updates the alpha value of the skin + */ + void updateAlpha(const float minimumOpacityAllowed = 0.0F); + + int getPadding() const A_WARN_UNUSED + { return mPadding; } + + int getTitlePadding() const A_WARN_UNUSED + { return mTitlePadding; } + + int getOption(const std::string &name) const A_WARN_UNUSED + { + if (mOptions->find(name) != mOptions->end()) + return (*mOptions)[name]; + else + return 0; + } + + int getOption(const std::string &name, + const int def) const A_WARN_UNUSED + { + if (mOptions->find(name) != mOptions->end()) + return (*mOptions)[name]; + else + return def; + } + + int instances; + + private: + std::string mFilePath; /**< File name path for the skin */ + std::string mName; /**< Name of the skin to use */ + ImageRect *mBorder; /**< The window border and background */ + Image *mCloseImage; /**< Close Button Image */ + Image *mCloseImageHighlighted; /**< Highlighted close Button Image */ + Image *mStickyImageUp; /**< Sticky Button Image */ + Image *mStickyImageDown; /**< Sticky Button Image */ + int mPadding; + int mTitlePadding; + std::map<std::string, int> *mOptions; +}; + +#endif // GUI_SKIN_H |