00001 /* This file is part of WarpTree 00002 * 00003 * Copyright (C) 2007 Jos van den Oever <jos@vandenoever.info> 00004 * 00005 * This library is free software; you can redistribute it and/or 00006 * modify it under the terms of the GNU Library General Public 00007 * License as published by the Free Software Foundation; either 00008 * version 2 of the License, or (at your option) any later version. 00009 * 00010 * This library is distributed in the hope that it will be useful, 00011 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00012 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00013 * Library General Public License for more details. 00014 * 00015 * You should have received a copy of the GNU Library General Public License 00016 * along with this library; see the file COPYING.LIB. If not, write to 00017 * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, 00018 * Boston, MA 02110-1301, USA. 00019 */ 00020 #ifndef LABELFITTER_H 00021 #define LABELFITTER_H 00022 00023 #include <QtCore/QList> 00024 #include <QtCore/QPoint> 00025 #include <QtCore/QRect> 00026 /* 00027 * Class that fits as many labels as possible on a grid. 00028 * Each label is attempted to fit as close to the middle as possible. 00029 */ 00030 class LabelFitter { 00031 private: 00032 struct Label { 00033 Label(QRect& r, const QPoint& p) :rect(&r), point(p) {} 00034 QRect* rect; 00035 QPoint point; 00036 }; 00037 QRect box; 00038 QList<Label> labels; 00039 public: 00044 void reset(int width, int height); 00056 bool fit(QRect& r, const QPoint& p); 00057 }; 00058 00059 #endif