[英]Fragment Container in Jetpack Compose
我想使用Jetpack Compose开发单个 Activity 多片段应用程序。 对于 recyclerView,我们有 Vertical 和 HorizontalScroller。 但是,对于片段我应该使用什么。
fun loadFragment(fragment: Fragment) {
val transaction:FragmentTransaction = supportFragmentManager.beginTransaction()
transaction.replace(R.id.f_container, fragment)
transaction.addToBackStack(null)
transaction.commit()
}
在这种情况下,我没有 R.id.f_container 因为我只使用 compose 创建 UI。
<FrameLayout
android:id="@+id/f_container"
android:layout_width="match_parent"
android:layout_height="match_parent"`enter code here`
app:layout_behavior="@string/appbar_scrolling_view_behavior"
app:layout_constraintEnd_toEndOf="parent"
tools:layout_editor_absoluteY="-56dp">
</FrameLayout>
您可以创建自己的 @Composable FragmentContainer 函数
@Composable
fun FragmentContainer(
modifier: Modifier = Modifier,
fragmentManager: FragmentManager,
commit: FragmentTransaction.(containerId: Int) -> Unit
) {
val containerId by rememberSaveable { mutableStateOf(View.generateViewId()) }
var initialized by rememberSaveable { mutableStateOf(false) }
AndroidView(
modifier = modifier,
factory = { context ->
FragmentContainerView(context)
.apply { id = containerId }
},
update = { view ->
if (!initialized) {
fragmentManager.commit { commit(view.id) }
initialized = true
} else {
fragmentManager.onContainerAvailable(view)
}
}
)
}
/** Access to package-private method in FragmentManager through reflection */
private fun FragmentManager.onContainerAvailable(view: FragmentContainerView) {
val method = FragmentManager::class.java.getDeclaredMethod(
"onContainerAvailable",
FragmentContainerView::class.java
)
method.isAccessible = true
method.invoke(this, view)
}
然后在活动中使用它
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContent {
FragmentContainer(
modifier = Modifier.fillMaxSize(),
fragmentManager = supportFragmentManager,
commit = { add(it, YourFragment()) }
)
}
}
或在片段中
override fun onCreateView(
inflater: LayoutInflater,
container: ViewGroup?,
savedInstanceState: Bundle?
): View = ComposeView(requireContext()).apply {
setContent {
FragmentContainer(
modifier = Modifier.fillMaxSize(),
fragmentManager = parentFragmentManager,
commit = { add(it, YourNestedFragment()) }
)
}
}
我不建议您重用现有的片段,而是尝试回收其内部视图以创建新的可组合。
无论如何,如果您想玩得开心,这是一个可能的解决方案:
AndroidView(
modifier = Modifier
.fillMaxHeight()
.fillMaxWidth(),
factory = { context ->
FrameLayout(context).apply {
FragmentBlankBinding.inflate(LayoutInflater.from(context), this, true).root
}
})
享受!
如果您正在创建一个新应用程序,您可以完全跳过使用 Fragments,而只使用可组合函数来表示您的屏幕。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.