RecyclerView高度随Item自适应
2014-10-24 11:40
363 查看
转载请注明出处:http://write.blog.csdn.net/postedit/40425231
编写RecyclerView.ItemDecoration时,在onDraw方法中,Drawable的高度等于RecyclerView的高度减去RecyclerView的上下padding。
可以看到,ItemDecoration高度竟然全屏了,然后检查xml布局文件:
activity_main.xml
根据Android-RecylerView初识里提到的,RecyclerView并不负责Item的显示工作,而Adapter负责的是数据仓库和Item的视图,所以最终把目标锁定到RecyclerView.LayoutManager上。于是尝试继承LinearLayoutManager,发现果然有onMeasure方法:
最后奉上示例程序Github链接。
编写RecyclerView.ItemDecoration时,在onDraw方法中,Drawable的高度等于RecyclerView的高度减去RecyclerView的上下padding。
@Override public void onDraw(Canvas c, RecyclerView parent, State state) { int top = parent.getPaddingTop(); int bottom = parent.getHeight() - parent.getPaddingBottom(); int childCount = parent.getChildCount(); for(int i=0;i < childCount;i++){ View child = parent.getChildAt(i); RecyclerView.LayoutParams layoutParams = (RecyclerView.LayoutParams)child.getLayoutParams(); int left = child.getRight() + layoutParams.rightMargin; int right = left + mDivider.getIntrinsicWidth(); mDivider.setBounds(left, top, right, bottom); mDivider.draw(c); } }但运行后的显示效果却和我的预期相差很大
可以看到,ItemDecoration高度竟然全屏了,然后检查xml布局文件:
activity_main.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.xmy.recylerviewdemo.MainActivity" > <android.support.v7.widget.RecyclerView android:id="@+id/recyclerView" android:layout_width="wrap_content" android:layout_height="wrap_content"/> </RelativeLayout>item.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="wrap_content" android:layout_height="wrap_content" android:gravity="center" android:padding="10.0dip" android:orientation="vertical" > <ImageView android:id="@+id/item_iv" android:layout_width="wrap_content" android:layout_height="wrap_content" android:scaleType="center" android:src="@drawable/img" android:adjustViewBounds="true"/> <TextView android:id="@+id/item_tv" android:layout_width="wrap_content" android:layout_height="wrap_content"/> </LinearLayout>xml布局文件中RecyclerView和Item的高度都设定的是wrap_content,那说好的自适应于item高度呢?查看Android文档,没发现有关RecyclerView高度相关说明,看来只能自己动手丰衣足食了。
根据Android-RecylerView初识里提到的,RecyclerView并不负责Item的显示工作,而Adapter负责的是数据仓库和Item的视图,所以最终把目标锁定到RecyclerView.LayoutManager上。于是尝试继承LinearLayoutManager,发现果然有onMeasure方法:
public void onMeasure(Recycler recycler, State state, int widthSpec,int heightSpec)在onMeasure中可以获得RecyclerView.Recycler。Recycler负责管理Item视图的重复利用,所以我们可以通过Recycler获取一个Item视图的实例,然后像复写其他ViewGroup一样,使用measureChild获取子视图的高度后使用setMeasuredDimension设置RecyclerView同样的高度即可。
public class MyLayoutManager extends LinearLayoutManager { public MyLayoutManager(Context context) { super(context); // TODO Auto-generated constructor stub } @Override public void onMeasure(Recycler recycler, State state, int widthSpec,int heightSpec) { View view = recycler.getViewForPosition(0); if(view != null){ measureChild(view, widthSpec, heightSpec); int measuredWidth = MeasureSpec.getSize(widthSpec); int measuredHeight = view.getMeasuredHeight(); setMeasuredDimension(measuredWidth, measuredHeight); } } }修改完之后的运行效果图:
最后奉上示例程序Github链接。
相关文章推荐
- RecyclerView高度随Item自适应
- RecyclerView高度随Item自适应
- RecyclerView高度随Item自适应
- 线性布局LayoutManager的RecyclerView高度随Item自适应
- RecyclerView高度随Item自适应 GridLayoutManager和LinearLayoutManager都适用
- 【Android 界面效果49】RecyclerView高度随Item自适应
- 【Android 界面效果49】RecyclerView高度随Item自适应
- RecylerViewd的Item高度自适应,Scrollview 嵌套 RecyclerView 及在Android 5.1版本滑动时 惯性消失问题
- ScrollView 嵌套 RecyclerView 高度自适应,item显示不全 问题
- 网格布局的RecyclerView高度随Item自适应
- 简述RecyclerView实现瀑布流并且随机自适应item的高度
- RecyclerView自适应高度的LayoutManager
- 使用RecyclerView实现的瀑布流高度自适应
- 关于RecyclerView 的Item 自适应问题
- Android RecyclerView item高度WRAP_CONTENT实现
- RecyclerView自适应高度的LinearLayoutManager
- Android 6.0 解决Recyclerview 在 Scrollview 中不能高度自适应问题
- RecyclerView 自适应高度 正确做法。
- 解决 RecyclerView 自适应高度
- <GridVew 高度自适应>设置GirdView中item高度来填满 达到自适应