共享内容重叠底部导航

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?

此外,您的布局活动文件将 &lt;RecyclerView&gt; 设置为 0dp。

在外部使用&lt;RelativeLayout&gt; 并在&lt;RecyclerView&gt; 中设置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 中的屏幕内容重叠

当底部导航栏存在时,appbar 与通知栏重叠

小程序自定义底部导航缓存

HTML5怎么把导航固定在底部?是只滑动内容,导航固定不动的。

在 React native 中创建自定义底部选项卡导航器

移动端底部导航栏固定——兼容IOS