- 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/
我想在单击按钮时进行移动:向左。这是针对移动运动的... 问题在于它的移动,但只有一次。我需要点击按钮发送垃圾邮件... 代码: 在创建中: this.buttonleft.inputEnabled
前言 今天大姚给大家分享一个.NET开源(MIT License)、免费、现代化、流畅、可测试、可移植的URL构建器和HTTP客户端库:Flurl。 项目介绍 Flurl是一个集现代性、流畅性、
我不确定其他与我的问题明显相似的问题是否归结为同一主题。 请考虑这段代码(为更清楚起见,为 head 部分提取了 CSS 代码): body { margin: 0;
我是一名学习 html/css 的学生,我在创建第一个网站时遇到了问题。我在配置页面时遇到了很多困难,因此它是流动的而不是固定的。我配置了一个框、图像和一些文本,因此它们在页面上是绝对的,但我无法使页
在我的游戏中,我已将角色设置为移动。它的设置方式是: if game_over_state == False: if event.type == pygame.KEYDOWN:
我一直在研究代码,但似乎无法让它工作。我用谷歌搜索,在这个网站上搜索了 13 页,但仍然找不到我要找的答案。 我希望视频以特定尺寸开始,然后随着我调整浏览器大小(从桌面到 iPad/iPhone)而缩
我已经从 sql server 2005 切换到 mysql,这并不是一个真正的问题。 我对 sql server 中存在的 (n)varchar 有一个小问题。通常我用过: mapping.Map(
我必须使用自定义 odbc 驱动程序。 我需要作为连接字符串传递的只是 DSN。 我如何使用(流畅)nhibernate 做到这一点? FluentNHibernate.Cfg.Db 仅提供带有 DS
我无法找到我们网站上动态显示的弹出窗口。最初该元素处于以下 html 状态: 使用jquery的show和hide,div显示5秒,稍后隐藏。 在我的 Selenium 脚本中,我尝试使用以下语句等
我有一个 two/three基于屏幕尺寸的列布局。 如果窗口大小大于 1000比我需要遵循 3 column其他布局我需要遵循 two column布局。 我是用JS实现的,但是代码很乱。现在我想用
我有一个 Flutter 应用程序,随着时间的推移和添加的功能越来越多,它变得越来越笨拙。因此,是否有一些实用程序可以使其像 60FPS 一样流畅? 我知道这里有一些官方指南:https://docs
我在如何实现 $(window).smartresize() 上纠结了几个小时使我的 div 流畅的功能。 我使用了这个 theme 中的 javascript但是当我尝试自己实现它时,我的 div
当我尝试通过 canvas.getContext('2d') 和 canvas.getContext('webgl') 将相同的 PNG 文件加载到 Canvas 中时,发现与canvas2d相比,w
我有一个所有实体的基类: public class BaseClass { public int SomeProperty {get; set;} } public class SomeEnt
我正在从事一个对时间相当敏感的元素。任务是制作一个微型网站,用户可以通过他们的智能手机访问该网站,在那里他们可以访问许多电影。他们会扫描二维码(我知道他们已经死了,我没有计划这次事件)。并登陆这个网站
我们正在使用Entity Framework 5.0。和数据库MySQL。当我们尝试迁移时间时出现异常。 could not be created because the principal key
快速问题:如何将传递给shiny.fluent::Text函数的文本设置为粗体?更广泛地说,如何将样式选项传递给此函数?。在函数的帮助页面中,它是这样写的。但我不明白如何使用这个变量参数。。我试着在不
我是一名优秀的程序员,十分优秀!