aboutsummaryrefslogtreecommitdiffstats
path: root/src/quick
diff options
context:
space:
mode:
authorAleix Pol <aleixpol@kde.org>2015-05-23 14:10:36 +0200
committerSimon Hausmann <simon.hausmann@theqtcompany.com>2015-05-23 13:52:36 +0000
commitdad48f0e9cca10528fcaab7ec7d08f678e81b1a9 (patch)
treeb2673ae09e2a5d1399e4bdbe266885fec3f35bcc /src/quick
parent1ebee6e995541554aa9250ccf3326d2579c237c6 (diff)
Makes it possible to extract all data from a QML DropArea
There's many types that aren't being covered by DropArea API, such as images. getDataAsString is not acceptable, since fromUtf8 chokes on reading non-utf8. This patch introduces getDataAsArrayBuffer method that won't try to convert the data into a QString and simply pass a QV4::ArrayBuffer, that internally keeps a QByteArray. Change-Id: I65411b3d365ee6c5e13effd9167156771ee08a05 Reviewed-by: Simon Hausmann <simon.hausmann@theqtcompany.com>
Diffstat (limited to 'src/quick')
-rw-r--r--src/quick/items/qquickdroparea.cpp20
-rw-r--r--src/quick/items/qquickdroparea_p.h1
2 files changed, 21 insertions, 0 deletions
diff --git a/src/quick/items/qquickdroparea.cpp b/src/quick/items/qquickdroparea.cpp
index 217b455d43..e46d546a16 100644
--- a/src/quick/items/qquickdroparea.cpp
+++ b/src/quick/items/qquickdroparea.cpp
@@ -36,6 +36,7 @@
#include "qquickitem_p.h"
#include "qquickwindow.h"
+#include <private/qv4arraybuffer_p.h>
#include <private/qqmlengine_p.h>
#ifndef QT_NO_DRAGANDDROP
@@ -496,6 +497,14 @@ void QQuickDropArea::dropEvent(QDropEvent *event)
Returns the data for the given \a format converted to a string. \a format should be one contained in the \l formats property.
*/
+/*!
+ \qmlmethod string QtQuick::DragEvent::getDataAsArrayBuffer(string format)
+ \since 5.5
+
+ Returns the data for the given \a format into an ArrayBuffer, which can
+ easily be translated into a QByteArray. \a format should be one contained in the \l formats property.
+*/
+
QObject *QQuickDropEvent::source()
{
if (const QQuickDragMimeData *dragMime = qobject_cast<const QQuickDragMimeData *>(event->mimeData()))
@@ -566,6 +575,17 @@ void QQuickDropEvent::getDataAsString(QQmlV4Function *args)
}
}
+void QQuickDropEvent::getDataAsArrayBuffer(QQmlV4Function *args)
+{
+ if (args->length() != 0) {
+ QV4::ExecutionEngine *v4 = args->v4engine();
+ QV4::Scope scope(v4);
+ QV4::ScopedValue v(scope, (*args)[0]);
+ const QString format = v->toQString();
+ args->setReturnValue(v4->newArrayBuffer(event->mimeData()->data(format))->asReturnedValue());
+ }
+}
+
void QQuickDropEvent::acceptProposedAction(QQmlV4Function *)
{
event->acceptProposedAction();
diff --git a/src/quick/items/qquickdroparea_p.h b/src/quick/items/qquickdroparea_p.h
index e35ec40757..3223f4203b 100644
--- a/src/quick/items/qquickdroparea_p.h
+++ b/src/quick/items/qquickdroparea_p.h
@@ -96,6 +96,7 @@ public:
QStringList formats() const;
Q_INVOKABLE void getDataAsString(QQmlV4Function *);
+ Q_INVOKABLE void getDataAsArrayBuffer(QQmlV4Function *);
Q_INVOKABLE void acceptProposedAction(QQmlV4Function *);
Q_INVOKABLE void accept(QQmlV4Function *);