/******************************************************************** KWin - the KDE window manager This file is part of the KDE project. Copyright (C) 2009 Martin Gräßlin 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 (at your option) 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 . *********************************************************************/ #ifndef DESKTOPITEMDELEGATE_H #define DESKTOPITEMDELEGATE_H #include "itemlayoutconfig.h" #include /** * @file * This file defines the class DesktopItemDelegate, the ItemDelegate for desktops. * * @author Martin Gräßlin * @since 4.4 */ namespace Plasma { class FrameSvg; } namespace KWin { namespace TabBox { class ClientItemDelegate; /** * The ItemDelegate for desktops used in TabBox. * * @author Martin Gräßlin * @since 4.4 */ class DesktopItemDelegate : public QAbstractItemDelegate { public: DesktopItemDelegate( QObject* parent = 0 ); ~DesktopItemDelegate(); virtual QSize sizeHint(const QStyleOptionViewItem& option, const QModelIndex& index) const; virtual void paint(QPainter* painter, const QStyleOptionViewItem& option, const QModelIndex& index) const; void setConfig( const ItemLayoutConfig& config ); void setLayouts( QMap< QString, ItemLayoutConfig >& layouts ); private: /** * Paints the given text at the given position based on the given ItemLayoutConfigRowElement. * @param painter The painter to paint the text * @param option The current QStyleOptionViewItem * @param element The current ItemLayoutConfigRowElement * @param x The left x positon for drawing the text * @param y The top y position for drawing the text * @param rowHeight The height of the current rendered row * @param text The text which should be drawn */ qreal paintTextElement( QPainter* painter, const QStyleOptionViewItem& option, const ItemLayoutConfigRowElement& element, const qreal& x, const qreal& y, const qreal& rowHeight, QString text ) const; /** * Calculates the size hint of the given row. * @param index The current QModelIndex * @param row The row for which the size hint has to be calculated * @return The size hint of the given row */ QSizeF rowSize( const QModelIndex& index, int row ) const; /** * Calculates the size hint of given text. * This method is used to calculate the maximum size of a row. * @param index The current model index * @param element The ItemLayoutConfigRowElement defining how the text has to be layed out. * @param text The text whose size has to be calculated * @return The size of the given text if it would be rendered */ QSizeF textElementSizeHint( const QModelIndex& index, const ItemLayoutConfigRowElement& element, QString text ) const; /** * The FrameSvg to render selected items */ Plasma::FrameSvg* m_frame; ItemLayoutConfig m_config; QMap< QString, ItemLayoutConfig > m_layouts; ClientItemDelegate* m_clientDelegate; }; } // namespace Tabbox } // namespace KWin #endif // DESKTOPITEMDELEGATE_H