RecyclerView滚动问题(子项远离彼此)

时间:2016-06-20 20:24:18

标签: android view scroll

Goodd day。我有简单的回收站视图和最简单的虚拟数据用于测试目的,因此我有一个奇怪的问题谷歌没有找到任何解决方案甚至根本没有问题。首次启动视图是好的,但一旦我开始流口水,孩子们的物品彼此相距甚远,因为没有人可以想象...真的非常非常远。但问题是实际的子项目布局参数是正确的,唯一的问题是我不知道为什么RecyclerView决定让每个项目远离彼此。请你帮我一个忙吗?发布我的RecyclerView的完整代码。

recyclerView的视图

   <?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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="match_parent"
    app:layout_behavior="@string/appbar_scrolling_view_behavior"
    tools:context="com.ink.activities.HomeActivity"
    tools:showIn="@layout/app_bar_home">

    <android.support.v7.widget.RecyclerView
        android:id="@+id/recycler_view"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:scrollbars="vertical" />
</RelativeLayout>

适配器。

public class FeedAdapter extends RecyclerView.Adapter<FeedAdapter.ViewHolder> {

    private List<FeedModel> feedList;
    private Context mContext;

    public class ViewHolder extends RecyclerView.ViewHolder {
        public TextView title, content;

        public ViewHolder(View view) {
            super(view);
            title = (TextView) view.findViewById(R.id.feedTitle);
            content = (TextView) view.findViewById(R.id.feedContent);
        }
    }


    public FeedAdapter(List<FeedModel> feedList, Context context) {
        mContext = context;
        this.feedList = feedList;
    }

    @Override
    public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        View itemView = LayoutInflater.from(parent.getContext())
                .inflate(R.layout.feed_single_view, parent, false);

        return new ViewHolder(itemView);
    }

    @Override
    public void onBindViewHolder(ViewHolder holder, int position) {
        FeedModel feedModel = feedList.get(position);
        holder.title.setText(feedModel.getTitle());
        holder.content.setText(feedModel.getContent());

//        animate(holder);
    }


    public void animate(RecyclerView.ViewHolder viewHolder) {
        final Animation animAnticipateOvershoot = AnimationUtils.loadAnimation(mContext, R.anim.bounce_interpolator);
        viewHolder.itemView.setAnimation(animAnticipateOvershoot);
    }

    @Override
    public int getItemCount() {
        return feedList.size();
    }
}

我猜你不需要持有人,因为没有任何观点。 RecyclerView适配器的单子项视图。

<?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"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <android.support.v7.widget.CardView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_margin="10dp"
        android:clickable="true"
        android:foreground="?android:attr/selectableItemBackground"
        app:cardCornerRadius="5dp"
        app:cardElevation="10dp">

        <RelativeLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content">

            <TextView
                android:id="@+id/feedTitle"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_centerHorizontal="true"
                android:layout_marginTop="10dp"
                android:fontFamily="@string/appFont"
                android:text="loading...."
                android:textColor="#000000"
                android:textSize="20sp" />

            <TextView
                android:id="@+id/feedContent"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_below="@+id/feedTitle"
                android:layout_marginLeft="2dp"
                android:layout_marginRight="2dp"
                android:layout_marginTop="10dp" />
        </RelativeLayout>
    </android.support.v7.widget.CardView>
</LinearLayout>

启动实际参数。

 mRecyclerView = (RecyclerView) findViewById(R.id.recycler_view);

        mAdapter = new FeedAdapter(mFeedModelArrayList, this);
        RecyclerView.ItemAnimator itemAnimator = new DefaultItemAnimator();
        itemAnimator.setAddDuration(500);
        itemAnimator.setRemoveDuration(500);
        mRecyclerView.setLayoutManager(new LinearLayoutManager(this));
        mRecyclerView.setItemAnimator(itemAnimator);

这段代码非常简单,重要的是要提到我在android studio的默认NAVIGATION DRAWER ACTIVITY内部(content_main layout内的默认模板)启动所有这些。所以plaese can can你能给我一些关于这个问题的暗示吗?

1 个答案:

答案 0 :(得分:3)

你正在使用

android:layout_width="match_parent"
android:layout_height="match_parent"

关于您的子项目视图。截至Support Library 23.2

  

RecyclerView小部件为创建列表和网格以及支持动画提供了一个先进而灵活的基础。此版本为LayoutManager API带来了令人兴奋的新功能:自动测量!这允许RecyclerView根据其内容的大小调整自身大小。这意味着现在可以使用以前不可用的方案,例如使用WRAP_CONTENT作为RecyclerView的维度。您会发现所有内置的LayoutManagers现在都支持自动测量。

     

由于此更改,请务必仔细检查项目视图的布局参数:以前忽略的布局参数(例如滚动方向的MATCH_PARENT)现在将得到充分尊重。

如果您只希望自己的商品尺寸符合要求,请将layout_height更改为wrap_contentmatch_parent表示它们与屏幕一样大。