首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用分页库在RecyclerVew中实现进度条(当向下滚动以加载更多内容时)?

使用分页库在RecyclerVew中实现进度条(当向下滚动以加载更多内容时)?
EN

Stack Overflow用户
提问于 2017-12-10 05:15:54
回答 1查看 835关注 0票数 0

下面是我当前代码中的几个片段,但当用力滚动时,动画就像到达了列表的底部一样,我想在其中添加进度条/微调器,就像在fb/insta提要中一样。

虽然新的项目在列表中更新时,再次向下滚动,但我希望过渡顺利与进度条,而不是每次看起来像饲料已经结束。

蒂娅。

代码语言:javascript
运行
复制
public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        RecyclerView recyclerView = findViewById(R.id.userList);
        LinearLayoutManager llm = new LinearLayoutManager(this);
        llm.setOrientation(LinearLayoutManager.VERTICAL);
        recyclerView.setLayoutManager(llm);

        UserViewModel viewModel = ViewModelProviders.of(this).get(UserViewModel.class);
        viewModel.init();
        final UserAdapter userUserAdapter = new UserAdapter();

        viewModel.userList.observe(this, pagedList -> {
            userUserAdapter.setList(pagedList);
        });

        recyclerView.setAdapter(userUserAdapter);
    }
}

DataSource:

代码语言:javascript
运行
复制
public class MyDataSource extends TiledDataSource<User> {

    Webservice webservice;

    MyDataSource(){
    webservice = WebServiceImpl.createGitHubService();
    }

    @Override
    public int countItems() {
        return DataSource.COUNT_UNDEFINED;
    }

    @Override
    public List<User> loadRange(int startPosition, int count) {
        List<User> gitHubUser = new ArrayList();
        try {
            Response<List<User>> response = webservice.getUsers(startPosition,count).execute();
            if (response.isSuccessful() && response.code() == 200) {
                gitHubUser.addAll(response.body());
            } else {
                Log.e("API CALL", response.message());
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
        return gitHubUser;
    }    }

ViewModel:

代码语言:javascript
运行
复制
public class UserViewModel extends ViewModel {

    public LiveData<PagedList<User>> userList;
    MyDataSource tDataSource;

    public UserViewModel() {

    }

    public void init() {

        userList = new LivePagedListProvider<Integer, User>() {
            @Override
            protected DataSource<Integer, User> createDataSource() {
                tDataSource = new MyDataSource();
                return tDataSource;
            }

        }.create(0, new PagedList.Config.Builder()
                .setEnablePlaceholders(false)
                .setPageSize(20)
                .setInitialLoadSizeHint(20)
                .build());
    }
}
EN

回答 1

Stack Overflow用户

发布于 2017-12-10 15:38:25

创建一个助手类EndlessRecyclerOnScrollListener。将以下代码粘贴到其中。

代码语言:javascript
运行
复制
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;

public abstract class EndlessRecyclerOnScrollListener extends RecyclerView.OnScrollListener {
    public static String TAG = EndlessRecyclerOnScrollListener.class.getSimpleName();

    private int previousTotal = 0; // The total number of items in the dataset after the last load
    private boolean loading = true; // True if we are still waiting for the last set of data to load.
    private int visibleThreshold = 5; // The minimum amount of items to have below your current scroll position before loading more.
    int firstVisibleItem, visibleItemCount, totalItemCount;

    private int current_page = 1;

    private LinearLayoutManager mLinearLayoutManager;

    public EndlessRecyclerOnScrollListener(LinearLayoutManager linearLayoutManager) {
        this.mLinearLayoutManager = linearLayoutManager;
    }

    @Override
    public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
        super.onScrolled(recyclerView, dx, dy);

        visibleItemCount = recyclerView.getChildCount();
        totalItemCount = mLinearLayoutManager.getItemCount();
        firstVisibleItem = mLinearLayoutManager.findFirstVisibleItemPosition();

        if (loading) {
            if (totalItemCount > previousTotal) {
                loading = false;
                previousTotal = totalItemCount;
            }
        }
        if (!loading && (totalItemCount - visibleItemCount)
                <= (firstVisibleItem + visibleThreshold)) {
            // End has been reached

            // Do something
            current_page++;

            onLoadMore(current_page);

            loading = true;
        }
    }

    public abstract void onLoadMore(int current_page);
}

在您的活动中,添加以下代码。

代码语言:javascript
运行
复制
public class SampleActivity extends ActionBarActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_sample);

        RecyclerView recyclerView = (RecyclerView) findViewById(R.id.list);
        LinearLayoutManager linearLayoutManager = new LinearLayoutManager(this);
        recyclerView.setLayoutManager(linearLayoutManager);
        recyclerView.setOnScrollListener(new EndlessRecyclerOnScrollListener(linearLayoutManager) {
            @Override
            public void onLoadMore(int current_page) {
                // make progress bar visible.
                //call API
            }
        });
    }
}

在activiy的xml中,在recyclerview下面放置一个进度条。在这里,当recyclerview滚动到底部时,将调用onLoadMore()。

有关更多信息,请参阅https://gist.github.com/ssinss/e06f12ef66c51252563e

票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47733276

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档