Android Weekly Notes #473 Android Weekly Issue #473

Android Weekly Issue #473

Debugging Story: The Case of Rogue Reflection

一個和反射相關的問題的追蹤過程.

Kotlin Multiplatform Mobile Codelab

KMP的codelab.

Creating a retro-style game with Jetpack Compose

復古風的遊戲.

Scalable Jetpack Compose Navigation

如何擴展Jetpack Compose的Navigation.

定義一個navigation的factory:

// An interface is created to allow a feature module to add their Composable to the NavGraph.
// Defined within a library module
interface ComposeNavigationFactory {
  fun create(builder: NavGraphBuilder, navController: NavHostController)
}

然後每個feature實現它:

// An implementation of the interface, as well as a Dagger 2 module installed via hilt.
// Defined within a feature module
internal class Feature1ComposeNavigationFactory @Inject constructor() : ComposeNavigationFactory {
  override fun create(builder: NavGraphBuilder, navController: NavHostController) {
    builder.composable(
      route = "feature1",
      content = {
        Feature1(
          navController = navController
        )
      }
    )
  }
}

// Defined within the 'feature 1' module
@Module
@InstallIn(SingletonComponent::class)
internal interface ComposeNavigationFactoryModule {
  @Singleton
  @Binds
  @IntoSet
  fun bindComposeNavigationFactory(factory: Feature1ComposeNavigationFactory): ComposeNavigationFactory
}

最後注入:

// An example of a set of factories being used to construct a NavHost.
// Potentially defined within the app module
@AndroidEntryPoint
class ExampleActivity: AppCompatActivity {
  @Inject
  lateinit var composeNavigationFactories: @JvmSuppressWildcards Set<ComposeNavigationFactory>

  @Composable
  fun JetpackNavigationHiltApp() {
    val navController = rememberNavController()

    NavHost(navController, startDestination = "feature1") {
      composeNavigationFactories.forEach { factory ->
        factory.create(this, navController)
      }
    }
  }
}

作者把這個搞了個庫:
https://github.com/LachlanMcKee/Hilt-Compose-Navigation-Factory

還有其他方案比如: https://github.com/zsoltk/compose-router

Providing AssistedInject supported ViewModel for Composable using Hilt

AssistedInject: 處理有一些參數需要運行時提供.

在composable裏需要藉助EntryPoint這樣搞一波:

@Composable
fun noteDetailViewModel(noteId: String): NoteDetailViewModel {
    val factory = EntryPointAccessors.fromActivity(
        LocalContext.current as Activity,
        MainActivity.ViewModelFactoryProvider::class.java
    ).noteDetailViewModelFactory()

    return viewModel(factory = NoteDetailViewModel.provideFactory(factory, noteId))
}

用的時候:

NavHost(navController, startDestination = Screen.Notes.route, route = NOTY_NAV_HOST_ROUTE) {
    composable(
        Screen.NotesDetail.route,
        arguments = listOf(navArgument(Screen.NotesDetail.ARG_NOTE_ID) { type = NavType.StringType })
    ) {
        val noteId = it.arguments?.getString(Screen.NotesDetail.ARG_NOTE_ID)!!
        NoteDetailsScreen(navController, noteDetailViewModel(noteId))
    }
}

底部是一個全kotlin技術棧的應用:
https://github.com/PatilShreyas/NotyKT

Two-way communication without internet: Nearby Connections (Part 2 of 3)

利用Nearby API, 沒網的時候也可以通信.

Using Composition in Kotlin

在kotlin中使用組合.

Advanced Usage of WorkManager in multi-process apps

WorkManager多進程的例子:
https://github.com/android/architecture-components-samples/tree/main/WorkManagerMultiprocessSample

Scope Storage Myths

Android 11之後, 如果app不訪問別的app擁有的文件, 則不需要請求READ_EXTERNAL_STORAGE權限.

還可以這樣:

<uses-permission
    android:name="android.permission.READ_EXTERNAL_STORAGE"
    android:maxSdkVersion="29" />

Refactoring Kotlin type-signatures for fun and profit

https://www.http4k.org/

Compose: Strikethru Animation

一個icon的動畫.

Browsing Jetpack Compose samples

看Jetpack Compose Sample的方法.

有一個Android Code Search的網站:
https://cs.android.com/

有一個code search plugin:
https://plugins.jetbrains.com/plugin/12578-codesearch

源碼:
https://github.com/guojianhua/code-search

Code

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章