/* * The ManaPlus Client * Copyright (C) 2007-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/>. */ #include "gui/windows/shortcutwindow.h" #include "gui/windows/setupwindow.h" #include "gui/widgets/layout.h" #include "gui/widgets/scrollarea.h" #include "gui/widgets/shortcutcontainer.h" #include "gui/widgets/tabs/tab.h" #include "debug.h" static const int SCROLL_PADDING = 0; int ShortcutWindow::mBoxesWidth = 0; class ShortcutTab final : public Tab { public: ShortcutTab(const Widget2 *const widget, std::string name, ShortcutContainer *const content) : Tab(widget), mContent(content) { setCaption(name); } A_DELETE_COPY(ShortcutTab) ShortcutContainer* mContent; }; ShortcutWindow::ShortcutWindow(const std::string &restrict title, ShortcutContainer *restrict const content, const std::string &restrict skinFile, int width, int height) : Window("Window", false, nullptr, skinFile), mItems(content), mScrollArea(new ScrollArea(mItems, false)), mTabs(nullptr), mPages() { setWindowName(title); setTitleBarHeight(getPadding() + getTitlePadding()); setShowTitle(false); setResizable(true); setDefaultVisible(false); setSaveVisible(true); mDragOffsetX = 0; mDragOffsetY = 0; content->setWidget2(this); if (setupWindow) setupWindow->registerWindowForReset(this); const int border = SCROLL_PADDING * 2 + getPadding() * 2; const int bw = mItems->getBoxWidth(); const int bh = mItems->getBoxHeight(); const int maxItems = mItems->getMaxItems(); setMinWidth(32); setMinHeight(32); setMaxWidth(bw * maxItems + border); setMaxHeight(bh * maxItems + border); if (width == 0) width = bw + border; if (height == 0) height = bh * maxItems + border; setDefaultSize(width, height, ImageRect::LOWER_RIGHT); mBoxesWidth += bw + border; mScrollArea->setPosition(SCROLL_PADDING, SCROLL_PADDING); mScrollArea->setHorizontalScrollPolicy(gcn::ScrollArea::SHOW_NEVER); place(0, 0, mScrollArea, 5, 5).setPadding(0); Layout &layout = getLayout(); layout.setRowHeight(0, Layout::AUTO_SET); layout.setMargin(0); loadWindowState(); enableVisibleSound(true); } ShortcutWindow::ShortcutWindow(const std::string &restrict title, const std::string &restrict skinFile, const int width, const int height) : Window("Window", false, nullptr, skinFile), mItems(nullptr), mScrollArea(nullptr), mTabs(new TabbedArea(this)), mPages() { mTabs->postInit(); setWindowName(title); setTitleBarHeight(getPadding() + getTitlePadding()); setShowTitle(false); setResizable(true); setDefaultVisible(false); setSaveVisible(true); mDragOffsetX = 0; mDragOffsetY = 0; if (setupWindow) setupWindow->registerWindowForReset(this); if (width && height) setDefaultSize(width, height, ImageRect::LOWER_RIGHT); setMinWidth(32); setMinHeight(32); place(0, 0, mTabs, 5, 5); Layout &layout = getLayout(); layout.setRowHeight(0, Layout::AUTO_SET); layout.setMargin(0); loadWindowState(); enableVisibleSound(true); } ShortcutWindow::~ShortcutWindow() { if (mTabs) mTabs->removeAll(); delete mTabs; mTabs = nullptr; delete mItems; mItems = nullptr; } void ShortcutWindow::addTab(const std::string &name, ShortcutContainer *const content) { ScrollArea *const scroll = new ScrollArea(content, false); scroll->setPosition(SCROLL_PADDING, SCROLL_PADDING); scroll->setHorizontalScrollPolicy(gcn::ScrollArea::SHOW_NEVER); content->setWidget2(this); Tab *const tab = new ShortcutTab(this, name, content); mTabs->addTab(tab, scroll); mPages.push_back(content); } int ShortcutWindow::getTabIndex() const { if (!mTabs) return 0; return mTabs->getSelectedTabIndex(); } void ShortcutWindow::widgetHidden(const gcn::Event &event) { if (mItems) mItems->widgetHidden(event); if (mTabs) { ScrollArea *const scroll = static_cast<ScrollArea *const>( mTabs->getCurrentWidget()); if (scroll) { ShortcutContainer *const content = static_cast<ShortcutContainer*>( scroll->getContent()); if (content) content->widgetHidden(event); } } } void ShortcutWindow::mousePressed(gcn::MouseEvent &event) { Window::mousePressed(event); if (event.isConsumed()) return; if (event.getButton() == gcn::MouseEvent::LEFT) { mDragOffsetX = event.getX(); mDragOffsetY = event.getY(); } } void ShortcutWindow::mouseDragged(gcn::MouseEvent &event) { Window::mouseDragged(event); if (event.isConsumed()) return; if (canMove() && isMovable() && mMoved) { int newX = std::max(0, getX() + event.getX() - mDragOffsetX); int newY = std::max(0, getY() + event.getY() - mDragOffsetY); newX = std::min(mainGraphics->mWidth - getWidth(), newX); newY = std::min(mainGraphics->mHeight - getHeight(), newY); setPosition(newX, newY); } } void ShortcutWindow::widgetMoved(const gcn::Event& event) { Window::widgetMoved(event); if (mItems) mItems->setRedraw(true); FOR_EACH (std::vector<ShortcutContainer*>::iterator, it, mPages) (*it)->setRedraw(true); } void ShortcutWindow::nextTab() { if (mTabs) mTabs->selectNextTab(); } void ShortcutWindow::prevTab() { if (mTabs) mTabs->selectPrevTab(); } #ifdef USE_PROFILER void ShortcutWindow::logicChildren() { BLOCK_START("ShortcutWindow::logicChildren") BasicContainer::logicChildren(); BLOCK_END("ShortcutWindow::logicChildren") } #endif