前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android中RecyclerView的item宽高问题详解

Android中RecyclerView的item宽高问题详解

作者头像
砸漏
发布2020-10-22 09:51:51
1.4K0
发布2020-10-22 09:51:51
举报
文章被收录于专栏:恩蓝脚本恩蓝脚本

前言

本文主要给大家介绍了关于Android中RecyclerView的item宽高问题的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。

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

代码语言:javascript
复制
View view = LayoutInflater.from(context).inflate(R.layout.test_test,null);

上面的做法就会出问题

改成这样就可以正常显示设置的宽高

代码语言:javascript
复制
View view = LayoutInflater.from(context).inflate(R.layout.test_test,parent,false);

那么还是有一个问题。

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

我也只找了很多方法,比如在onCreateViewHolder方法中parent.addView()也没用。

在网上查了很多帖子都是一些扯淡的话,无奈之下我只好查看源码,没想到正好发现解决办法的关键。

看过源码就知道原来我们要传的parent这个参数就是这个recyclerview。

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

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

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

比如:

代码语言:javascript
复制
<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来说是件容易的事。

代码语言:javascript
复制
<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的内容就能正常的展示到中间。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对ZaLou.Cn的支持。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档