RecyclerView的item的宽高问题

简介: 在创建viewholder传入的View时,如果不指定其viewgroup,就会出现宽高只包裹显示内容的问题。View view = LayoutInflater.from(context).inflate(R.layout.test_test,null);上面的做法就会出问题改成这样就可以正常显示设置的宽高View view = LayoutInflater.from(context).inflate(R.layout.test_test,parent,false);那么还是有一个问题。

在创建viewholder传入的View时,如果不指定其viewgroup,就会出现宽高只包裹显示内容的问题。

View view = LayoutInflater.from(context).inflate(R.layout.test_test,null);

上面的做法就会出问题
改成这样就可以正常显示设置的宽高

View view = LayoutInflater.from(context).inflate(R.layout.test_test,parent,false);

那么还是有一个问题。
假如我的view是在adapter创建之前创建的,也就是说我的view是从外边传进来的,不是在onCreateViewHolder方法中创建。这样就无法设置parent。遇到这种情况又要怎么处理呢?

我也只找了很多方法,比如在onCreateViewHolder方法中parent.addView()也没用。
在网上查了很多帖子都是一些扯淡的话,无奈之下我只好查看源码,没想到正好发现解决办法的关键。
看过源码就知道原来我们要传的parent这个参数就是这个recyclerview。

img_3bba4bbd9232a4b433b073eea78f0f07.png
Paste_Image.png
img_a7f15d7afe0ed3220e264491de937fd5.png
Paste_Image.png
img_bef445db9c1783afab75a758a29f17cb.png
Paste_Image.png

从这里发现原来我们用到的parent就是RecyclerView.this。
这就说明只要在创建view之前有recyclerview,那么即便是在adapter之前创建view也能让这个view在recyclerview中正常显示

img_0ee5111eb8a4d9dd71178f5df4e9bb2f.png
Paste_Image.png

附加内容:另类解决item的宽高问题

附加时间 2017-8-30

上面的内容是我挺早前写的,现在遇到新的情况所以补充一下。上面我们说了,如果在创建item时不指定parent,最后展示的效果是会包裹内容。
比如:

<RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:padding="10dp">
        <TextView
            android:id="@+id/tv_test"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textSize="@dimen/text_size_15"
            android:layout_centerInParent="true" />
    </RelativeLayout>

这样的item布局,就算我设置TextView显示在中间,实际运行的时候会展示在左边,这个情况有点像RelativeLayout的viewgroup把里面的空气抽出来一样。

上面的解决方法是没问题的,创建时为这个布局设置parent。但是,有的时候你解耦把RecyclerView和item的耦合度降得很低,这是创建item布局要拿到RecyclerView这个parent很麻烦,这时怎么办?
其实你会发现,有时候不设置parent,Item的宽度也能填充整个父布局,为什么,因为这种情况下item的宽度本来就已经填充布局了,也就是说在宽度上已经没有“空气”了,所以再宽上不会被压缩。
按照这个原理,我们可以来个骚操作解决这个问题,那就是想办法让布局宽度填充,对RelativeLayout来说是件容易的事。

<RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:padding="10dp">
        <TextView
            android:id="@+id/tv_test"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textSize="@dimen/text_size_15"
            android:layout_centerInParent="true" />

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentRight="true"
            />
    </RelativeLayout>

这样写,展示的时候,第一个TextView的内容就能正常的展示到中间。

目录
相关文章
|
Android开发
Android RecyclerView 使用大全 - 基础使用,item 动画,下拉刷新等(一)
Android RecyclerView 使用大全 - 基础使用,item 动画,下拉刷新等
|
Android开发
Android RecyclerView 使用大全 - 基础使用,item 动画,下拉刷新等(三)
Android RecyclerView 使用大全 - 基础使用,item 动画,下拉刷新等
|
5月前
|
Android开发 UED
Android Item平移动画
【6月更文挑战第18天】
105 8
|
5月前
|
JSON Android开发 数据格式
Android动态添加view设置view大小(宽高)
Android动态添加view设置view大小(宽高)
125 0
|
Android开发
Android RecyclerView 使用大全 - 基础使用,item 动画,下拉刷新等(二)
Android RecyclerView 使用大全 - 基础使用,item 动画,下拉刷新等
|
Android开发
【RecyclerView】 九、为 RecyclerView 设置不同的布局样式
【RecyclerView】 九、为 RecyclerView 设置不同的布局样式
275 0
【RecyclerView】 九、为 RecyclerView 设置不同的布局样式
RecyclerView的item不充满的整个宽度的原因
RecyclerView的item不充满的整个宽度的原因
ListView Item多布局的实现
ListView这个小节的最后一节,给大家带来的是ListView多布局Item的实现, 何为ListView Item多布局,打个比方,QQ这种聊天列表
117 0
RecyclerView的item宽度不能全屏显示
RecyclerView的item宽度不能全屏显示
222 0
|
Android开发
Android ListView的每个子Item如何设置高度
Android ListView的每个子Item如何设置高度
557 0