【发布时间】:2022-01-13 15:44:04
【问题描述】:
我有一个包含谷歌地图视图的组合。当我点击地图上的一个图钉时,我想触发navController.navigate,这样我就可以导航到另一个可组合项。但是,当我调用它时,应用程序会卡住而不是导航。点击按钮导航按预期工作。
我还创建了一个非常简单的应用程序来演示这个问题。 MainActivity 看起来像这样:
class MainActivity : ComponentActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContent {
val navController = rememberNavController()
NavHost(navController = navController, startDestination = "Screen1") {
composable("Screen1") {
Button({ navController.navigate("MapsScreen") }) {
Text(text = "Go to Maps")
}
}
composable("MapsScreen") {
val mapView = rememberMapViewWithLifecycle()
AndroidView({ mapView }) { mapView ->
mapView.getMapAsync { map ->
map.setOnInfoWindowClickListener {
navController.navigate("Screen1")
}
val markerOptions = MarkerOptions()
.position(LatLng(41.390205, 2.154007))
.title("Barcelona")
map.addMarker(markerOptions)!!
}
}
}
}
}
}
}
@Composable
fun rememberMapViewWithLifecycle(): MapView {
val context = LocalContext.current
val mapView = remember {
MapView(context).apply {
id = R.id.map
}
}
val lifecycle = LocalLifecycleOwner.current.lifecycle
DisposableEffect(lifecycle, mapView) {
// Make MapView follow the current lifecycle
val lifecycleObserver = getMapLifecycleObserver(mapView)
lifecycle.addObserver(lifecycleObserver)
onDispose {
lifecycle.removeObserver(lifecycleObserver)
}
}
return mapView
}
private fun getMapLifecycleObserver(mapView: MapView): LifecycleEventObserver =
LifecycleEventObserver { _, event ->
when (event) {
Lifecycle.Event.ON_CREATE -> mapView.onCreate(Bundle())
Lifecycle.Event.ON_START -> mapView.onStart()
Lifecycle.Event.ON_RESUME -> mapView.onResume()
Lifecycle.Event.ON_PAUSE -> mapView.onPause()
Lifecycle.Event.ON_STOP -> mapView.onStop()
Lifecycle.Event.ON_DESTROY -> mapView.onDestroy()
else -> throw IllegalStateException()
}
}
在项目中,我使用androidx.navigation:navigation-compose:2.4.0-beta02,根据documentation,这是目前的最新版本。
完整的项目可在Github获得
作为我使用的示例的灵感: Using Google Maps in a Jetpack Compose app 和 Crane Sample
可能是什么问题以及如何解决?
【问题讨论】:
-
当通过在 AndroidView 中添加 android.widget.Button 而不是地图导航来完成相同的实验时,请参阅同一存储库中的分支按钮以获取更多详细信息。
标签: android google-maps-android-api-2 android-jetpack-compose