summaryrefslogtreecommitdiff
path: root/src/gui/widgets/characterviewsmall.cpp
diff options
context:
space:
mode:
authorAndrei Karas <akaras@inbox.ru>2013-04-22 12:16:20 +0300
committerAndrei Karas <akaras@inbox.ru>2013-04-29 00:49:56 +0300
commit76c98ce0c8e78778f73d6a5728441897e134fb9e (patch)
tree63753c9b80004c2f66314d8ea883a9b378656a12 /src/gui/widgets/characterviewsmall.cpp
parentecf7284930fc6b67db33146819bedf6ec0ed7e7b (diff)
downloadmanaverse-76c98ce0c8e78778f73d6a5728441897e134fb9e.tar.gz
manaverse-76c98ce0c8e78778f73d6a5728441897e134fb9e.tar.bz2
manaverse-76c98ce0c8e78778f73d6a5728441897e134fb9e.tar.xz
manaverse-76c98ce0c8e78778f73d6a5728441897e134fb9e.zip
Improve a bit look in character selection window.
Add selection skin for playerbox. New theme file: playerboxselected.xml
Diffstat (limited to 'src/gui/widgets/characterviewsmall.cpp')
-rw-r--r--src/gui/widgets/characterviewsmall.cpp112
1 files changed, 112 insertions, 0 deletions
diff --git a/src/gui/widgets/characterviewsmall.cpp b/src/gui/widgets/characterviewsmall.cpp
new file mode 100644
index 000000000..59cdd8150
--- /dev/null
+++ b/src/gui/widgets/characterviewsmall.cpp
@@ -0,0 +1,112 @@
+/*
+ * The ManaPlus Client
+ * Copyright (C) 2013 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/>.
+ */
+
+#include "gui/widgets/characterviewsmall.h"
+
+#include "gui/widgets/button.h"
+#include "gui/widgets/characterdisplay.h"
+#include "gui/widgets/label.h"
+
+#include "debug.h"
+
+CharacterViewSmall::CharacterViewSmall(CharSelectDialog *const widget,
+ std::vector<CharacterDisplay*>
+ *const entries,
+ const int padding) :
+ CharacterViewBase(widget, padding),
+ mSelectedEntry(nullptr),
+ mPrevious(new Button(this, "<", "prev", this)),
+ mNext(new Button(this, ">", "next", this)),
+ mNumber(new Label(this, "??")),
+ mCharacterEntries(entries)
+{
+ addKeyListener(widget);
+ if (entries)
+ {
+ FOR_EACHP (std::vector<CharacterDisplay*>::iterator,
+ it, entries)
+ {
+ CharacterDisplay *character = *it;
+ add(character);
+ }
+ show(0);
+ }
+ add(mPrevious);
+ add(mNext);
+ add(mNumber);
+
+ setHeight(200);
+}
+
+CharacterViewSmall::~CharacterViewSmall()
+{
+ removeKeyListener(mParent);
+}
+
+void CharacterViewSmall::show(const int i)
+{
+ const int sz = static_cast<signed>(mCharacterEntries->size());
+ if (mSelectedEntry)
+ mSelectedEntry->setVisible(false);
+ if (i >= sz)
+ mSelected = 0;
+ else if (i < 0)
+ mSelected = mCharacterEntries->size() - 1;
+ else
+ mSelected = i;
+ mSelectedEntry = (*mCharacterEntries)[mSelected];
+ mSelectedEntry->setVisible(true);
+ mNumber->setCaption(strprintf("%d / %d", mSelected + 1, sz));
+ mNumber->adjustSize();
+}
+
+void CharacterViewSmall::resize()
+{
+ const CharacterDisplay *const firtChar = (*mCharacterEntries)[0];
+ const int x = (getWidth() - firtChar->getWidth()) / 2;
+ const int y = (getHeight() - firtChar->getHeight()) / 2;
+ FOR_EACHP (std::vector<CharacterDisplay*>::iterator,
+ it, mCharacterEntries)
+ {
+ (*it)->setPosition(x, y);
+ }
+ const int y2 = (getHeight() - mPrevious->getHeight()) / 2;
+ const int y3 = y2 - 55;
+ mPrevious->setPosition(x - mPrevious->getWidth() - 10, y3);
+ mNext->setPosition(getWidth() - x + 10, y3);
+ mNumber->setPosition(10, y2);
+}
+
+void CharacterViewSmall::action(const gcn::ActionEvent &event)
+{
+ const std::string &eventId = event.getId();
+ if (eventId == "next")
+ {
+ mSelected ++;
+ show(mSelected);
+ mParent->updateState();
+ }
+ else if (eventId == "prev")
+ {
+ mSelected --;
+ show(mSelected);
+ mParent->updateState();
+ }
+}