Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/typescript/9.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
(Android)ListView:向下滚动时,一次加载5个项目_Android - Fatal编程技术网

(Android)ListView:向下滚动时,一次加载5个项目

(Android)ListView:向下滚动时,一次加载5个项目,android,Android,所以我制作了一个滑动标签应用程序,将json加载到listview中。我的问题是,我将如何实现一个在开始时只加载5个listview项,而在向下滚动时加载另5个listview项的功能?(而不是在开头加载所有listview项) 我已经在网上搜索过了,但我真的不知道该怎么做。如有任何建议或想法,将不胜感激 这是我的一些代码。这些类就是我认为代码应该用到的地方:我使用了android开发者网站上的SlidingTableLayout&strip 自定义列表适配器代码: public class C

所以我制作了一个滑动标签应用程序,将json加载到listview中。我的问题是,我将如何实现一个在开始时只加载5个listview项,而在向下滚动时加载另5个listview项的功能?(而不是在开头加载所有listview项)

我已经在网上搜索过了,但我真的不知道该怎么做。如有任何建议或想法,将不胜感激

这是我的一些代码。这些类就是我认为代码应该用到的地方:我使用了android开发者网站上的SlidingTableLayout&strip

自定义列表适配器代码:

public class CustomListAdapter extends BaseAdapter {
private Activity activity;
private LayoutInflater inflater;
private List<Tanga> tangasItems;
ImageLoader imageLoader = AppController.getInstance().getImageLoader();

public CustomListAdapter(Activity activity, List<Tanga> movieItems) {
    this.activity = activity;
    this.tangasItems = movieItems;
}

@Override
public int getCount() {
    return tangasItems.size();
}

@Override
public Object getItem(int location) {
    return tangasItems.get(location);
}

@Override
public long getItemId(int position) {
    return position;
}

@Override
public View getView(int position, View convertView, ViewGroup parent) {

    if (inflater == null)
        inflater = (LayoutInflater) activity
                .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    if (convertView == null)
        convertView = inflater.inflate(R.layout.list_row, null);

    TextView name = (TextView) convertView.findViewById(R.id.name);

    // getting movie data for the row
    Tanga m = tangasItems.get(position);

    // title
    name.setText(m.getName());

    return convertView;
}

}

有多种方法可以处理此问题,最简单的方法是创建另一个
Tanga
类型的
ArrayList
,假设它的名称是
tangaList2
。您必须做的是在for循环中编写此代码

public void onResponse(JSONArray response) {
                // Parsing json
                for (int i = 0; i < response.length(); i++) {
                    try {

                        JSONObject obj = response.getJSONObject(i);
                        Tanga movie = new Tanga();

                        //name
                        String name = obj.getString("name");
                        movie.setName(name);


                        // adding movie to movies array
                        if(i < 5) {
                        tangaList.add(movie);
                        }
                        else { 
                        tangaList2.add(movie);
                        }
                    } catch (JSONException e) {
                        e.printStackTrace();
                    }
                }

                // notifying list adapter about data changes
                // so that it renders the list view with updated data
                adapter.notifyDataSetChanged();
            }
public void onResponse(JSONArray响应){
//解析json
对于(int i=0;i
在此之后,您还应该在片段中实现onScrollListener:

     listView.setOnScrollListener(new AbsListView.OnScrollListener() {
        @Override
        public void onScrollStateChanged(AbsListView view, int scrollState) {

        }

        @Override
        public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
        if ((++firstVisibleItem) + visibleItemCount > totalItemCount)     {
        for(int i = 0; i < 5  && tangaList2.size() > 0; i++){
         tangaList.add(tangaList2.get(0));
         tangaList2.remove(0);
        }
        }
        }
    });
listView.setOnScrollListener(新的AbsListView.OnScrollListener(){
@凌驾
公共无效onScrollStateChanged(AbsListView视图,int scrollState){
}
@凌驾
public void onScroll(AbsListView视图、int firstVisibleItem、int visibleItemCount、int totalItemCount){
如果(++firstVisibleItem)+visibleItemCount>totalItemCount){
对于(int i=0;i<5&&tangaList2.size()>0;i++){
tangaList.add(tangaList2.get(0));
删除(0);
}
}
}
});

我来试试。谢谢。你介意,我在哪里添加listView.setOnScrollListener?在这一行之前添加它:JsonArrayRequest movieReq=new JsonArrayRequest(…)嗯,它告诉我无法解析符号OnScrollListener,建议我改为AbsListView.OnScrollListener。但是当我尝试时,它将方法更改为:public void onScrollStateChanged(AbsListView AbsListView,int I){}您好,很抱歉再次询问,但它给了我java.lang.IndexOutOfBoundsException:索引0无效,大小为0。。。。在com.example.mariogp18.tanga.Tab1$1.onScroll(Tab1.java:66)11使用视图持有者模式?将listview放在scrollview中,这样使用scrollview onScroll listener,您将获得项目数,因此,在每次滚动达到5个项目时,点击webservice获取剩余的5个项目
public void onResponse(JSONArray response) {
                // Parsing json
                for (int i = 0; i < response.length(); i++) {
                    try {

                        JSONObject obj = response.getJSONObject(i);
                        Tanga movie = new Tanga();

                        //name
                        String name = obj.getString("name");
                        movie.setName(name);


                        // adding movie to movies array
                        if(i < 5) {
                        tangaList.add(movie);
                        }
                        else { 
                        tangaList2.add(movie);
                        }
                    } catch (JSONException e) {
                        e.printStackTrace();
                    }
                }

                // notifying list adapter about data changes
                // so that it renders the list view with updated data
                adapter.notifyDataSetChanged();
            }
     listView.setOnScrollListener(new AbsListView.OnScrollListener() {
        @Override
        public void onScrollStateChanged(AbsListView view, int scrollState) {

        }

        @Override
        public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
        if ((++firstVisibleItem) + visibleItemCount > totalItemCount)     {
        for(int i = 0; i < 5  && tangaList2.size() > 0; i++){
         tangaList.add(tangaList2.get(0));
         tangaList2.remove(0);
        }
        }
        }
    });