QAndroidApplication Struct

struct QNativeInterface::QAndroidApplication

Androidのコア・アプリケーションのネイティブ・インターフェース。詳細...

Header: #include <QCoreApplication>
CMake: find_package(Qt6 REQUIRED COMPONENTS Core)
target_link_libraries(mytarget PRIVATE Qt6::Core)
qmake: QT += core
Since: Qt 6.2

静的パブリックメンバー

(since 6.2) QJniObject context()
(since 6.2) void hideSplashScreen(int duration = 0)
(since 6.2) bool isActivityContext()
(since 6.2) QFuture<QVariant> runOnAndroidMainThread(const std::function<QVariant ()> &runnable, const QDeadlineTimer timeout = QDeadlineTimer::Forever)
(since 6.2) int sdkVersion()

詳細説明

QCoreApplication::nativeInterface() からアクセスします。

メンバー関数ドキュメント

[static, since 6.2] QJniObject QAndroidApplication::context()

Android コンテキストをQJniObject として返します。 直近に開始されたアクティビティオブジェクトが有効な場合、コンテキストはActivity です。そうでない場合、コンテキストはService です。

この関数は Qt 6.2 で導入されました。

[static, since 6.2] void QAndroidApplication::hideSplashScreen(int duration = 0)

与えられたduration のフェード効果を使用して、スプラッシュ画面を隠します。duration が提供されない場合(デフォルトは 0)、スプラッシュスクリーンはアプリの開始直後に非表示になります。

この関数は Qt 6.2 で導入されました。

[static, since 6.2] bool QAndroidApplication::isActivityContext()

QAndroidApplication::context() がActivity コンテキストを提供する場合、true を返します。

この関数は Qt 6.2 で導入されました。

[static, since 6.2] QFuture<QVariant> QAndroidApplication::runOnAndroidMainThread(const std::function<QVariant ()> &runnable, const QDeadlineTimer timeout = QDeadlineTimer::Forever)

Android スレッドに関数runnable をポストします。関数はキューに入れられ、Android UIスレッドで実行されます。呼び出しがAndroid UIスレッドで行われた場合、runnable 、直ちに実行されます。Androidアプリが一時停止しているか、メイン・アクティビティがNULLの場合、runnable 、Androidメイン・スレッドのキューに追加されます。

この呼び出しは、QFuture<QVariant>を返すので、同期呼び出しと非同期呼び出しの両方が可能で、どんな戻り値の型も扱える。ただし、QFuture::result ()から結果を返すには、QVariant::value ()を使用する必要がある。

runnable の実行がtimeout の期間よりも長い場合、QFuture::waitForFinished ()とQFuture::result ()のブロック呼び出しは、timeout が経過した時点で終了する。ただし、runnable がすでに実行を開始している場合は、キャンセルされない。

以下の例では、戻り値を期待する非同期呼び出しの実行方法を示す:

auto task = QNativeInterface::QAndroidApplication::runOnAndroidMainThread([=]() {
    QJniObject surfaceView;
    if (!surfaceView.isValid())
        qDebug() << "SurfaceView object is not valid yet";

    surfaceView = QJniObject("android/view/SurfaceView",
                             "(Landroid/content/Context;)V",
                             QNativeInterface::QAndroidApplication::context());

    return QVariant::fromValue(surfaceView);
}).then([](QFuture<QVariant> future) {
    auto surfaceView = future.result().value<QJniObject>();
    if (surfaceView.isValid())
        qDebug() << "Retrieved SurfaceView object is valid";
});

次の例は、戻り値の型がvoidの同期呼び出しの実行方法を示している:

QNativeInterface::QAndroidApplication::runOnAndroidMainThread([]() {
   QJniObject activity = QNativeInterface::QAndroidApplication::context();
   // Hide system ui elements or go full screen
   activity.callObjectMethod("getWindow", "()Landroid/view/Window;")
           .callObjectMethod("getDecorView", "()Landroid/view/View;")
           .callMethod<void>("setSystemUiVisibility", "(I)V", 0xffffffff);
}).waitForFinished();

注意: Androidのメインスレッドで行う操作の種類には注意してください。長い操作はアプリのUIレンダリングや入力処理をブロックする可能性があります。関数の実行時間が長くなることが予想される場合は、runnableQDeadlineTimer を使用して実行を管理し、UIスレッドをブロックしないようにするのもよいでしょう。通常、5秒以上の操作はアプリのUIをブロックする可能性があります。詳しくは、Keeping your app responsiveを参照してください。

この関数はQt 6.2で導入されました。

[static, since 6.2] int QAndroidApplication::sdkVersion()

Android SDKのバージョンを返します。これは API レベルとしても知られています。

この関数は Qt 6.2 で導入されました。

©2024 The Qt Company Ltd. 本文書に含まれる文書の著作権は、それぞれの所有者に帰属します。 本書で提供されるドキュメントは、Free Software Foundation が発行したGNU Free Documentation License version 1.3に基づいてライセンスされています。 Qtおよびそれぞれのロゴは、フィンランドおよびその他の国におけるThe Qt Company Ltd.の 商標です。その他すべての商標は、それぞれの所有者に帰属します。