From 174da8f65245ae4f9333dc169d60fbdf3003f1ea Mon Sep 17 00:00:00 2001 From: Assam Boudjelthia Date: Tue, 5 May 2020 17:28:18 +0300 Subject: Add example to show how to work with activities and handle their result Task-number: QTBUG-83038 Change-Id: I87a631551c3c6fbb22eaaf56acad6b8ae87f4560 Reviewed-by: Tarja Sundqvist Reviewed-by: BogDan Vatra (cherry picked from commit 85b2ea13da75303371ef8f82d5c0a079fa437904) Reviewed-by: Ville Voutilainen --- examples/androidextras/androidextras.pro | 6 +- .../customactivity/activityhandler.cpp | 88 ++++++++++++++ .../androidextras/customactivity/activityhandler.h | 73 +++++++++++ .../customactivity/android/AndroidManifest.xml | 92 ++++++++++++++ .../android/res/layout/second_activity.xml | 26 ++++ .../customactivity/android/res/values/strings.xml | 6 + .../example/activityhandler/CustomActivity.java | 78 ++++++++++++ .../customactivity/customactivity.pro | 27 +++++ .../qtandroidextras-example-customactivity.qdoc | 134 +++++++++++++++++++++ examples/androidextras/customactivity/main.cpp | 74 ++++++++++++ examples/androidextras/customactivity/main.qml | 84 +++++++++++++ examples/androidextras/customactivity/qml.qrc | 5 + src/androidextras/doc/images/customactivity.png | Bin 0 -> 39727 bytes 13 files changed, 691 insertions(+), 2 deletions(-) create mode 100644 examples/androidextras/customactivity/activityhandler.cpp create mode 100644 examples/androidextras/customactivity/activityhandler.h create mode 100644 examples/androidextras/customactivity/android/AndroidManifest.xml create mode 100644 examples/androidextras/customactivity/android/res/layout/second_activity.xml create mode 100644 examples/androidextras/customactivity/android/res/values/strings.xml create mode 100644 examples/androidextras/customactivity/android/src/org/qtproject/example/activityhandler/CustomActivity.java create mode 100644 examples/androidextras/customactivity/customactivity.pro create mode 100644 examples/androidextras/customactivity/doc/src/qtandroidextras-example-customactivity.qdoc create mode 100644 examples/androidextras/customactivity/main.cpp create mode 100644 examples/androidextras/customactivity/main.qml create mode 100644 examples/androidextras/customactivity/qml.qrc create mode 100644 src/androidextras/doc/images/customactivity.png diff --git a/examples/androidextras/androidextras.pro b/examples/androidextras/androidextras.pro index 80d1186..4ac3b2d 100644 --- a/examples/androidextras/androidextras.pro +++ b/examples/androidextras/androidextras.pro @@ -5,11 +5,13 @@ android { SUBDIRS += \ notification \ jnimessenger \ - services + services \ + customactivity EXAMPLE_FILES += \ notification \ jnimessenger \ - services + services \ + customactivity } } diff --git a/examples/androidextras/customactivity/activityhandler.cpp b/examples/androidextras/customactivity/activityhandler.cpp new file mode 100644 index 0000000..2d7b172 --- /dev/null +++ b/examples/androidextras/customactivity/activityhandler.cpp @@ -0,0 +1,88 @@ +/**************************************************************************** +** +** Copyright (C) 2020 The Qt Company Ltd. +** Contact: https://www.qt.io/licensing/ +** +** This file is part of the QtAndroidExtras module of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:BSD$ +** Commercial License Usage +** Licensees holding valid commercial Qt licenses may use this file in +** accordance with the commercial license agreement provided with the +** Software or, alternatively, in accordance with the terms contained in +** a written agreement between you and The Qt Company. For licensing terms +** and conditions see https://www.qt.io/terms-conditions. For further +** information use the contact form at https://www.qt.io/contact-us. +** +** BSD License Usage +** Alternatively, you may use this file under the terms of the BSD license +** as follows: +** +** "Redistribution and use in source and binary forms, with or without +** modification, are permitted provided that the following conditions are +** met: +** * Redistributions of source code must retain the above copyright +** notice, this list of conditions and the following disclaimer. +** * Redistributions in binary form must reproduce the above copyright +** notice, this list of conditions and the following disclaimer in +** the documentation and/or other materials provided with the +** distribution. +** * Neither the name of The Qt Company Ltd nor the names of its +** contributors may be used to endorse or promote products derived +** from this software without specific prior written permission. +** +** +** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE." +** +** $QT_END_LICENSE$ +** +****************************************************************************/ +#include "activityhandler.h" + +#include + +const int REQUEST_CODE = 123; +const jint RESULT_OK = QAndroidJniObject::getStaticField("android/app/Activity", "RESULT_OK"); +ActivityHandler *ActivityHandler::m_instance = nullptr; + +ActivityHandler::ActivityHandler(QObject *parent) : QObject(parent) +{ + m_instance = this; +} + +void ActivityHandler::showSecondActivity() +{ + QAndroidIntent activityIntent(QtAndroid::androidActivity().object(), + "org/qtproject/example/activityhandler/CustomActivity"); + + QtAndroid::startActivity( + activityIntent.handle(), REQUEST_CODE, + [this](int requestCode, int resultCode, const QAndroidJniObject &data) { + activityReceiver(requestCode, resultCode, data); + }); +} + +void ActivityHandler::activityReceiver(int requestCode, int resultCode, const QAndroidJniObject &data) +{ + if (requestCode == REQUEST_CODE) { + if (resultCode == RESULT_OK) { + const QAndroidJniObject key = QAndroidJniObject::fromString("message"); + const QAndroidJniObject message = data.callObjectMethod( + "getStringExtra", "(Ljava/lang/String;)Ljava/lang/String;", key.object()); + if (message.isValid()) + emit ActivityHandler::instance()->receiveFromActivityResult(message.toString()); + } else { + emit ActivityHandler::instance()->receiveFromActivityResult("Rejected!"); + } + } +} diff --git a/examples/androidextras/customactivity/activityhandler.h b/examples/androidextras/customactivity/activityhandler.h new file mode 100644 index 0000000..3dba71e --- /dev/null +++ b/examples/androidextras/customactivity/activityhandler.h @@ -0,0 +1,73 @@ +/**************************************************************************** +** +** Copyright (C) 2020 The Qt Company Ltd. +** Contact: https://www.qt.io/licensing/ +** +** This file is part of the QtAndroidExtras module of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:BSD$ +** Commercial License Usage +** Licensees holding valid commercial Qt licenses may use this file in +** accordance with the commercial license agreement provided with the +** Software or, alternatively, in accordance with the terms contained in +** a written agreement between you and The Qt Company. For licensing terms +** and conditions see https://www.qt.io/terms-conditions. For further +** information use the contact form at https://www.qt.io/contact-us. +** +** BSD License Usage +** Alternatively, you may use this file under the terms of the BSD license +** as follows: +** +** "Redistribution and use in source and binary forms, with or without +** modification, are permitted provided that the following conditions are +** met: +** * Redistributions of source code must retain the above copyright +** notice, this list of conditions and the following disclaimer. +** * Redistributions in binary form must reproduce the above copyright +** notice, this list of conditions and the following disclaimer in +** the documentation and/or other materials provided with the +** distribution. +** * Neither the name of The Qt Company Ltd nor the names of its +** contributors may be used to endorse or promote products derived +** from this software without specific prior written permission. +** +** +** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE." +** +** $QT_END_LICENSE$ +** +****************************************************************************/ +#ifndef MULTIACTIVITY_H +#define MULTIACTIVITY_H + +#include + +class ActivityHandler : public QObject +{ + Q_OBJECT + +public: + ActivityHandler(QObject *parent = nullptr); + static ActivityHandler *instance() { return m_instance; } + + Q_INVOKABLE void showSecondActivity(); + void activityReceiver(int requestCode, int resultCode, const QAndroidJniObject &data); + +signals: + void receiveFromActivityResult(const QString &message); + +private: + static ActivityHandler *m_instance; +}; + +#endif // MULTIACTIVITY_H diff --git a/examples/androidextras/customactivity/android/AndroidManifest.xml b/examples/androidextras/customactivity/android/AndroidManifest.xml new file mode 100644 index 0000000..c78a9f4 --- /dev/null +++ b/examples/androidextras/customactivity/android/AndroidManifest.xml @@ -0,0 +1,92 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/examples/androidextras/customactivity/android/res/layout/second_activity.xml b/examples/androidextras/customactivity/android/res/layout/second_activity.xml new file mode 100644 index 0000000..0c07790 --- /dev/null +++ b/examples/androidextras/customactivity/android/res/layout/second_activity.xml @@ -0,0 +1,26 @@ + + + + + +