为什么findFirstVisibleItemPosition不能按预期工作?

时间:2017-07-18 16:44:58

标签: android listview android-recyclerview

我正在努力解决这个问题很长一段时间我试图用recyclerview替换我的listview,我的listview看起来像这样: -

<ListView
            android:id="@+id/browser_sub_list_view"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_alignParentBottom="true"
            android:layout_alignParentTop="true"
            android:clipToPadding="false"
            android:drawSelectorOnTop="true"
            android:paddingTop="340dp"/>

现在我打电话

view.getFirstVisiblePosition(); 

在这个列表视图中,我返回第一个项目的位置为零,因为我已经给出了顶部填充,所以它将一直返回零,直到第一个项目超出屏幕范围。

但是当我试图用recyclerview做同样的事情时,即使第一项recyclerview可见仍然它给了我不同的第一个可见项的值,它发生因为recyclerview认为toppadding为屏幕绑定现在我没有任何线索如何解决这个问题。 请帮忙。

这是我的代码。

MainActivity.Java

public class MainActivity extends AppCompatActivity {
    private RecyclerView mRecyclerView;
    private TheAdapter adapter;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mRecyclerView = (RecyclerView) findViewById(R.id.recyclerview);
        mRecyclerView.setLayoutManager(new LinearLayoutManager(this));

        ArrayList<String> items = new ArrayList<>();
        for (int i = 0; i < 300; i++) {
            items.add("This is item:-" + i);
        }

        adapter = new TheAdapter(items);
        mRecyclerView.setAdapter(adapter);
        mRecyclerView.addOnScrollListener(new RecyclerView.OnScrollListener() {
            @Override
            public void onScrollStateChanged(RecyclerView recyclerView, int newState) {
                super.onScrollStateChanged(recyclerView, newState);
            }

            @Override
            public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
                LinearLayoutManager linearLayoutManager = (LinearLayoutManager) recyclerView.getLayoutManager();
                Log.d("DISTANCE", "" + linearLayoutManager.findFirstVisibleItemPosition());
            }
        });
    }
}

activity_main.xml中

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
                xmlns:tools="http://schemas.android.com/tools"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                tools:context=".MainActivity">

    <android.support.v7.widget.RecyclerView
        android:id="@+id/recyclerview"
        android:layout_width="match_parent"
        android:clipToPadding="false"
        android:paddingTop="340dp"
        android:layout_height="match_parent"
        />

</RelativeLayout>

这是我的适配器类

class TheAdapter extends RecyclerView.Adapter<TheAdapter.ItemHolder> {

    public TheAdapter(ArrayList<String> data) {
        mData = data;
    }

    private ArrayList<String> mData;

    @Override
    public ItemHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.list_item, parent, false);

        return new ItemHolder(view);
    }

    @Override
    public void onBindViewHolder(ItemHolder holder, int position) {
        holder.mTextView.setText(mData.get(position));
    }

    @Override
    public int getItemCount() {

        return mData == null ? 0 : mData.size();
    }

    public class ItemHolder extends RecyclerView.ViewHolder {
        private TextView mTextView;

        public ItemHolder(View itemView) {
            super(itemView);
            mTextView = (TextView) itemView.findViewById(R.id.textTitle);
        }
    }
}

1 个答案:

答案 0 :(得分:2)

在找到更好的答案之前,您可以尝试以下代码。 int posfindFirstVisibleItemPosition()报告的位置。此方法将返回RecyclerView中最顶层的可见位置。

public int findRealFirstVisibleItemPosition(int pos) {
    View view;
    final LinearLayoutManager linearLayoutManager =
            (LinearLayoutManager) mRecyclerView.getLayoutManager();

    while (pos > 0) {
        view = linearLayoutManager.findViewByPosition(pos - 1);
        if (view == null) {
            break;
        }
        pos = pos - 1;
    }

    return pos;
}

我似乎记得大填充导致这些类型的滚动视图问题。