共享内容重叠底部导航
Posted
技术标签:
【中文标题】共享内容重叠底部导航【英文标题】:Shared Content overlapping Bottom Navigation 【发布时间】:2019-05-06 18:52:58 【问题描述】:我的 MainActivity 有一个 RecyclerView 和一个 BottomNavigationView。 RecyclerView 中的项目是 CardViews。
当我单击一个被 BottomNavigationView 遮住一半的项目时(- 将其称为 BNV),它“弹出”在 BNV 上方,然后向上滑动成为 LaunchedActivity 中的标题。
退出 LaunchedActivity 时,它会向下滑动,越过 BNV,然后“弹”回原位:
我该怎么做:
-
让共享内容似乎从 BNV 下方滑出,
或失败,
让共享内容一开始是不可见的,然后在滑到标题时淡出
我尝试过使用 BNV 的高度,我尝试将 sharedElementEnterTransition 设置为 Fade(),我尝试使用 BottomNavigation 指定 excludeTarget;我似乎无法按照自己的意愿进行操作。
这是 MainActivity 的布局:
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_
android:layout_
tools:context=".MainActivity">
<android.support.v7.widget.RecyclerView
android:id="@+id/rv"
android:layout_
android:layout_
android:layout_marginStart="8dp"
android:layout_marginEnd="8dp"
android:layout_marginTop="8dp"
android:layout_marginBottom="8dp"
app:layout_constraintBottom_toTopOf="@+id/bottomNavigationView"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintStart_toStartOf="parent"
/>
<android.support.design.widget.BottomNavigationView
android:id="@+id/bottomNavigationView"
android:layout_
android:layout_
app:menu="@menu/navigation"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
/>
</android.support.constraint.ConstraintLayout>
Activity_launched 在这里:
<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_
android:layout_
tools:context=".LaunchedActivity">
<android.support.design.widget.AppBarLayout
android:layout_
android:layout_
android:theme="@style/AppTheme.AppBarOverlay">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_
android:layout_
android:background="?attr/colorPrimary"
app:popupTheme="@style/AppTheme.PopupOverlay"/>
</android.support.design.widget.AppBarLayout>
<include layout="@layout/content_launched"/>
<android.support.design.widget.FloatingActionButton
android:id="@+id/fab"
android:layout_
android:layout_
android:layout_gravity="bottom|end"
android:layout_margin="@dimen/fab_margin"
app:srcCompat="@android:drawable/ic_dialog_email"/>
</android.support.design.widget.CoordinatorLayout>
和 content_launched:
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_
android:layout_
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:showIn="@layout/activity_launched"
tools:context=".LaunchedActivity">
<LinearLayout
android:id="@+id/launched_header"
android:transitionName="header" android:layout_ android:layout_
app:layout_constraintTop_toTopOf="parent" app:layout_constraintStart_toStartOf="parent"
android:orientation="vertical" app:layout_constraintEnd_toEndOf="parent"
android:background="@android:color/holo_blue_bright"
android:layout_marginEnd="8dp">
<TextView
android:text="TextView"
android:layout_
android:layout_
android:layout_gravity="center"
android:id="@+id/launched_title"/>
<TextView
android:text="TextView"
android:layout_
android:layout_
android:layout_gravity="center"
android:id="@+id/launched_text"/>
</LinearLayout>
</android.support.constraint.ConstraintLayout>
RecyclerView 中的项目调用 MainActivity.onItemClicked:
fun onItemClicked(view: View, item: Item)
val intent = Intent(applicationContext, LaunchedActivity::class.java)
intent.putExtra("ITEM", item)
val options = ActivityOptions.makeSceneTransitionAnimation(
this,
android.util.Pair<View, String>(view, "header")
)
startActivity(intent, options.toBundle())
这是回收器中的数组:
data class Item(val title: String, val text: String): Serializable
val itemList = listOf(Item("One", "1"), Item("Two", "2"),
Item("Three", "3"), Item("Four", "4"), Item("Five", "5"))
最后,这是来自 LaunchedActivity.onCreate:
with(window)
requestFeature(Window.FEATURE_CONTENT_TRANSITIONS)
requestFeature(Window.FEATURE_ACTIVITY_TRANSITIONS)
sharedElementEnterTransition = AutoTransition()
sharedElementExitTransition = AutoTransition()
LaunchedActivity.onCreate 将项目拉出意图并设置launch_title 和launched_text。
【问题讨论】:
你能分享你的布局和点击代码 在recyclerview和底部导航之间留出余量。同时分享您的布局和活动代码。 我添加了布局和代码 我确定原因在 ActivityOptions.makeSceneTransitionAnimation 中,因为如果我没记错的话,它会渲染为叠加层......所以它总是在所有内容之上 【参考方案1】:添加recyclerView的item的CardView
app:cardMaxElevation="8dp"
并提供您的 BNV
app:elevation="16dp"
试一试,尝试更多的海拔差异,因为点击的卡片视图比实际海拔更高
【讨论】:
我仍然得到相同的效果:该卡之前在 BNV 上方弹出,之后又弹回。 @brismith 尝试在此编写 bottomNavigationView?.bringtoFront() - 有趣的 onItemClicked(view: View, item: Item)。 bnv.bringToFront 不影响行为。【参考方案2】:你听说过clipToPadding
,它可以为底部视图添加填充,这样就不会阻碍底部视图。
所以尝试设置clipToPadding = "true"
并检查是否解决。
Android what does the clipToPadding Attribute do?
此外,您的布局活动文件将 <RecyclerView>
设置为 0dp。
在外部使用<RelativeLayout>
并在<RecyclerView>
中设置layout_above="@bnv"
有点类似于此。
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/container"
android:layout_
android:layout_>
<FrameLayout
android:id="@+id/content"
android:layout_
android:layout_
android:layout_above="@+id/navigation1"
android:layout_weight="1">
<RelativeLayout
android:layout_
android:layout_
android:orientation="vertical">
<com.nxtoff.plzcome.commonutills.BottomNavigationViewPager
android:id="@+id/viewpager"
android:layout_
android:layout_
app:layout_behavior="@string/appbar_scrolling_view_behavior" />
<View
android:layout_
android:layout_
android:layout_below="@+id/viewpager"
android:background="#999999" />
</RelativeLayout>
</FrameLayout>
<com.google.android.material.bottomnavigation.BottomNavigationView
android:id="@+id/navigation1"
android:layout_
android:layout_
android:layout_alignParentBottom="true"
android:layout_gravity="bottom"
android:background="?android:attr/windowBackground"
app:itemBackground="@android:color/white"
app:itemIconTint="@drawable/nav_item_colors"
app:itemTextColor="@drawable/nav_item_colors"
app:menu="@menu/navigation" />
<com.google.android.material.floatingactionbutton.FloatingActionButton
android:id="@+id/xfb_fab"
android:layout_
android:layout_
android:layout_alignParentBottom="true"
android:layout_centerHorizontal="true"
android:layout_gravity="bottom|center_horizontal"
android:layout_margin="22dp"
android:layout_marginBottom="30dp"
android:background="@color/colorloader"
android:clickable="true"
android:src="@drawable/plus_fab"
android:tint="@color/colorviolet"
app:backgroundTint="@color/colorloader"
app:elevation="8dp"
app:fabSize="normal"
/>
</RelativeLayout>
编辑 1:
试用此代码并告诉我。
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_
android:layout_
tools:context=".MainActivity">
<androidx.recyclerview.widget.RecyclerView
android:id="@+id/rv"
android:layout_
android:layout_
android:layout_marginStart="8dp"
android:layout_marginEnd="8dp"
android:layout_marginTop="8dp"
android:layout_above="@id/bottomNavigationView"
android:layout_alignParentTop="true"
android:layout_marginBottom="8dp"
/>
<com.google.android.material.bottomnavigation.BottomNavigationView
android:id="@+id/bottomNavigationView"
android:layout_
android:layout_
app:menu="@menu/navigation"
android:layout_alignParentBottom="true"
/>
</RelativeLayout>
【讨论】:
我添加了clipPadding 和clipChildren 属性,但没有效果。另外我将ConstraintLayout(这就是rv的高度和宽度为0的原因)切换到RelativeLayout,并将rv的layout_above指定为bnv。我仍然得到相同的行为。 FWIW,我见过其他具有相同效果的 Android 应用程序:其中两个是 Zinio 和 PlayerFM。我希望我没有被它困住。 我确定有解决方案。我仍然认为 rv 不接受layout_above
.. 让我尝试一下并回复你。以上是关于共享内容重叠底部导航的主要内容,如果未能解决你的问题,请参考以下文章
底部导航栏与 Jetpack Compose 中的屏幕内容重叠