//---------------主布局文件----------------------------

<ListView android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:id="@+id/lv"></ListView>

//---------------主Activity------------------------------

package com.example.listviewscroll;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.ArrayList;
import java.util.List;

import com.example.listviewscroll.JingDian.ResultBean;
import com.example.listviewscroll.JingDian.ResultBean.RowsBean;

import com.google.gson.Gson;

import android.os.AsyncTask;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.app.Activity;
import android.util.Log;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.AbsListView;
import android.widget.TextView;
import android.widget.Toast;
import android.widget.AbsListView.OnScrollListener;
import android.widget.ListView;

public class MainActivity extends Activity {

    private ListView lv;
    private List<RowsBean> rowsBeans = new ArrayList<JingDian.ResultBean.RowsBean>();        
    private MyAdapter adapter;
    private List<RowsBean> list;
    // 定义一个页数
    private int ye = 0;

    private Handler handler = new Handler() {
        public void handleMessage(Message msg) {
            switch (msg.what) {
            case 0:
                // 获得数据
                String text = (String) msg.obj;
                tojson(text);
                break;

            default:
                break;
            }
        }

    };
    
    
//----------注意:使用了Gson.jar包-解析json串---------

    // 解析数据
    private void tojson(String text) {
        
        Gson gson = new Gson();
        // 类名
        JingDian jingDian = gson.fromJson(text, JingDian.class);

        ResultBean resultBean = jingDian.getResult();
        // 添加
        rowsBeans = resultBean.getRows();
        Log.i("11111111111", rowsBeans.toString());
        list.addAll(rowsBeans);
        
          //更新适配器
        if (adapter == null) {
            adapter = new MyAdapter(list,this);            
            lv.setAdapter(adapter);             
            } else {                 
                adapter.notifyDataSetChanged();
                }
                 
    };
    
//------------------onCreate中------------------
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //找到控件Listview
        lv = (ListView) findViewById(R.id.lv);
      
        list=new ArrayList<JingDian.ResultBean.RowsBean>();
        //获得网络数据
        huodeshuju(ye);
        //设置Listview的滑动监听
        lv.setOnScrollListener(new OnScrollListener() {
            
            @Override
            public void onScrollStateChanged(AbsListView view, int scrollState) {
                switch (scrollState) {
                //滚动结束
                case OnScrollListener.SCROLL_STATE_IDLE:
                    //滚动停止时,判断如果滚动到底部
                    if (view.getLastVisiblePosition()==view.getCount()-1) {
                        
                        // 使页数加1
                        ye++;
                        Toast.makeText(MainActivity.this, "" + ye, Toast.LENGTH_SHORT).show();
                        huodeshuju(ye);
                        adapter.notifyDataSetChanged();
                        
                        
                    }else if (view.getFirstVisiblePosition()==0) {
                        //滚动到顶部
                        // 重新定义为第一页
                        
                        list.clear();
                        ye = 1;
                        Toast.makeText(MainActivity.this, "" + ye, Toast.LENGTH_SHORT).show();
                        // 获得数据
                        huodeshuju(ye);
                        // 刷新适配器
                        adapter.notifyDataSetChanged();
                        
                    }
                    
                    break;
                //开始滚动
                case OnScrollListener.SCROLL_STATE_FLING:
                    
                    break;
                //正在滚动
                case OnScrollListener.SCROLL_STATE_TOUCH_SCROLL:
                    
                    break;

                default:
                    break;
                }
                
            }
            
            @Override
            public void onScroll(AbsListView view, int firstVisibleItem,int visibleItemCount, int totalItemCount) {
                
                
            }
        });
       
        
    }
    
    
    
    // 获得数据
        private void huodeshuju(final int ye) {
            // 使用线程

            new Thread() {
                public void run() {
                    try {
                        // 先创建出了一个URL对象,urlPath:是我们访问接口地址
                        URL url = new URL(
                                "http://api.fang.anjuke.com/m/android/1.3/shouye/recInfosV3/?city_id=14&lat=40.04652&lng=116.306033&api_key=androidkey&sig=9317e9634b5fbc16078ab07abb6661c5&macid=45cd2478331b184ff0e15f29aaa89e3e&app=a-ajk&_pid=11738&o=PE-TL10-user+4.4.2+HuaweiPE-TL10+CHNC00B260+ota-rel-keys%2Crelease-keys&from=mobile&m=Android-PE-TL10&cv=9.5.1&cid=14&i=864601026706713&v=4.4.2&qtime=20160411091603&pm=b61&uuid=1848c59c-185d-48d9-b0e9-782016041109&_chat_id="
                                        + ye);

                        // URL链接对象,通过URL对象打开一个connection链接对像
                        HttpURLConnection urlConnection = (HttpURLConnection) url
                                .openConnection();
                        // 设置urlConnection对象链接超时
                        urlConnection.setConnectTimeout(5000);
                        // 设置urlConnection对象获取数据超时
                        urlConnection.setReadTimeout(5000);
                        // 设置本次urlConnection请求方式
                        urlConnection.setRequestMethod("GET");

                        // 获取本次网络请求的状态码
                        int code = urlConnection.getResponseCode();
                        // 如果本次返回的状态吗是200(成功)
                        if (code == 200) {
                            // 调用urlConnection.getInputStream得到本次请求所返回的结果流
                            InputStream inputStream = urlConnection
                                    .getInputStream();
                            // 创建一个BufferedReader,去读取结果流
                            BufferedReader reader = new BufferedReader(
                                    new InputStreamReader(inputStream));
                            String readLine;
                            StringBuffer buffer = new StringBuffer();
                            while ((readLine = reader.readLine()) != null) {
                                buffer.append(readLine);

                            }
                            // 读取完结果流之后所得到的结果
                            String result = buffer.toString();
                            Log.i("数据:----", ye + ":" + result);
                            Message message = new Message();
                            message.what = 0;
                            message.obj = result;
                            handler.sendMessage(message);

                        }
                    } catch (MalformedURLException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                    } catch (IOException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                    }

                };
            }.start();
            
            

        }

    
    
}

Listview的OnScrollListener的滑动监听实现分页加载的更多相关文章

  1. 纯JS监听document是否加载完成

    欢迎加入前端交流群交流知识&&获取视频资料:749539640 概述 一个document 的 Document.readyState 属性描述了文档的加载状态. 一个文档的 read ...

  2. ListView实现分页加载(三)实现分页加载

    在上一篇中,我们实现了底部布局(即带上了进度条).没有读过的朋友可以点击下面的链接: http://www.cnblogs.com/fuly550871915/p/4866966.html 但是进度条 ...

  3. 使用swipecard实现卡片视图左右滑动监听以及点击监听

     前言: 大家好,今天给大家介绍安卓一种特别实用有很酷炫的组件swipecard,当然这并不是安卓爸爸创造的,这是国内的一个我认为是大牛的一个人随便写着玩儿搞出来了,我看了他的代码介绍已经很清晰了,但 ...

  4. Android 自定义ScrollView的滑动监听事件

    项目结构: 1.LazyScrollView类(自定义ScrollView) package android.zhh.com.myapplicationscrollview; /** * Create ...

  5. Android RecyclerView滑动监听,判断是否滑动到了最后一个item

    项目中的需求,RecyclerView横向滑动列表,要有加载更多的功能,给RecyclerView设置一个滑动监听,在onScrolled方法中判断一下滑动方向,然后在onScrollStateCha ...

  6. 移动端H5页面惯性滑动监听

    移动端H5页面惯性滑动监听 在移动端,当你快速滑动有滚动条的页面时,当你手指离开屏幕时,滚动条并不会立即停止,而是会随着"惯性"继续滑动一段距离. 在做项目的过程中,需要监听惯性滑 ...

  7. listview下拉刷新 上拉(滑动分页)加载更多

    最 近做的类似于微博的项目中,有个Android功能要使用到listview的向下拉刷新来刷新最新消息,向上拉刷新(滑动分页)来加载更多.新浪微博就是使用这种方式的典型.当用户从网络上读取微博的时候, ...

  8. ListView实现分页加载(一)制作Demo

    一.什么是分页加载 在下面的文章中,我们来讲解LitView分页加载的实现.什么是分页加载呢?我们先看几张效果图吧,如下:                                       ...

  9. Android基本控件之listView(三)<用ListView实现分页加载>

    我们之前讨论了ListView的基本使用方法和ListView的优化 今天我们再来讨论一个关于ListView的一个新的东西~就是分页加载.那么什么是分页加载呢?简单点说,就是"下拉刷新&q ...

随机推荐

  1. 一把刀终极配置 For XP v2.0 免费绿色版

    软件名称: 一把刀终极配置 For XP 软件语言: 简体中文 授权方式: 免费软件 运行环境: WinXP 软件大小: 924KB 图片预览: 软件简介: 一把刀终极配置 For XP,用于快速方便 ...

  2. dd if=/dev/zero of=的含义是什么?Linux 下的dd命令使用详解

    http://blog.sina.com.cn/s/blog_8b5bb24f01016y3o.html 一.dd命令的解释 dd:用指定大小的块拷贝一个文件,并在拷贝的同时进行指定的转换. 注意:指 ...

  3. iOS UITextView 根据输入text自适应高度

    转载自:http://www.cnblogs.com/tmf-4838/p/5380495.html #import "ViewController.h" @interface V ...

  4. ssh连接ubuntu提示连接不上的问题

    今天在自己的电脑上安装了最新版本的 ubuntu (我都在root用户下运行,非root用户请添加sudo命令) uname -rvo 运行结果为 3.13.0-32-generic #57-Ubun ...

  5. HDU - 2255 奔小康赚大钱(最大带权匹配)

     Problem Description 传说在遥远的地方有一个非常富裕的村落,有一天,村长决定进行制度改革:重新分配房子.这可是一件大事,关系到人民的住房问题啊.村里共有n间房间,刚好有n家老百姓, ...

  6. pudn下载地址的规律

    A:http://download.pudn.com/downloads15/sourcecode/app/354278Cams.rar(随机数字6个)B:http://www.pudn.com/do ...

  7. 瑞游天翼客户端win7,win8,win10

    以管理员身份运行即可, 链接: http://pan.baidu.com/s/1kTw7VH9 密码: vttq

  8. 如何在VBS脚本中显示“选择文件对话框”或“选择目录对话框”

    .选择文件[XP操作系统,不能用于Win2000或98],使用“UserAccounts.CommonDialog”对象向用户显示一个标准的“文件打开”对话框 Set objDialog = Crea ...

  9. Chapter 2 Open Book——19

    He bent over and began scraping together a pile of the white mush. 他弯下腰,开始团起一个白色的雪球. "I'll see ...

  10. H5的新应用-在地图上标识附近加油站的地址

    ------------------------ <style type="text/css">          html{height:100%}         ...