16
8

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

クラス名の文字列を使わずにDynamic Feature ModuleのActivityを呼び出す

Last updated at Posted at 2019-02-20

アプリケーションからDynamic Feature Module形式のモジュールに含まれるクラスは見えないので、Activityを呼び出す際には

app/src/main/java/com/example/app/MainActivity.kt
startActivity(
    Intent().setClassName(
        this,
        "com.example.dynamic_feature.DynamicFeatureActivity"
    )
)

のようにクラス名の文字列を指定することになりますが、補完が効かず、Activityのクラス名を変更した際に追随してくれません。
またNavigationでActivityへの遷移を定義している場合は、モジュールがインストールされていない状態だとアプリケーションがクラッシュしてしまいます。
これを何とかする方法です。

以下のコードはPlay Consoleのinternal test trackを使った検証はしていませんのでご注意下さい。

activity-aliasを使います。

まず、アプリケーション側で以下のようなsealed classを作ります。

app/src/main/java/com/example/app/ActivityAlias.kt
package com.example.app

import android.app.Activity

sealed class ActivityAlias : Activity()
sealed class DynamicFeatureActivityAlias : ActivityAlias()

ActiivtyAliasクラスがActivityを継承しているのは、Navigationのクラス存在チェックを回避するためです。
DynamicFeatureActivityAliasをsealed classとして定義しているのは、インスタンス化を防ぐためです。

さらに、ProGuard/R8でリネームされないように、アプリケーションのproguard-rules.proに以下の設定を追加しておきます。

app/proguard-rules.pro
-keep class * extends com.example.app.ActivityAlias

最後に、対象モジュールのAndroidManifest.xmlにactivity-aliasを追加し、上記で作成したDynamicFeatureActivityAliasのクラス名をandroid:nameに指定します。

dynamic_feature/src/main/AndroidManifest.xml
<activity-alias
    android:name="com.example.app.DynamicFeatureActivityAlias"
    android:targetActivity=".DynamicFeatureActivity" />

モジュールからアプリケーション側のクラスは見えるので、android:nameの値は補完が効き、クラス名の変更にも追随してくれます。

これで、以下のようにIntent(Context, Class)を使ってIntentを生成することができるようになります。

app/src/main/java/com/example/app/MainActivity.kt
startActivity(Intent(this, DynamicFeatureActivityAlias::class.java))

Nagivationを使う場合は、以下のようにandroid:nameにDynamicFeatureActivityAliasのクラス名を指定することができます。

app/src/main/res/navigation/nav_graph.xml
<activity
    android:id="@+id/dynamic_feature"
    android:name="com.example.app.DynamicFeatureActivityAlias" />

DynamicFeatureActivityAliasはActivityのサブクラスなので、エラーにはなりません。

以上です。

参考

マルチモジュールとNavigation
https://medium.com/@star_zero/%E3%83%9E%E3%83%AB%E3%83%81%E3%83%A2%E3%82%B8%E3%83%A5%E3%83%BC%E3%83%AB%E3%81%A8navigation-c7aaffbfd76

16
8
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
16
8

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?