aboutsummaryrefslogtreecommitdiffstats
path: root/examples/androidextras/services/servicebroadcast/doc/src/qtandroidextras-example-service-broadcastreceiver.qdoc
diff options
context:
space:
mode:
Diffstat (limited to 'examples/androidextras/services/servicebroadcast/doc/src/qtandroidextras-example-service-broadcastreceiver.qdoc')
-rw-r--r--examples/androidextras/services/servicebroadcast/doc/src/qtandroidextras-example-service-broadcastreceiver.qdoc152
1 files changed, 152 insertions, 0 deletions
diff --git a/examples/androidextras/services/servicebroadcast/doc/src/qtandroidextras-example-service-broadcastreceiver.qdoc b/examples/androidextras/services/servicebroadcast/doc/src/qtandroidextras-example-service-broadcastreceiver.qdoc
new file mode 100644
index 0000000..781f95a
--- /dev/null
+++ b/examples/androidextras/services/servicebroadcast/doc/src/qtandroidextras-example-service-broadcastreceiver.qdoc
@@ -0,0 +1,152 @@
+/****************************************************************************
+**
+** 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$
+**
+****************************************************************************/
+
+/*!
+ \title Android Service with BroadcastReceiver
+ \ingroup examples-qtandroidextras
+ \example services/servicebroadcast
+ \brief Demonstrates how to run an Android service in a separate process using
+ a separate .so lib file, and how to communicate with Qt using a BroadcastReceiver.
+
+ \image androidservices.png
+
+ This example demonstrates how to create and run an Android service in a
+ separate process that uses a separate \c .so lib file, and then exchange data
+ between QML/C++ and the Java service using a
+ \l{Android: BroadcastReceiver}{BroadcastReceiver}.
+
+ When clicking the \uicontrol {Send to Service} button, the name entered in the QML
+ view, Qt, in this case, is sent to the Android service. Then, the service
+ replies back with a message \c {Hello Qt} which is printed in the QML view.
+
+ \include examples-run.qdocinc
+
+ \section1 Create the Service
+
+ When running the app's process, you can extend either \c QtService or \c Service.
+ Extending \c QtService allows Qt to load all the necessary libraries to load
+ Qt components correctly and call native methods on Android. However, here
+ the service is running in the same process, and with the BroadcastReceiver
+ you don't need native calls to exchange messages with Qt, so extending either
+ class works.
+
+ Start by creating the Java service class. This is a normal Android \c Service
+ that receives a name from QML and replies back with \c {Hello <name>}:
+
+ \quotefromfile services/servicebroadcast/android/src/org/qtproject/example/qtandroidservice/QtAndroidService.java
+ \skipto package
+ \printuntil /^\}/
+
+ In the owerwritten method
+ \l{Android: Service onStartCommand}{onStartCommand()}, the service receives
+ a name from the calling intent, then sends a broadcast to the BroadcastReceiver,
+ which in turn will call the native method \c {sendToQt(String message)}. For
+ more information on managing native calls in Qt, see
+ \l{Calling QML/C++ Functions from Java Code}.
+
+ Since the service is run on a separate \c .so lib file, you must create a
+ sub-project for the service process which uses \l{QAndroidService}. Start
+ with a \c .pro file as follows:
+
+ \quotefromfile services/servicebroadcast/service.pro
+ \printuntil service_main
+
+ Then, create the file \c service_main.cpp:
+
+ \quotefromfile services/servicebroadcast/service_main.cpp
+ \skipto include
+ \printuntil /^\}/
+
+ \section1 Manage the AndroidManifest.xml File
+
+ To use the service, it must be declared in the \c AndroidManifest.xml
+ file:
+
+ \quotefromfile services/servicebroadcast/android/AndroidManifest.xml
+ \skipto <service
+ \printuntil </service>
+
+ \section1 Start the Service
+
+ Take the following steps to set up and start the service:
+
+ \list 1
+ \li Register the native method
+
+ \li Create the BroadcastReceiver in a custom Java class:
+
+ \quotefromfile services/servicebroadcast/android/src/org/qtproject/example/qtandroidservice/ActivityUtils.java
+ \skipto package
+ \printuntil /^\}/
+
+ \li Register the BroadcastReceiver:
+
+ \quotefromfile services/common/qtandroidservice.cpp
+ \skipto :registerBroadcastReceiver
+ \printuntil /^\}/
+
+ \li Call the \l{Android: Service startService}{startService()}
+ method, as follows:
+
+ \quotefromfile services/common/qtandroidservice.cpp
+ \skipto sendToService
+ \printuntil /^\}/
+
+ This function is used to start the Service. If the service is already running,
+ it will only send the names without starting a new service instance.
+
+ \li Then, you have to add the necessary \l Connections, as described in
+ \l{Qt JNI Messenger}{Qt JNI Messenger Example}.
+
+ \endlist
+
+ \sa {Android Service with BroadcastReceiver - Same Lib File},
+ {Android Services}, {Qt for Android}, {Qt Android Extras}
+*/