1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
|
/*
* Copyright (c) 2009 Cyrille Berger <cberger@cberger.net>
* Copyright (c) 2011 Yue Liu <yue.liu@mail.com>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation;
* either version 2, or (at your option) any later version of the License.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this library; see the file COPYING. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#ifndef FLOWLAYOUT_H
#define FLOWLAYOUT_H
#include <QObject>
class QRectF;
class KoShape;
class FlowLayout : public QObject {
Q_OBJECT
public:
explicit FlowLayout(const QString &_id);
virtual ~FlowLayout();
public:
const QString& id() const;
public:
void replaceLayout(Layout* layout);
void addShapes(QList<KoShape*> _shapes);
void addShape(KoShape* _shape);
void removeShape(KoShape* _shape);
virtual QRectF boundingBox() const;
protected:
const QList<KoShape*>& shapes() const;
protected:
/**
* This function is called when a list of shapes is added to the layout.
*
* The default implementation call shapeAdded for each shape
*/
virtual void shapesAdded(QList<KoShape*> _shape);
/**
* This function is called when a shape is added to the layout.
*/
virtual void shapeAdded(KoShape* _shape) = 0;
/**
* This function is called when a shape is removed to the layout.
*/
virtual void shapeRemoved(KoShape* _shape) = 0;
/**
* This function is called when a shape geometry is changed.
*/
virtual void shapeGeometryChanged(KoShape* _shape) = 0;
/**
* This function is called when the layout is expected to update the position of shapes
*/
virtual void relayout() = 0;
protected:
// Reimplemented from QObject
virtual bool event(QEvent * e);
signals:
void boundingBoxChanged( const QRectF& _rect );
private:
struct Private;
Private* const d;
};
#endif
|