在折叠栏布局android中向上滚动时淡化整个布局
Posted
技术标签:
【中文标题】在折叠栏布局android中向上滚动时淡化整个布局【英文标题】:Fading the whole layout as scrolled up in collapsing bar layout android 【发布时间】:2016-12-28 15:44:55 【问题描述】:以下是我的协调器布局的代码。效果很好。
<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_
android:layout_
android:fitsSystemWindows="true">
<android.support.design.widget.AppBarLayout
android:id="@+id/appbar"
android:layout_
android:layout_
android:fitsSystemWindows="true"
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">
<android.support.design.widget.CollapsingToolbarLayout
android:id="@+id/collapsing_toolbar"
android:layout_
android:layout_
android:fitsSystemWindows="true"
app:contentScrim="#f4f4f4"
app:expandedTitleMarginEnd="16dp"
app:expandedTitleMarginStart="48dp"
app:layout_scrollFlags="scroll|exitUntilCollapsed">
<RelativeLayout
android:layout_
android:layout_>
<ImageView
android:id="@+id/header"
android:layout_
android:layout_
android:background="@drawable/echo3"
android:fitsSystemWindows="true"
android:scaleType="centerCrop" />
<RelativeLayout
android:layout_
android:layout_
android:layout_alignParentBottom="true"
android:background="#fff">
<TextView
android:layout_
android:layout_
android:layout_centerInParent="true"
android:text="Private Albums"
android:textColor="#000"
android:textSize="22sp"
android:textStyle="bold" />
</RelativeLayout>
</RelativeLayout>
<android.support.v7.widget.Toolbar
android:id="@+id/anim_toolbar"
android:layout_
android:layout_
app:layout_collapseMode="pin" />
</android.support.design.widget.CollapsingToolbarLayout>
</android.support.design.widget.AppBarLayout>
<android.support.v4.widget.NestedScrollView
android:layout_
android:layout_
android:layout_below="@+id/anim_toolbar"
app:layout_behavior="@string/appbar_scrolling_view_behavior">
<include layout="@layout/content_profile" />
<!--<fragment-->
<!--android:id="@+id/detail"-->
<!--android:name="<package>.<fragment_name>"-->
<!--android:layout_-->
<!--android:layout_ />-->
</android.support.v4.widget.NestedScrollView>
</android.support.design.widget.CoordinatorLayout>
但是我想在向上滚动时淡化整个相对布局,它应该开始淡化(意味着整个折叠栏布局)。它确实在特定点淡出,但我希望它在我向上滚动时淡出。 谢谢,任何帮助表示赞赏。
【问题讨论】:
【参考方案1】:您可以在向上滚动时通过将 AppBarLayout.OnOffsetChangedListener 连接到 AppBarLayout 来减小 RelativeLayout 的 alpha。下面是我在应用中使用的代码。
appBar = (AppBarLayout) findViewById(R.id.app_bar_layout);
appBar.addOnOffsetChangedListener(new AppBarLayout.OnOffsetChangedListener()
@Override
public void onOffsetChanged(AppBarLayout appBarLayout, int verticalOffset)
relativeLayoutToFadeOut.setAlpha(1.0f - Math.abs(verticalOffset / (float)
appBarLayout.getTotalScrollRange()));
);
【讨论】:
这应该被标记为正确答案。感谢分享@ChinLoong 谢谢你,我正在搜索它,就像你实现它一样。【参考方案2】:请参考下面的代码,对我来说它工作正常..
<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_
android:id="@+id/view_profile_parent_layout"
android:background="@color/splash_bg_color"
tools:context=".Activity">
<android.support.design.widget.AppBarLayout
android:id="@+id/app_barLayout"
android:layout_
android:layout_
android:elevation="@dimen/view_profile_app_bar_elevation"
android:theme="@style/ThemeOverlay.AppCompat.Light">
<android.support.design.widget.CollapsingToolbarLayout
android:id="@+id/collapsing_bar_layout"
android:layout_
android:layout_
app:contentScrim="?attr/colorPrimary"
app:titleEnabled="false"
android:fitsSystemWindows="true"
app:layout_scrollFlags="exitUntilCollapsed|scroll"
app:title="Collapsing Toolbar">
<RelativeLayout
android:layout_
android:layout_
android:layout_marginTop="?attr/actionBarSize">
<de.hdodenhof.circleimageview.CircleImageView
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/view_profile_imageView"
android:layout_
android:layout_
android:src="@drawable/ic_profile_icon"
android:layout_centerHorizontal="true"
app:civ_border_
app:civ_border_color="@color/textPrimary"/>
<TextView
android:id="@+id/view_profile_profile_name_textView"
android:layout_
android:layout_
android:layout_marginTop="@dimen/view_profile_profile_name_margin_top"
android:layout_below="@id/view_profile_imageView"
android:fontFamily="@font/roboto_regular"
android:text=""
android:textSize="@dimen/view_profile_profile_name_text_size"
android:gravity="center"
android:textColor="@color/white"/>
</RelativeLayout>
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
app:layout_collapseMode="pin"
android:layout_
android:layout_
android:elevation="@dimen/login_btn_elevation"
app:popupTheme="@style/AppTheme.PopupOverlay"
app:contentInsetLeft="0dp"
app:contentInsetStart="0dp"
android:contentInsetStart="0dp"
android:contentInsetLeft="0dp">
</android.support.v7.widget.Toolbar>
</android.support.design.widget.CollapsingToolbarLayout>
</android.support.design.widget.AppBarLayout>
【讨论】:
以上是关于在折叠栏布局android中向上滚动时淡化整个布局的主要内容,如果未能解决你的问题,请参考以下文章
如何在 Xamarin Forms 中滚动时折叠(隐藏或向上滑动)导航栏(标题栏)?
xml [使布局覆盖任务栏]在折叠工具栏布局中,必须添加所有元素:android:fitsSystemWindows =“t