仿知乎专题页
2016-09-30 本文已影响440人
chefish
github地址 https://github.com/chefish/BehaviorDemo
看了知乎详情页的效果,感觉不错,在上滑的过程把主标题逐渐放到toolbar上去。
实现这个效果大概有2种思路,首先简单的使用CollapsingToolbarLayout,内含Toolbar,然后把expandedTitle放到合适的位置(默认是居左下)。然后上滑的过程中自然会逐渐滑到toolbar上去,这就是CollapsingToolbarLayout内部实现的。
第二种想法,是在CollapsingToolbarLayout内部放一个TextView,然后Toolbar放在CollapsingToolbarLayout外部,用anchor的方法来实现,上移的过程中操作TextView的变化。
我拿DDMS抓了下知乎的页面,发现标题那里没有TextView,所以应该是第一种方法实现的。试着写了下。
expandedTitle的标题位置用 app:expandedTitleGravity="center"就可以了
然后加一个上滑的时候逐渐变透明。
最后效果如下
核心代码如下
<?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_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
tools:context="com.fish.behaviordemo.MainActivity">
<!--这里必须要写fitsSystemWindows,不然上滑会出现statusbar占2份高度问题-->
<android.support.design.widget.AppBarLayout
android:id="@+id/appbar"
android:layout_width="match_parent"
android:layout_height="352dp"
android:background="?attr/colorPrimary"
android:fitsSystemWindows="true">
<android.support.design.widget.CollapsingToolbarLayout
android:id="@+id/collapsingToolbarLayout"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:expandedTitleGravity="center"
app:layout_scrollFlags="scroll|exitUntilCollapsed|snap">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
style="@style/ToolBarWithNavigationBack"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:minHeight="?attr/actionBarSize"
app:layout_collapseMode="pin"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
app:theme="@style/ThemeOverlay.AppCompat.Light" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center_horizontal"
android:gravity="center_horizontal"
android:orientation="vertical"
android:paddingTop="?attr/actionBarSize"
app:layout_collapseMode="parallax"
app:layout_collapseParallaxMultiplier="0.5">
<de.hdodenhof.circleimageview.CircleImageView
android:id="@+id/profile_image"
android:layout_width="60dp"
android:layout_height="60dp"
android:layout_gravity="center_horizontal"
android:layout_marginTop="25dp"
android:elevation="8dp"
android:src="@drawable/user_avatar"
app:border_color="#FFF"
app:border_width="2dp"
app:layout_scrollFlags="scroll" />
<TextView
android:id="@+id/attention_num"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="60dp"
android:text="8080关注" />
<TextView
android:id="@+id/detail"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="10dp"
android:text="都说C++难学" />
<Button
android:id="@+id/attention"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="10dp"
android:text="关注" />
</LinearLayout>
</android.support.design.widget.CollapsingToolbarLayout>
</android.support.design.widget.AppBarLayout>
<!--关键代码-->
<android.support.v4.widget.NestedScrollView
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior">
<LinearLayout
android:id="@+id/linear"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
</LinearLayout>
</android.support.v4.widget.NestedScrollView>
<android.support.design.widget.FloatingActionButton
android:id="@+id/fab"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="bottom|end"
android:layout_margin="@dimen/fab_margin"
android:src="@android:drawable/ic_dialog_email"
app:layout_behavior="com.fish.behaviordemo.fab.MyBehavior" />
</android.support.design.widget.CoordinatorLayout>
@Override
public void onOffsetChanged(AppBarLayout appBarLayout, int verticalOffset) {
if (mMaxScrollSize == 0){
mMaxScrollSize = appBarLayout.getTotalScrollRange();
}
int currentScrollPercentage = (Math.abs(verticalOffset)) * 100
/ mMaxScrollSize;
float alpha=(float) (1 - currentScrollPercentage/100.0);
attention.setAlpha(alpha);
image.setAlpha(alpha);
attentionNumTv.setAlpha(alpha);
detailTv.setAlpha(alpha);
}