BaseAdapterチュートリアル(2)BaseAdapterのnotifyDataSetChanged動的リフレッシュ

6640 ワード

BaseAdapterチュートリアル(2)BaseAdapterのnotifyDataSetChanged動的リフレッシュ
このような需要に直面して、ListViewは最底まで滑って、それから自動的に底に新しいCellを加えて、動的なリフレッシュを実現します.
 
1.まず、ListViewにsetOnScrollListenerを追加します.
        lvHomePostItem.setOnScrollListener(new AbsListView.OnScrollListener() {
            private Integer scrollState;
            @Override
            public void onScrollStateChanged(AbsListView view, int scrollState) {
                this.scrollState = scrollState;
                switch (scrollState) {
                    // Not scrolling
                    case AbsListView.OnScrollListener.SCROLL_STATE_IDLE:
                        // go to last cell
                        if (view.getLastVisiblePosition() == (view.getCount() - 1) && totalAmountOfLvItem <= 20 ) {
                            addData();
                        }
                        break;
                }
            }

            @Override
            public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {}
        });

2.addData()は、notifyDataSetChangedが呼び出されます.一方、notifyDataSetChangedは、UIをリフレッシュし、動的リフレッシュを実現するためにListViewをコールバックする.
    private Integer totalAmountOfLvItem = 0;
    private Integer getExtraNumberOfPost = 2;
    private String getHotPostByCursor;
    private String getPostResult;
    private List postExtraDTOs = new ArrayList();
    private ArrayList bitExtraMaps = new ArrayList();
    private void addData() {
        popupLoadingWindow();

        // Network thread
        new Thread(new Runnable() {
            @Override
            public void run() {

                totalAmountOfLvItem = postAdapter.getCount();

                // clear list
                if ( !postExtraDTOs.isEmpty()) {
                    postExtraDTOs.clear();
                }

                if ( !bitExtraMaps.isEmpty()) {
                    bitExtraMaps.clear();
                }

                // get extra post
                getHotPostByCursor = Configuration.getHotPostByCursor(totalAmountOfLvItem, getExtraNumberOfPost);
                getPostResult = okhttp.getResponse(getHotPostByCursor);
                postExtraDTOs = gsonTools.getPost(getPostResult);
                totalAmountOfLvItem += getExtraNumberOfPost;

                // get extra bitmap
                for ( int i = 0; i < postExtraDTOs.size(); i++ ) {
                    Bitmap temp = bitMap.returnBitMap(postExtraDTOs.get(i).getAbstractImg());
                    bitExtraMaps.add(temp);
                }

                // UI thread
                getActivity().runOnUiThread(new Runnable() {
                    @Override
                    public void run() {

                        // set extra post & bitmap into ListView Data
                        for ( int i = 0; i < postExtraDTOs.size(); i++ ) {
                            postHotDTOs.add(postExtraDTOs.get(i));
                            bitHotMaps.add(bitExtraMaps.get(i));
                        }

                        postAdapter.notifyDataSetChanged();
                        lvHomePostItem.setSelection(postAdapter.getCount()-1);

                        dismissPopupLoadingWindow();
                    }
                });

            }
        }).start();
    }

このように動的リフレッシュを実現します.
posted on
2017-12-27 22:13 chankuang読書(
...) コメント(
...) コレクションの編集
転載先:https://www.cnblogs.com/chenkuang/p/8127920.html