/* * Copyright (C) 2007 Ivan Cukic <ivan.cukic+kde@gmail.com> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU Library/Lesser General Public License * version 2, or (at your option) any later version, as published by the * Free Software Foundation * * 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 Library/Lesser 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. */ #ifndef PLASMA_BORDER_LAYOUT #define PLASMA_BORDER_LAYOUT #include <QtCore/QMap> #include <plasma/plasma_export.h> #include <plasma/plasma.h> #include <plasma/layouts/layout.h> namespace Plasma { /** * A layout which lays one item per border (left, top, bottom, right) * and one item in center. * * Similar to java.awt.BorderLayout from the Java's standard library */ class PLASMA_EXPORT BorderLayout : public Layout { public: explicit BorderLayout(LayoutItem * parent = 0); virtual ~BorderLayout(); virtual Qt::Orientations expandingDirections() const; QSizeF sizeHint() const; /** * Adds item in the center. Equal to: * addItem(item, Plasma::CenterPositioned); */ void addItem(Plasma::LayoutItem * item); /** * Adds item at the specified position */ void addItem(Plasma::LayoutItem * item, Position position); void removeItem(Plasma::LayoutItem * item); virtual int count() const; virtual int indexOf(LayoutItem * item) const; virtual LayoutItem * itemAt(int i) const; virtual LayoutItem * takeAt(int i); /** * Deactivates the automatic sizing of a border widget, * and sets it to the specified size. * * For left and right widgets, it sets the width; while * for top and bottom ones, it sets the height. */ void setSize(qreal size, Position border); /** * Activates the automatic sizing of a border widget, * according to it's sizeHint() */ void setAutoSize(Position border); /** * Returns the size of the specified border widget. If * automatic sizing for that border widget is activated, * it will return a value less than zero. */ qreal size(Position border); protected: void relayout(); void releaseManagedItems(); private: class Private; Private * const d; }; } #endif /* PLASMA_BORDER_LAYOUT */