- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个垂直的 Recyclerview(parent) 里面有三行。每一行都是 RecyclerView(child1)、RecyclerView(child2)、RecyclerView(child3),每行都有不同类型的布局管理器,比如 child1 有 gridLayout 管理器,child2 和 3 有 Vertical LinearLayout 管理器。
所以当我在行中设置它们时,每一行都有不同类型的适配器。但是当我滚动 recyclerview 时出现问题。滚动不流畅,第二行可见需要 700 毫秒。
我的 row_list_item 布局是:
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<LinearLayout
android:id="@+id/ll_main_block"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="40dp"
android:orientation="horizontal"
android:paddingLeft="10dp"
android:paddingStart="10dp"
android:paddingRight="10dp"
android:layout_marginTop="15dp"
android:layout_marginBottom="12dp"
android:paddingEnd="10dp"
android:gravity="center_vertical"
android:weightSum="1">
<TextView
android:id="@+id/tv_heading"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="0.8"
android:gravity="center_vertical"
android:text=""
android:textColor="@color/dark_grey"
android:textSize="@dimen/midium_text_size" />
<LinearLayout
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="0.2"
android:id="@+id/linearLayout_viewall"
android:visibility="gone"
android:gravity="center_vertical|end"
android:orientation="horizontal">
<TextView
android:id="@+id/tv_more"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:drawablePadding="5dp"
android:gravity="center_vertical|end"
android:text="@string/view_all"
android:textSize="@dimen/small_text_size" />
<ImageView
android:layout_width="15dp"
android:layout_height="15dp"
android:contentDescription="@null"
android:src="@drawable/next" />
</LinearLayout>
</LinearLayout>
<android.support.v7.widget.RecyclerView
android:id="@+id/rv_category_outlet"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</LinearLayout>
</FrameLayout>
我将一些主要的适配器代码与 multiType 放在一起:
@Override
public int getItemCount() {
int size = 4;
if (isErrorView) {
size = 1;
}
return size;
}
@Override
public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view = null;
if (viewType == TYPE_NEARBY
|| viewType == TYPE_PEOPLE || viewType == TYPE_DEFAULT || viewType == TYPE_SERVICES) {
view = LayoutInflater.from(parent.getContext())
.inflate(R.layout.list_item_discover_adapter, parent, false);
RecyclerView.ViewHolder timelineViewHolder = new vHolderEverything(view);
return timelineViewHolder;
} else if (viewType == TYPE_ERROR) {
view = LayoutInflater.from(parent.getContext())
.inflate(R.layout.inflator_error_listview, parent, false);
vHolderError timelineViewHolder = new vHolderError(view);
return timelineViewHolder;
}
return null;
}
@Override
public void onBindViewHolder(RecyclerView.ViewHolder holder, final int position) {
String headingText = "";
boolean isMainBlockInvisible = false;
vHolderEverything mVHolder;
switch (getItemViewType(position)) {
case TYPE_ERROR:
break;
case 1:
mVHolder = (vHolderEverything) holder;
try {
GridLayoutManager lLayout = new GridLayoutManager(curr_activity, 2);
mVHolder.rv_category_outlet.setNestedScrollingEnabled(false);
mVHolder.rv_category_outlet.setHasFixedSize(true);
int spanCount = 4; // 3 columns
int spacing = 4; // 50px
boolean includeEdge = false;
mVHolder.rv_category_outlet.addItemDecoration(new GridSpacingItemDecoration(spanCount, spacing, includeEdge));
mVHolder.rv_category_outlet.setLayoutManager(lLayout);
if (dataForDiscovery != null) {
try {
if (position == TYPE_SERVICES) {
headingText = curr_activity.getResources().getString(R.string.popular_Service);
mVHolder.adapterObject_services.clear();
mVHolder.adapterObject_services.addAll(dataForDiscovery.getData().getPopularServices());
if (mVHolder.adapterObject_services != null && mVHolder.adapterObject_services.size() > 0) {
mVHolder.rv_category_outlet.setAdapter(mVHolder.discoveryPopularListAdapter);
} else {
isMainBlockInvisible = true;
}
} else {
isMainBlockInvisible = true;
}
} catch (Exception e) {
isMainBlockInvisible = true;
}
} else {
isMainBlockInvisible = true;
}
} catch (Exception e) {
isMainBlockInvisible = true;
}
if (isMainBlockInvisible) {
mVHolder.ll_main_block.setVisibility(View.GONE);
} else {
((vHolderEverything) holder).linearLayout_viewall.setVisibility(View.GONE);
mVHolder.tv_heading.setText(headingText);
mVHolder.tv_more.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Activity_Search.search_initiate_view_pager.setCurrentItem(position);
}
});
}
break;
case 2:
mVHolder = (vHolderEverything) holder;
try {
LinearLayoutManager layoutManager = new org.solovyev.android.views.llm.LinearLayoutManager(curr_activity, LinearLayoutManager.VERTICAL, false);
mVHolder.rv_category_outlet.setLayoutManager(layoutManager);
mVHolder.rv_category_outlet.setHasFixedSize(true);
if (dataForDiscovery != null) {
try {
if (position == TYPE_PEOPLE) {
mVHolder.adapterObject.clear();
mVHolder.adapterObject.addAll(dataForDiscovery.getData().getPeople());
headingText = curr_activity.getResources().getString(R.string.follow_people_discover);
if (mVHolder.adapterObject != null && mVHolder.adapterObject.size() > 0) {
mVHolder.rv_category_outlet.setAdapter(mVHolder.adapter);
} else {
isMainBlockInvisible = true;
}
} else {
isMainBlockInvisible = true;
}
} catch (Exception e) {
isMainBlockInvisible = true;
}
} else {
isMainBlockInvisible = true;
}
} catch (Exception e) {
isMainBlockInvisible = true;
}
if (isMainBlockInvisible) {
mVHolder.ll_main_block.setVisibility(View.GONE);
} else {
// if (headingText.equalsIgnoreCase("Services")) {
((vHolderEverything) holder).linearLayout_viewall.setVisibility(View.GONE);
// } else {
// ((vHolderEverything) holder).linearLayout_viewall.setVisibility(View.VISIBLE);
//}
mVHolder.tv_heading.setText(headingText);
mVHolder.tv_more.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Activity_Search.search_initiate_view_pager.setCurrentItem(position);
}
});
}
break;
case TYPE_DEFAULT:
mVHolder = (vHolderEverything) holder;
mVHolder.ll_main_block.setVisibility(View.GONE);
break;
default:
mVHolder = (vHolderEverything) holder;
mVHolder.ll_main_block.setVisibility(View.GONE);
break;
}
}
public static class vHolderEverything extends RecyclerView.ViewHolder {
TextView tv_heading;
TextView tv_more;
RecyclerView rv_category_outlet;
LinearLayout ll_main_block, linearLayout_viewall;
ArrayList<ReusableServices> adapterObject_services= new ArrayList<ReusableServices>();
DiscoveryPopularListAdapter discoveryPopularListAdapter = null;
RecyclerView.Adapter adapter = null;
ArrayList<FollowPeopleSuggestionData> adapterObject= new ArrayList<FollowPeopleSuggestionData>();
public vHolderEverything(View itemView) {
super(itemView);
this.tv_heading = (TextView) itemView.findViewById(R.id.tv_heading);
this.tv_more = (TextView) itemView.findViewById(R.id.tv_more);
this.rv_category_outlet = (RecyclerView) itemView.findViewById(R.id.rv_category_outlet);
this.ll_main_block = (LinearLayout) itemView.findViewById(R.id.ll_main_block);
this.linearLayout_viewall = (LinearLayout) itemView.findViewById(R.id.linearLayout_viewall);
MazkaraApp.getInstance().applyTypefaceItalic(tv_more);
MazkaraApp.getInstance().applyTypefaceBlack(tv_heading);
try {
if (adapterObject_services != null)
discoveryPopularListAdapter = new DiscoveryPopularListAdapter(curr_activity, adapterObject_services);
} catch (Exception e) {
e.printStackTrace();
}
try {
if (adapterObject != null)
adapter = new AdapterRecycler_Search_Users(curr_activity, curr_activity, adapterObject);
} catch (Exception e) {
e.printStackTrace();
}
}
}
只有第一次才会发生。第二次它应该正常工作。
最佳答案
@Anant 我有同样的要求,下面的技巧奏效了。将父 recyclerview 放入 NestedScrollView 并在您的 onCreate 方法中设置。
mRecyclerView.setHasFixedSize(true);
mRecyclerView.setNestedScrollingEnabled(false);
这可以防止父 recyclerview 的滚动,并且滚动变得绝对平滑。
关于android - Recyclerview 内的 Recyclerview 滚动不流畅,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38610034/
我在另一个 RecyclerView(parentRecyclerView) 中实现了 RecyclerView(childRecyclerView),图片说明了所有的实现: 我想编写一个 espre
我正在构建一个应用程序,它使用ViewPager2在页面之间水平滚动,每个页面都有一个垂直滚动的内容RecyclerView,其中每个列表的第一个位置都有一行水平滚动小部件,例如附加到寻呼机指示器类型
我正在尝试实现一个水平的 recyclerview 并且 recyclerview 的每个项目都将是一个具有网格布局的垂直 recyclerview。我面临的问题是,当我尝试垂直滚动子 recycle
我使用显示条目列表的 RecyclerView。每个条目都托管另一个 RecyclerView,它是一个图像列表。 我现在想让这个嵌套的 RecyclerView 可点击,而不是它的项目,而是整个 V
我正在尝试将手机中的图像加载到我的回收 View 中。 到目前为止,我已经创建了一个 recyclerview.adapter 和一个 gridlayoutmanager,并将它们附加到我的 recy
我需要一个可扩展 View ,其中父/可扩展标题将具有文本和下拉箭头。每个此类标题的子项应该是在网格结构中具有多个项目的 View 。 (有点像带有 GridLayoutManager 的回收器 Vi
我正在使用显示不同类别列表的 RecyclerView。每行项目还包含 RecyclerView 以显示类别项目列表。父级 RecyclerView 由垂直 LinearLayoutManager 填
我正在更新一个旧的 Android 项目,现在我从 RecyclerView 中反复收到这条日志语句: W/RecyclerView:RecyclerView 不支持滚动到绝对位置。改为使用 scro
在我的 Adapter 中,我调用 LayoutManager.ChildAt(position) 来获取 itemview,但是我得到的 View 不是匹配的 itemview,当我调用 notif
我正在从 ListView 迁移到 RecyclerView,但是在 SQLite 中输入一些数据后,我的列表没有使用 notifyDataSetChanged() 更新;所以我总是要调用setAda
我正在用 Google Now Cards 的风格创建一组 5 张卡片。我首先关注的是总体布局。 我正在使用 CardView 和 RecyclerView ,我想要实现的是这样的: 这是我的 Car
在我的应用程序中,我有一个 RecyclerView,其中包含一个简单的项目 View ,每行包含一个 TextView 和一个 Spinner。 用户从操作栏中单击“保存”后,我需要遍历所有项目并获
我正在尝试检查 RecyclerView 中是否可以看到某些特定项目;但我无法实现。请帮助我确定我的项目是否在 RecyclerView 中完全可见。 mrecylerView.addOnScroll
我有一个提要片段,它的主要元素是帖子的 RecyclerView。 我正在使用 Lisa Wray 的 Groupie 库管理回收站 https://github.com/lisawray/group
我有这两个类似的行为回收器 View 适配器,它们之间的唯一区别是 onclick 方法和传递给它们的对象。所以,我正在考虑将类 B 设计为从回收器 View 适配器继承,这样我就可以更改构造函数来执
这很奇怪。我对这个问题感到沮丧。我将数据保存在 ArrayList 中。当我将数据放在 RecyclerView 上时。数据未显示在列表中。这是我的代码 listOrder.forEach { ord
编辑我通过使用 CoordinatorLayout 和 AppBarLayout 作为 header 和 TabLayout 的包装解决了这个问题。本来应该很明显,但是哦,好吧。 原始问题:我有一个设
我有一个回收 View 。我想从其适配器类更新回收器 View 。我尝试了 notiftDataSetChanged( ) 但它只适用于主类。下面是 recyclerview 适配器类的代码。 pac
我正在使用具有不同 viewholders 的 recyclerview(具有垂直 LinearLayout),其中一个有另一个 RecyclerView(带有水平 LL)。在第二个 recycler
我想创建一个与 Google Play Store 或 Netflix App 类似的布局,其中在单个 RecyclerView 中基本上有多个水平 RecyclerView。如果这不是他们做事的方式
我是一名优秀的程序员,十分优秀!