summaryrefslogtreecommitdiffstats
path: root/kdecore/kmultipledrag.h
diff options
context:
space:
mode:
Diffstat (limited to 'kdecore/kmultipledrag.h')
-rw-r--r--kdecore/kmultipledrag.h105
1 files changed, 105 insertions, 0 deletions
diff --git a/kdecore/kmultipledrag.h b/kdecore/kmultipledrag.h
new file mode 100644
index 000000000..bb08c86cc
--- /dev/null
+++ b/kdecore/kmultipledrag.h
@@ -0,0 +1,105 @@
+/* This file is part of the KDE project
+ Copyright (C) 2001 David Faure <[email protected]>
+
+ This program is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Library General Public
+ License as published by the Free Software Foundation; either
+ version 2 of the License.
+
+ 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
+ Library General Public License for more details.
+
+ You should have received a copy of the GNU Library General Public License
+ along with this program; see the file COPYING. If not, write to
+ the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+ Boston, MA 02110-1301, USA.
+*/
+
+#ifndef KMULTIPLEDRAG_H
+#define KMULTIPLEDRAG_H
+
+#ifndef QT_NO_DRAGANDDROP
+
+#include <qdragobject.h>
+#include <qvaluelist.h>
+#include "kdelibs_export.h"
+
+class KMultipleDragPrivate;
+/**
+ * This class makes it easy for applications to provide a drag object
+ * (for drag-n-drop or for clipboard) that has several representations
+ * of the same data, under different formats.
+ *
+ * Instead of creating a specific class for each case (as would otherwise
+ * be necessary), you can simply create independent drag objects (e.g.
+ * a QImageDrag object and a KURLDrag object), and bundle them together
+ * using KMultipleDrag.
+ *
+ * Sample code for this:
+ *
+ * \code
+ * KMultipleDrag *drag = new KMultipleDrag( parentWidget );
+ * drag->addDragObject( new QImageDrag( someQImage, 0 ) );
+ * drag->addDragObject( new KURLDrag( someKURL, 0 ) );
+ * drag->drag();
+ * \endcode
+ *
+ * Note that the drag objects added to the multiple drag become owned by it.
+ * For that reason their parent should be 0.
+ *
+ * @author David Faure <[email protected]>
+ */
+class KDECORE_EXPORT KMultipleDrag : public QDragObject
+{
+ Q_OBJECT
+
+public:
+ /**
+ * Create a new KMultipleDrag object.
+ * @param dragSource the parent object which is the source of the data,
+ * 0 for a parent-less object
+ * @param name the name of the object, can be 0
+ */
+ KMultipleDrag( QWidget *dragSource = 0, const char *name = 0 );
+
+ /**
+ * Call this to add each underlying drag object to the multiple drag object.
+ * The drag object should not have a parent because the multiple drag object
+ * will own it.
+ *
+ * @param dragObject the drag object to add. Should have no parent object.
+ */
+ void addDragObject( QDragObject *dragObject );
+
+ /**
+ * Returns the data of a drag object with that supports the given
+ * mime type.
+ * @param mime the mime type to search
+ * @return the data, or a null byte array if not found
+ * @reimp
+ */
+ virtual QByteArray encodedData( const char *mime ) const;
+
+ /**
+ * Returns the @p i'th supported format, or 0.
+ * @param i the number of the format to check
+ * @return the format with the number @p i, or 0 otherwise
+ * @reimp
+ */
+ virtual const char* format( int i ) const;
+
+protected:
+// KDE4: make private
+ QPtrList<QDragObject> m_dragObjects;
+ QValueList<int> m_numberFormats;
+protected:
+ virtual void virtual_hook( int id, void* data );
+private:
+ KMultipleDragPrivate* d;
+};
+
+#endif // QT_NO_DRAGANDDROP
+
+#endif // KMULTIPLEDRAG_H