gpt4 book ai didi

android - Android Bottom Sheet 上的静态页脚 View

转载 作者:行者123 更新时间:2023-12-03 10:11:21 25 4
gpt4 key购买 nike

我正在尝试制作 静态页脚 在 Android 的 Bottom Sheet 上。下面是我当前尝试的 GIF。注意 footer完全展开时工作表底部的文本。我希望将此页脚文本发送到 总是 无论工作表处于何种状态都显示。(例如,如果工作表仅展开一半,页脚仍应显示。当工作表展开/折叠时,页脚仍应始终显示等)我该如何完成此行为?我看过这个:https://github.com/umano/AndroidSlidingUpPanel但我更愿意获得一个不涉及任何外部库的 Vanilla android 解决方案。

enter image description here

这是我当前的 XML。我认为问题在于页脚被锚定到 View 的底部,但 View 的底部只有在工作表完全展开时才可见。我想看看是否可以让页脚显示,而不管工作表的状态如何:

<?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.widget.CoordinatorLayout
xmlns:airbnb="http://schemas.android.com/apk/res-auto"
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:focusableInTouchMode="true"
android:orientation="vertical"
android:id="@+id/linear_layout_container">

<TextView
android:id="@+id/header_text"
android:layout_width="match_parent"
android:text="Header"
android:layout_height="36dp"
android:layout_alignParentTop="true"
/>

<com.airbnb.epoxy.EpoxyRecyclerView
android:id="@+id/bottom_sheet_recycler_view"
android:layout_width="match_parent"
android:layout_height="wrap_content"
airbnb:layoutManager="LinearLayoutManager"
android:layout_above="@+id/footer_text"
android:layout_below="@+id/header_text"
/>
<TextView
android:id="@+id/footer_text"
android:layout_width="match_parent"
android:text="Footer"
android:layout_height="36dp"
android:layout_alignParentBottom="true"
airbnb:layout_anchorGravity="bottom"
/>
</RelativeLayout>
</androidx.coordinatorlayout.widget.CoordinatorLayout>

这是我的 fragment 的样子。它只是一个显示 Bottom Sheet 的空白 fragment : ContainerFragment.kt

import android.os.Bundle
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import androidx.fragment.app.Fragment
import androidx.recyclerview.widget.LinearLayoutManager
import com.airbnb.epoxy.EpoxyRecyclerView
import com.google.android.material.bottomsheet.BottomSheetDialog

class ContainerFragment : Fragment() {


override fun onCreateView(
inflater: LayoutInflater, container: ViewGroup?,
savedInstanceState: Bundle?
): View? {
// Inflate the layout for this fragment
return inflater.inflate(R.layout.container_fragment_layout, container, false)
}

override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
super.onViewCreated(view, savedInstanceState)
view.alpha = 0f
val bottomSheet = BottomSheetDialog(requireContext())
val bottomSheetView = LayoutInflater.from(context).inflate(R.layout.test_bottom_sheet_layout, null)
bottomSheet.setContentView(bottomSheetView)
bottomSheet.show()
val epoxyRecyclerView : EpoxyRecyclerView = bottomSheetView.findViewById(R.id.bottom_sheet_recycler_view)
epoxyRecyclerView.layoutManager = LinearLayoutManager(context, LinearLayoutManager.VERTICAL, false)
epoxyRecyclerView.withModels {
(0..100).forEach {
basicRow {
id(it)
title("This is the entry at index $it.")
}
}
}
}
companion object {
fun newInstance() = ContainerFragment()
}
}

这是我的 fragment 布局: container_fragment_layout.xml :
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent">

</LinearLayout>

最佳答案

您需要以编程方式执行此操作,但它确实比看起来更简单。只需在 BottomSheet 滑动时调整 View 的位置。

  • 添加页脚 View 作为您的 Bottom Sheet 的直接子级

  • <androidx.coordinatorlayout.widget.CoordinatorLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <FrameLayout
    android:id="@+id/bottom_sheet"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#EECCCCCC"
    app:layout_behavior="com.google.android.material.bottomsheet.BottomSheetBehavior">

    <TextView
    android:id="@+id/pinned_bottom"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="#500000FF"
    android:padding="16dp"
    android:text="Bottom" />
    </FrameLayout>
    </androidx.coordinatorlayout.widget.CoordinatorLayout>
  • 添加 BottomSheetCallback并调整 translationY在 onSlide()

  • BottomSheetBehavior.from(bottom_sheet).addBottomSheetCallback(
    object : BottomSheetBehavior.BottomSheetCallback() {

    override fun onSlide(bottomSheet: View, slideOffset: Float) {
    val bottomSheetVisibleHeight = bottomSheet.height - bottomSheet.top

    pinned_bottom.translationY =
    (bottomSheetVisibleHeight - pinned_bottom.height).toFloat()
    }

    override fun onStateChanged(bottomSheet: View, newState: Int) {
    }
    })

    它运行顺利,因为您只是更改了翻译。

    您还可以使用此技术将 View 固定在 BottomSheet 的中心:

    pinned_center.translationY = (bottomSheetVisibleHeight - pinned_center.height) / 2f

    我在 GitHub 上创建了一个示例项目来重现这两个用例(固定在中间和底部): https://github.com/dadouf/BottomSheetGravity

    Demo

    关于android - Android Bottom Sheet 上的静态页脚 View ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58292471/

    25 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com