From bd0f3345a938b35ce6a12f6150373b0955b8dd12 Mon Sep 17 00:00:00 2001 From: Timothy Pearson Date: Sun, 10 Jul 2011 15:24:15 -0500 Subject: Add Qt3 development HEAD version --- examples/demo/dnd/iconview.cpp | 42 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 examples/demo/dnd/iconview.cpp (limited to 'examples/demo/dnd/iconview.cpp') diff --git a/examples/demo/dnd/iconview.cpp b/examples/demo/dnd/iconview.cpp new file mode 100644 index 0000000..c7c184e --- /dev/null +++ b/examples/demo/dnd/iconview.cpp @@ -0,0 +1,42 @@ +#include + +#include "dnd.h" +#include "iconview.h" + + +IconView::IconView( QWidget* parent, const char* name ) + : QIconView( parent, name ) +{ + connect( this, SIGNAL(dropped(QDropEvent*, const QValueList&)), + SLOT(slotNewItem(QDropEvent*, const QValueList&))); +} + +IconView::~IconView() +{ + +} + + +QDragObject *IconView::dragObject() +{ + if ( !currentItem() ) return 0; + + QTextDrag * drg = new QTextDrag( ((IconViewItem*)currentItem())->tag(), this ); + drg->setSubtype("dragdemotag"); + drg->setPixmap( *currentItem()->pixmap() ); + + return drg; +} + +void IconView::slotNewItem( QDropEvent *e, const QValueList& ) +{ + QString tag; + if ( !e->provides( "text/dragdemotag" ) ) return; + + if ( QTextDrag::decode( e, tag ) ) { + IconItem item = ((DnDDemo*) parentWidget())->findItem( tag ); + IconViewItem *iitem = new IconViewItem( this, item.name(), *item.pixmap(), tag ); + iitem->setRenameEnabled( TRUE ); + } + e->acceptAction(); +} -- cgit v1.2.1