kde-playground/kdepim/kdgantt2/kdgantttreeviewrowcontroller.cpp
2015-04-14 21:49:29 +00:00

131 lines
4.4 KiB
C++

/****************************************************************************
** Copyright (C) 2001-2006 Klarälvdalens Datakonsult AB. All rights reserved.
**
** This file is part of the KD Gantt library.
**
** This file may be distributed and/or modified under the terms of the
** GNU General Public License version 2 as published by the Free Software
** Foundation and appearing in the file LICENSE.GPL included in the
** packaging of this file.
**
** Licensees holding valid commercial KD Gantt licenses may use this file in
** accordance with the KD Gantt Commercial License Agreement provided with
** the Software.
**
** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
**
** See http://www.kdab.net/kdgantt for
** information about KD Gantt Commercial License Agreements.
**
** Contact info@kdab.net if any conditions of this
** licensing are not clear to you.
**
**********************************************************************/
#include "kdgantttreeviewrowcontroller.h"
#include "kdgantttreeviewrowcontroller_p.h"
#include <QAbstractProxyModel>
#include <QHeaderView>
#include <QScrollBar>
#include <cassert>
using namespace KDGantt;
/*!\class TreeViewRowController
* This is an implementation of AbstractRowController that
* aligns a gantt view with a QTreeView.
*/
TreeViewRowController::TreeViewRowController( QTreeView* tv,
QAbstractProxyModel* proxy )
: _d( new Private )
{
_d->treeview = static_cast<Private::HackTreeView*>(tv);
_d->proxy = proxy;
}
TreeViewRowController::~TreeViewRowController()
{
delete _d; _d=0;
}
#define d d_func()
int TreeViewRowController::headerHeight() const
{
//return d->treeview->header()->sizeHint().height();
return d->treeview->viewport()->y()-d->treeview->frameWidth();
}
int TreeViewRowController::maximumItemHeight() const
{
return d->treeview->fontMetrics().height();
}
int TreeViewRowController::totalHeight() const
{
return d->treeview->verticalScrollBar()->maximum()+d->treeview->viewport()->height();
}
bool TreeViewRowController::isRowVisible( const QModelIndex& _idx ) const
{
//qDebug() << _idx.model()<<d->proxy << d->treeview->model();
const QModelIndex idx = d->proxy->mapToSource( _idx );
assert( idx.isValid() ? ( idx.model() == d->treeview->model() ):( true ) );
return d->treeview->visualRect(idx).isValid();
}
bool TreeViewRowController::isRowExpanded( const QModelIndex& _idx ) const
{
const QModelIndex idx = d->proxy->mapToSource( _idx );
assert( idx.isValid() ? ( idx.model() == d->treeview->model() ):( true ) );
return d->treeview->isExpanded( idx );
}
Span TreeViewRowController::rowGeometry( const QModelIndex& _idx ) const
{
const QModelIndex idx = d->proxy->mapToSource( _idx );
assert( idx.isValid() ? ( idx.model() == d->treeview->model() ):( true ) );
QRect r = d->treeview->visualRect(idx).translated( QPoint( 0, d->treeview->verticalOffset() ) );
return Span( r.y(), r.height() );
}
QModelIndex TreeViewRowController::indexAt( int height ) const
{
/* using indexAt( QPoint ) wont work here, since it does hit detection
* against the actual item text/icon, so we would return wrong values
* for items with no text etc.
*
* The code below could cache for performance, but currently it doesn't
* seem to be the performance bottleneck at all.
*/
if ( !d->treeview->model() ) return QModelIndex();
int y = d->treeview->verticalOffset();
QModelIndex idx = d->treeview->model()->index( 0, 0, d->treeview->rootIndex() );
do {
if ( y >= height ) break;
#if QT_VERSION >= 0x040300
y += d->treeview->rowHeight( idx );
#else
// Since TreeViewRowController is NOT using uniform row height
// we can use this:
y += d->treeview->indexRowSizeHint( idx );
#endif
idx = d->treeview->indexBelow( idx );
} while ( idx.isValid() );
return d->proxy->mapFromSource( idx );
}
QModelIndex TreeViewRowController::indexAbove( const QModelIndex& _idx ) const
{
const QModelIndex idx = d->proxy->mapToSource( _idx );
return d->proxy->mapFromSource( d->treeview->indexAbove( idx ) );
}
QModelIndex TreeViewRowController::indexBelow( const QModelIndex& _idx ) const
{
const QModelIndex idx = d->proxy->mapToSource( _idx );
return d->proxy->mapFromSource( d->treeview->indexBelow( idx ) );
}