1 /***************************************************************************
2 * Copyright (C) 2007 by Peter Penz <peter.penz@gmx.at> *
4 * This program is free software; you can redistribute it and/or modify *
5 * it under the terms of the GNU General Public License as published by *
6 * the Free Software Foundation; either version 2 of the License, or *
7 * (at your option) any later version. *
9 * This program is distributed in the hope that it will be useful, *
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
12 * GNU General Public License for more details. *
14 * You should have received a copy of the GNU General Public License *
15 * along with this program; if not, write to the *
16 * Free Software Foundation, Inc., *
17 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA *
18 ***************************************************************************/
20 #include "draganddrophelper.h"
21 #include "dolphiniconsview.h"
23 #include <kdirmodel.h>
26 #include <QAbstractItemView>
27 #include <QAbstractProxyModel>
34 void DragAndDropHelper::startDrag(QAbstractItemView
* itemView
, Qt::DropActions supportedActions
)
36 QModelIndexList indexes
= itemView
->selectionModel()->selectedIndexes();
37 if (indexes
.count() > 0) {
38 QMimeData
*data
= itemView
->model()->mimeData(indexes
);
43 QDrag
* drag
= new QDrag(itemView
);
45 if (indexes
.count() == 1) {
46 QAbstractProxyModel
* proxyModel
= static_cast<QAbstractProxyModel
*>(itemView
->model());
47 KDirModel
* dirModel
= static_cast<KDirModel
*>(proxyModel
->sourceModel());
48 const QModelIndex index
= proxyModel
->mapToSource(indexes
.first());
50 const KFileItem item
= dirModel
->itemForIndex(index
);
51 pixmap
= item
.pixmap(KIconLoader::SizeMedium
, KIconLoader::SizeMedium
);
53 pixmap
= KIcon("document-multiple").pixmap(KIconLoader::SizeMedium
, KIconLoader::SizeMedium
);
55 drag
->setPixmap(pixmap
);
56 drag
->setMimeData(data
);
57 drag
->exec(supportedActions
, Qt::IgnoreAction
);
61 void DragAndDropHelper::drawHoverIndication(QAbstractItemView
* itemView
,
65 if (bounds
.isEmpty()) {
69 QWidget
* widget
= itemView
->viewport();
71 QPainter
painter(widget
);
73 QBrush
blendedBrush(brush
);
74 QColor color
= blendedBrush
.color();
76 blendedBrush
.setColor(color
);
78 if (dynamic_cast<DolphinIconsView
*>(itemView
)) {
79 const int radius
= 10;
80 QPainterPath
path(QPointF(bounds
.left(), bounds
.top() + radius
));
81 path
.quadTo(bounds
.left(), bounds
.top(), bounds
.left() + radius
, bounds
.top());
82 path
.lineTo(bounds
.right() - radius
, bounds
.top());
83 path
.quadTo(bounds
.right(), bounds
.top(), bounds
.right(), bounds
.top() + radius
);
84 path
.lineTo(bounds
.right(), bounds
.bottom() - radius
);
85 path
.quadTo(bounds
.right(), bounds
.bottom(), bounds
.right() - radius
, bounds
.bottom());
86 path
.lineTo(bounds
.left() + radius
, bounds
.bottom());
87 path
.quadTo(bounds
.left(), bounds
.bottom(), bounds
.left(), bounds
.bottom() - radius
);
90 painter
.setRenderHint(QPainter::Antialiasing
);
91 painter
.fillPath(path
, blendedBrush
);
93 painter
.fillRect(bounds
, blendedBrush
);