2

我想添加隐藏/显示回滚视图滚动时的布局。当recyclerview向下滚动时,该布局将隐藏,并显示recyclerview向上滚动的时间,如twitter的新推文布局。我可以为appbarlayout做到这一点,但我无法做到这一布局。我怎样才能做到这一点?如何在recyclerview滚动时隐藏/显示布局(如Twitter的新推文布局)

http://i.hizliresim.com/rVyDq3.png

紫色的布局将隐藏显示像动作条:

http://i.hizliresim.com/gAMp92.png

这里是我的布局文件:

<android.support.v4.widget.DrawerLayout 
xmlns:app="http://schemas.android.com/apk/res-auto" 
xmlns:android="http://schemas.android.com/apk/res/android" 
android:id="@+id/drawerLayout" 
android:layout_width="match_parent" 
android:layout_height="match_parent" 
android:elevation="7dp"> 

<!-- my main content --> 
<android.support.design.widget.CoordinatorLayout 
    android:id="@+id/coordinatorLayout" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent"> 

    <android.support.design.widget.AppBarLayout 
     android:id="@+id/appBarLayout" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content"> 

     <android.support.v7.widget.Toolbar 
      android:id="@+id/tool_bar" 
      style="@style/ToolBarStyle" 
      android:layout_width="match_parent" 
      android:layout_height="?attr/actionBarSize" 
      android:background="?attr/colorPrimary" 
      android:minHeight="?attr/actionBarSize" 
      app:layout_scrollFlags="scroll|enterAlways" /> 

     <LinearLayout 
      android:orientation="vertical" 
      android:id="@+id/linearLayout" 
      android:layout_width="match_parent" 
      android:layout_height="48dp" 
      android:background="@color/color_accent_pink"> 

     </LinearLayout> 

    </android.support.design.widget.AppBarLayout> 


    <android.support.v7.widget.RecyclerView 
     android:id="@+id/newsRecyclerView" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:scrollbars="vertical" 
     android:clickable="true" 
     app:layout_behavior="@string/appbar_scrolling_view_behavior" /> 

    <!-- that layout will hide/show when recyclerview scroll --> 
    <LinearLayout 
     android:orientation="horizontal" 
     android:id="@+id/takimlar" 
     android:layout_width="match_parent" 
     android:layout_height="48dp" 
     android:background="@color/bg_group_item_swiping_active_state" 
     android:layout_gravity="bottom" > 

    </LinearLayout> 

</android.support.design.widget.CoordinatorLayout> 

<!-- my navigation drawer --> 
<RelativeLayout 
    android:id="@+id/container" 
    android:layout_width="235dp" 
    android:layout_height="match_parent" 
    android:layout_gravity="left" 
    android:background="@color/myDrawerBackground"> 


    <TextView 
     android:id="@+id/merhabaText" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_marginTop="400dp" 
     android:layout_marginRight="40dp" 
     android:layout_alignParentRight="true" 
     android:text="Hello!"/> 

</RelativeLayout> 

回答

0

我有一个简单的解决方案..

recyclerview.addOnScrollListener(new HidingScrollListener() 
    { 

     @Override 
     public void onHide() 
     { 

      tabss.animate().translationY(tabss.getHeight()) 
        .setInterpolator(new AccelerateInterpolator(2)).start();  
      filtershow.animate().translationY(-filtershow.getHeight()) 
        .setInterpolator(new AccelerateInterpolator(1)); 
     } 

     @Override 
     public void onShow() 
     { 
      tabss.animate().translationY(0).setInterpolator(new 
        DecelerateInterpolator(2)).start(); 
     filtershow.animate().translationY(0).setInterpolator 
       (new DecelerateInterpolator(1)).start(); 
     } 
    }); 

在这种Recyclerview我躲在屏幕顶部的过滤器和屏幕底部的标签 如果你想对这个隐藏的布局有疑问,请问我。 我会为您提供您所需的代码。