ScrollView嵌套RecyclerView再嵌套RecyclerView导致的布局展示不完整问题

2024-09-05 01:58

本文主要是介绍ScrollView嵌套RecyclerView再嵌套RecyclerView导致的布局展示不完整问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景:页面布局,最外层有个ScrollView,然后里面有个RecyclerView,然后每个RecyclerView的item都是一个RecyclerView

异常:页面展示不完整,最底下的Item 展示一半,在往上滑就滑不动了

 

解决:

// 每一个item渲染完后重新计算外层recyclerview高度
// 因为外层的recyclerview是先渲染的,渲染时 内部recyclerview无数据此时高度是0
// 当内部recyclerview 渲染完后要重新计算高度 外部recyclerview才可以撑开//第一步:测量内部recyclerView高度
recommendedRvViewHolder.recyclerView.measure(0, 0);//第二步:重新设置外层的recyclerview高度  已经有的高度 + 新渲染Item的高度 
ViewGroup.LayoutParams params = recyclerView.getLayoutParams();
//这里的30 是布局文件中"为你推荐"、"热门榜单"所在布局的高度 18  + 两个item之间的间距 9  27 取整 30
params.height += recommendedRvViewHolder.recyclerView.getMeasuredHeight() + DensityUtil.dip2px(mContext, 30);
recyclerView.setLayoutParams(params);

看下图:最底下的item展示出来了

 

部分核心的代码:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:background="@color/common_white"android:orientation="vertical"><include layout="@layout/search_layout"></include><ScrollViewandroid:layout_width="match_parent"android:layout_height="match_parent"android:scrollbars="none"><LinearLayoutandroid:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"><com.youth.banner.Bannerandroid:id="@+id/star_film_home_banner"android:layout_width="match_parent"android:layout_height="158dp"android:visibility="invisible" /><LinearLayoutandroid:layout_width="match_parent"android:layout_height="5dp"android:background="@color/film_common_bg_gray" /><android.support.v7.widget.RecyclerViewandroid:id="@+id/star_film_recommend_rv"android:layout_width="match_parent"android:layout_height="wrap_content"android:layout_gravity="center_horizontal"android:layout_marginTop="10dp"android:overScrollMode="never"android:scrollbars="none" /></LinearLayout></ScrollView>
</LinearLayout>
public class RecommendedListRvAdapter extends RecyclerView.Adapter<RecommendedRvViewHolder> {/*** 查询的每页数量*/private final int PAGE_SIZE = 6;private Context mContext;private List<CategoryObjectV1> cats;private RecyclerView recyclerView;public RecommendedListRvAdapter(Context context, List<CategoryObjectV1> cats, RecyclerView rv) {this.mContext = context;this.cats = cats;this.recyclerView = rv;}@NonNull@Overridepublic RecommendedRvViewHolder onCreateViewHolder(@NonNull ViewGroup viewGroup, int i) {View view = LayoutInflater.from(mContext).inflate(R.layout.recommended_recy_item, null);return new RecommendedRvViewHolder(view);}@Overridepublic void onBindViewHolder(@NonNull final RecommendedRvViewHolder recommendedRvViewHolder, final int i) {try {recommendedRvViewHolder.recommend_item_tv.setText(cats.get(i).getLanguages().get(0).getName());recommendedRvViewHolder.recommend_item_ll.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {//跳转到推荐二级页面Intent intent = new Intent(mContext, StarFilmSecondActivity.class);intent.putExtra(StarConstants.INTENT_CAT_ID, cats.get(i).getId());mContext.startActivity(intent);}});// 设置频道列表数据recommendedRvViewHolder.recyclerView.setLayoutManager(new GridLayoutManager(mContext, 3));recommendedRvViewHolder.recyclerView.addItemDecoration(new DividerGridItemDecoration(mContext, mContext.getResources().getDrawable(R.drawable.recy_custom_divider)));//请求目录下的推荐内容并渲染UIStarCoreVariable.threadPoolUtil.poolExecute(new Runnable() {@Overridepublic void run() {final OndemandContentSimplePageCacheDTO ondemandContentSimplePageCacheDTO = VodService.getInstance().requestVodContentFromServer(ServerConfigLocalConstants.SERVER_UP_URL, cats.get(i).getId(), 1, PAGE_SIZE);MainUIHandler.handler().post(new Runnable() {@Overridepublic void run() {FilmChannelRecyAdapter filmChannelRecyAdapter = new FilmChannelRecyAdapter(mContext, ondemandContentSimplePageCacheDTO);recommendedRvViewHolder.recyclerView.setAdapter(filmChannelRecyAdapter);// 每一个item渲染完后重新计算外层recyclerview高度// 因为外层的recyclerview是先渲染的,渲染时 内部recyclerview无数据此时高度是0// 当内部recyclerview 渲染完后要重新计算高度 外部recyclerview才可以撑开recommendedRvViewHolder.recyclerView.measure(0, 0);ViewGroup.LayoutParams params = recyclerView.getLayoutParams();//这里的30 是布局文件中"为你推荐"、"热门榜单"所在布局的高度 18  + 两个item之间的间距 9  27 取整 30params.height += recommendedRvViewHolder.recyclerView.getMeasuredHeight() + DensityUtil.dip2px(mContext, 30);recyclerView.setLayoutParams(params);}});}});} catch (Exception e) {e.printStackTrace();}}@Overridepublic int getItemCount() {return cats.size();}
}
public class RecommendedRvViewHolder extends RecyclerView.ViewHolder {public LinearLayout recommend_item_ll;public TextView recommend_item_tv;public RecyclerView recyclerView;public RecommendedRvViewHolder(@NonNull View itemView) {super(itemView);recommend_item_ll = itemView.findViewById(R.id.rec_item_all_ll);recommend_item_tv = itemView.findViewById(R.id.rec_item_name_tv);recyclerView = itemView.findViewById(R.id.rec_item_rv);}
}
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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="wrap_content"android:orientation="vertical"><RelativeLayoutandroid:layout_width="match_parent"android:layout_height="18dp"android:orientation="vertical"><ImageViewandroid:id="@+id/rec_item_iv"android:layout_width="5dp"android:layout_height="14dp"android:layout_centerVertical="true"android:background="@color/film_common_light_red" /><TextViewandroid:id="@+id/rec_item_name_tv"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_centerVertical="true"android:layout_marginLeft="10dp"android:layout_toRightOf="@id/rec_item_iv"android:textColor="@color/film_common_text_black"android:textSize="@dimen/film_common_text_size_big"tools:text="为你推荐" /><LinearLayoutandroid:id="@+id/rec_item_all_ll"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_alignParentRight="true"android:layout_centerVertical="true"android:layout_marginRight="9dp"><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_gravity="center_vertical"android:layout_marginRight="4dp"android:text="热门榜单"android:textColor="@color/film_common_text_gray"android:textSize="@dimen/film_common_text_size_small" /><ImageViewandroid:layout_width="8dp"android:layout_height="7dp"android:layout_gravity="center_vertical"android:background="@drawable/common_arrow_right" /></LinearLayout></RelativeLayout><android.support.v7.widget.RecyclerViewandroid:id="@+id/rec_item_rv"android:layout_width="match_parent"android:layout_height="wrap_content"android:layout_marginLeft="9dp"android:layout_marginTop="9dp"android:layout_marginRight="9dp"android:scrollbars="none" /></LinearLayout>

 

这篇关于ScrollView嵌套RecyclerView再嵌套RecyclerView导致的布局展示不完整问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1137651

相关文章

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码

《在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码》在MyBatis的XML映射文件中,trim元素用于动态添加SQL语句的一部分,处理前缀、后缀及多余的逗号或连接符,示... 在MyBATis的XML映射文件中,<trim>元素用于动态地添加SQL语句的一部分,例如SET或W

numpy求解线性代数相关问题

《numpy求解线性代数相关问题》本文主要介绍了numpy求解线性代数相关问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 在numpy中有numpy.array类型和numpy.mat类型,前者是数组类型,后者是矩阵类型。数组

Spring常见错误之Web嵌套对象校验失效解决办法

《Spring常见错误之Web嵌套对象校验失效解决办法》:本文主要介绍Spring常见错误之Web嵌套对象校验失效解决的相关资料,通过在Phone对象上添加@Valid注解,问题得以解决,需要的朋... 目录问题复现案例解析问题修正总结  问题复现当开发一个学籍管理系统时,我们会提供了一个 API 接口去

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas

Redis缓存问题与缓存更新机制详解

《Redis缓存问题与缓存更新机制详解》本文主要介绍了缓存问题及其解决方案,包括缓存穿透、缓存击穿、缓存雪崩等问题的成因以及相应的预防和解决方法,同时,还详细探讨了缓存更新机制,包括不同情况下的缓存更... 目录一、缓存问题1.1 缓存穿透1.1.1 问题来源1.1.2 解决方案1.2 缓存击穿1.2.1

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言

解决Cron定时任务中Pytest脚本无法发送邮件的问题

《解决Cron定时任务中Pytest脚本无法发送邮件的问题》文章探讨解决在Cron定时任务中运行Pytest脚本时邮件发送失败的问题,先优化环境变量,再检查Pytest邮件配置,接着配置文件确保SMT... 目录引言1. 环境变量优化:确保Cron任务可以正确执行解决方案:1.1. 创建一个脚本1.2. 修