- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在 NestedScrollView 中有 Recyclerview。现在我有 1000 个项目要填充到 Recylerview 中,但它的显示 UI 在其主线程上工作太多,并且不断崩溃或要求等待消息。任何建议将不胜感激。
UI:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/view_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/bg">
<android.support.v4.widget.NestedScrollView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fillViewport="true">
<android.support.v7.widget.RecyclerView
android:id="@+id/recylerview"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:divider="@null"
android:orientation="horizontal" />
</android.support.v4.widget.NestedScrollView>
</RelativeLayout>
//List Item:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/view_main"
android:layout_width="match_parent"
android:layout_height="wrap_content"
>
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="4dp">
<RelativeLayout
android:id="@+id/rl_img"
android:layout_width="@dimen/img_wextra"
android:layout_height="wrap_content"
android:background="@drawable/rl_bg"
android:layout_alignBottom="@+id/ll_info"
android:layout_alignTop="@+id/tv_title"
android:orientation="horizontal">
<ImageView
android:id="@+id/img"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
android:padding="4dp"
android:maxHeight="30dp"
android:maxWidth="30dp"
android:scaleType="fitXY" />
<ProgressBar
android:id="@+id/pb_img"
android:layout_width="@dimen/pb_size"
android:layout_height="@dimen/pb_size"
android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
android:visibility="visible"
/>
</RelativeLayout>
<ImageView
android:id="@+id/img_arrow"
android:layout_width="@dimen/frwd_size"
android:layout_height="@dimen/frwd_size"
android:layout_alignParentEnd="true"
android:layout_alignParentRight="true"
android:layout_centerVertical="true"
android:src="@drawable/icon_next" />
<me.grantland.widget.AutofitTextView
android:id="@+id/tv_title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/ll_info"
android:layout_toLeftOf="@+id/img_arrow"
android:textColor="@color/item_heading"
android:textSize="@dimen/text_size_medium" />
<me.grantland.widget.AutofitTextView
android:id="@+id/tv_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/ll_info"
android:layout_below="@+id/tv_title"
android:layout_toLeftOf="@+id/img_arrow"
android:textSize="@dimen/text_size_small" />
<me.grantland.widget.AutofitTextView
android:id="@+id/tv_data"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/ll_info"
android:layout_below="@+id/tv_name"
android:layout_toLeftOf="@+id/img_arrow"
android:textSize="@dimen/text_size_small" />
<LinearLayout
android:id="@+id/ll_info"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_above="@+id/ll_btns"
android:layout_alignLeft="@+id/ll_btns"
android:layout_below="@+id/tv_loc"
android:layout_marginLeft="4dp"
android:layout_marginTop="4dp"
android:layout_toLeftOf="@+id/img_arrow"
android:layout_toRightOf="@+id/rl_img"
android:orientation="horizontal">
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical">
<TextView
android:id="@+id/tv_title_1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1.5"
android:textColor="@color/text_heading_color"
android:textSize="@dimen/text_size_small" />
<TextView
android:id="@+id/tv_title_2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1.5"
android:textColor="@color/text_heading_color"
android:textSize="@dimen/text_size_small" />
<TextView
android:id="@+id/tv_title_3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1.5"
android:textColor="@color/text_heading_color"
android:textSize="@dimen/text_size_small" />
<TextView
android:id="@+id/tv_title_4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1.5"
android:textColor="@color/text_heading_color"
android:textSize="@dimen/text_size_small" />
</LinearLayout>
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical">
<TextView
android:id="@+id/tv_userName"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight=".5"
android:maxLines="1"
android:text="0000000"
android:textColor="@color/colorBlack"
android:textSize="@dimen/text_size_small" />
<TextView
android:id="@+id/tv_userdes"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight=".5"
android:maxLines="1"
android:text="0000000"
android:textColor="@color/colorBlack"
android:textSize="@dimen/text_size_small" />
<TextView
android:id="@+id/tv_usernum"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight=".5"
android:maxLines="1"
android:text="0000000"
android:textColor="@color/colorBlack"
android:textSize="@dimen/text_size_small" />
<TextView
android:id="@+id/tv_userrating"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight=".5"
android:maxLines="1"
android:text="0000000"
android:textColor="@color/colorBlack"
android:textSize="@dimen/text_size_small" />
</LinearLayout>
</LinearLayout>
</RelativeLayout>
</RelativeLayout>
Code:
recylerview.setLayoutManager(new LinearLayoutManager(getContext(), LinearLayoutManager.VERTICAL, false));
recylerview.setItemAnimator(new DefaultItemAnimator());
recylerview.setNestedScrollingEnabled(false);
recylerview.addItemDecoration(new SimpleDividerItemDecoration(getActivity()));
ItemOffsetDecoration itemDecoration = new ItemOffsetDecoration(getActivity(), R.dimen.item_offset_mini);
recylerview.addItemDecoration(itemDecoration);
recylerview.setAdapter(itemAdapter);
//Adapter
public class ItemAdapter extends RecyclerView.Adapter<ItemAdapter.ItemViewHolder> {
public interface OnItemClickListener {
void onItemClick(ItemModel item);
}
private List<ItemModel> items;
private Context context;
private OnItemClickListener listener;
public ItemAdapter(Context context, List<ItemModel> items, OnItemClickListener listener) {
this.items = items;
this.context = context;
this.listener = listener;
}
@Override
public ItemAdapter.ItemViewHolder onCreateViewHolder(ViewGroup viewGroup, int i) {
View view = LayoutInflater.from(viewGroup.getContext()).inflate(R.layout.item, viewGroup, false);
return new ItemViewHolder(view);
}
@Override
public void onBindViewHolder(ItemAdapter.ItemViewHolder viewHolder, int i) {
viewHolder.bind(items.get(i), listener);
viewHolder.tv_title.setText(items.get(i).getTitle());
viewHolder.tv_name.setText(items.get(i).getItemTitle());
viewHolder.tv_loc.setText(items.get(i).getItemLoc());
viewHolder.tv_name.setTextColor(Color.BLACK);
viewHolder.tv_loc.setTextColor(Color.BLACK);
viewHolder.tv_userName.setText(items.get(i).getUserName());
viewHolder.tv_userdes.setText(items.get(i).getUserDes());
FragmentUtils.setBOLDFont(viewHolder.tv_title);
FragmentUtils.setFont(viewHolder.tv_name);
FragmentUtils.setFont(viewHolder.tv_loc);
FragmentUtils.setFont(viewHolder.tv_title_1);
FragmentUtils.setFont(viewHolder.tv_title_2);
FragmentUtils.setFont(viewHolder.tv_title_3);
FragmentUtils.setFont(viewHolder.tv_title_4);
// Loading profile image
if (items.get(i).getImage().size() != 0) {
Drawable myIcon = context.getResources().getDrawable( R.drawable.not_found );
ImageUtils.displayImageFromUrl(context, items.get(i).getImage().get(0).getThumbnail(), viewHolder.img,myIcon, new RequestListener<Drawable>() {
@Override
public boolean onLoadFailed(@android.support.annotation.Nullable GlideException e, Object model, Target<Drawable> target, boolean isFirstResource) {
viewHolder.pb_img.setVisibility(View.GONE);
return false;
}
@Override
public boolean onResourceReady(Drawable resource, Object model, Target<Drawable> target, DataSource dataSource, boolean isFirstResource) {
viewHolder.pb_img.setVisibility(View.GONE);
return false;
}
});
} else {
ImageUtils.displayImageFromResources(context, viewHolder.img, R.drawable.not_found);
viewHolder.pb_img.setVisibility(View.GONE);
}
}
@Override
public int getItemCount() {
return items.size();
}
public class ItemViewHolder extends RecyclerView.ViewHolder {
@BindView(R.id.tv_title)
public TextView tv_title;
@BindView(R.id.tv_name)
public TextView tv_name;
@BindView(R.id.tv_des)
public TextView tv_des;
@BindView(R.id.tv_userName)
public TextView tv_userName;
@BindView(R.id.tv_userLoc)
public TextView tv_userLoc;
@BindView(R.id.img)
public ImageView img;
@BindView(R.id.pb_img)
public ProgressBar pb_img;
@BindView(R.id.tv_title_1)
public TextView tv_title_1;
@BindView(R.id.tv_title_2)
public TextView tv_title_2;
@BindView(R.id.tv_title_3)
public TextView tv_title_3;
@BindView(R.id.tv_title_4)
public TextView tv_title_4;
public ItemViewHolder(View view) {
super(view);
ButterKnife.bind(this, view);
}
public void bind(final ItemModel item, final OnItemClickListener listener) {
itemView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
listener.onItemClick(item);
}
});
}
}
}
///Log:
01-23 10:14:19.343 11462-11467/com.app I/art: Do full code cache collection, code=252KB, data=241KB
01-23 10:14:19.344 11462-11467/com.app I/art: Starting a blocking GC JitCodeCache
01-23 10:14:19.344 11462-11467/com.app I/art: After code cache collection, code=213KB, data=181KB
01-23 10:14:20.212 11462-11467/com.app I/art: Do partial code cache collection, code=250KB, data=207KB
01-23 10:14:20.213 11462-11467/com.app I/art: After code cache collection, code=250KB, data=207KB
01-23 10:14:20.213 11462-11467/com.app I/art: Increasing code cache capacity to 1024KB
01-23 10:14:27.706 11462-11462/com.app I/Choreographer: Skipped 505 frames! The application may be doing too much work on its main thread.
01-23 10:14:35.519 11462-11462/com.app I/Choreographer: Skipped 464 frames! The application may be doing too much work on its main thread.
01-23 10:14:43.019 11462-11462/com.app I/Choreographer: Skipped 449 frames! The application may be doing too much work on its main thread.
01-23 10:14:50.488 11462-11462/com.app I/Choreographer: Skipped 447 frames! The application may be doing too much work on its main thread.
最佳答案
发生这种情况是因为您有一个 <RecyclerView>
用 wrap_content
标记因为它在 <NestedScrollView>
中的高度.这意味着您的 1000 个项目中的每一个都将有一个为其创建的 viewholder,从而导致数千个 View 被膨胀和填充。我想即使您等待所有这些发生,您的应用程序也会崩溃并显示 OutOfMemoryError
。 .
明显的问题是为什么要在 NestedScrollView 中包含 RecyclerView。如果你有这个:
<RelativeLayout
...>
<android.support.v7.widget.RecyclerView
android:id="@+id/recylerview"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
</RelativeLayout>
RecyclerView 实际上能够执行 View 回收,您的应用应该会响应。
关于android - NestedScrollview 中的 Recyclerview(有很多项目)崩溃了 Android,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48394581/
所以我有一个 Fragment,它使用 CoordinatorLayout,里面有一个 NestedScrollView。 NestedScrollView 内部是一个 ViewPager。 View
我知道这个问题很多,但我尝试了几乎所有的解决方案,即使是神奇的解决方案显然对我不起作用!:(父级是 NestedScrollview,在子级中还有另一个嵌套 ScrollView ) pare
我想在滚动式 Instagram 时将 TabLayout 固定在顶部。有没有办法在 NestedScrollView 中执行此操作? NestedScrollView -- ConstraintLa
我的构造中有两个项目,一个是静态项目,另一个是带有可拖动项目的回收 View 。两种类型的 View 都由 LinearLayout 包装。 LinearLayout 由 NestedScrollVi
java.lang.NoSuchMethodError: No virtual method setOnScrollChangeListener(Landroidx/core/widget/Neste
我有一个带有RecyclerView的PagedListAdapter。 当我将RecyclerView放入NestedScrollView中时,PagedList无法计算列表的末尾,因此start请
我将 CollapsingToolbarLayout 与 NestedScrollView 结合使用,在 NestedScrollView 内我有一个项目列表,但在执行中我无法滚动所有项目。 在我的示
我试图将后退按钮保留在页面底部,并让嵌套 ScrollView 填充页面底部统计信息相对布局和后退按钮下方的空间。它目前适合顶部的统计信息,但由于它适合页面,所以将后退按钮推离了页面底部。
所以我在 styles.xml 中为 AppTheme NoActionBar 设置,因为我只希望在几个 Activites 中使用工具栏,并且我还创建了包含两个项目的 post_details_me
这是我 Activity 中的原始布局: 看起来不错: 内容布局文件包含一个 TableLayout。 由于内容可能很长,我添加了一个 Neste
我使用 https://github.com/nhaarman/ListViewAnimations实现拖放,滑动删除等。但是有问题第一个图像可以滚动列表但不能拖放(它下降到相同的位置并且不进入onI
我在 CoordinatorLayout 中有一个 NestedScrollView。在 NestedScrollView 中,我有一个包含一些组件的 LinearLayout,其中一些是按钮。组件没
我注意到 CoordinatorLayout 内的 NestedSCrollView 中的内容如果没有填满整个屏幕,则始终对齐在底部。我该如何解决? 我的代码:
我正在使用 NestedScrollView 以达到某些目的 similar to this . 更新 这是我的 repo . 我发现当移动设备变成横向滚动时,我无法看到按钮或底部的灰色 View 。
我似乎找不到 nestedScrollView 的选项使其水平而不是垂直。我一直在使用 HorizontalScrollView 但我想切换到嵌套。有没有办法做到这一点?搜索文档我没有看到它,但它
我的 xml 由一个约束布局组成。这里面有 2 个按钮和 1 个嵌套的 ScrollView 。 ScrollView 中有各种元素,包括回收 View 。我希望回收 View 不滚动,而只滚动嵌套的
我在 NestedScrollview 中有一个 Recyclerview.. 一切正常,除了一个 thig。我在 NestedScrollview 中共有三个 View ,前两个是 LinearLa
我在我的 fragment 中使用 NestedScrollView。在我的 xml 中的 RelativeLayout 但它没有覆盖整个屏幕高度。 下面是我的代码 - 运行代码时,只有黑色
在我的应用程序中,我需要复杂的 ScrollView 。作为垂直列表和动画标题中的水平列表。下面的代码是一个极简示例,可以使我的问题在 iOS 设备上重现。 我在 flutter 中遇到嵌套 Scro
我正在使用带有标题图像的 CoordinatorLayout 制作详细 View ,我想在具有 NestedScrollView 的 View 中应用圆角边缘,如下所示: 我正在使用带有标题图像的 C
我是一名优秀的程序员,十分优秀!