package com.sunway.works.applycash;

import java.util.ArrayList;

import java.util.Calendar;

import java.util.HashMap;

import java.util.List;

import java.util.Map;

import com.sunway.works.R;

import com.sunway.works.applycash.ApplyCashListActivity;

import com.sunway.works.cost.apply.EditExpenseActivity;

import com.sunway.works.cost.apply.ExpenseAuditActivity;

import com.sunway.works.entitys.ApplyCashEntity;

import com.sunway.works.entitys.IousEntity;

import com.sunway.works.network.HttpService;

import com.sunway.works.network.HttpServiceImpl;

import android.os.Bundle;

import android.os.Handler;

import android.os.Message;

import android.annotation.SuppressLint;

import android.app.Activity;

import android.app.DatePickerDialog;

import android.app.Dialog;

import android.app.Service;

import android.app.ActionBar.LayoutParams;

import android.content.Context;

import android.content.Intent;

import android.util.Log;

import android.view.Gravity;

import android.view.LayoutInflater;

import android.view.Menu;

import android.view.View;

import android.view.ViewGroup;

import android.view.Window;

import android.view.View.OnClickListener;

import android.view.inputmethod.InputMethodManager;

import android.view.WindowManager;

import android.widget.AbsListView;

import android.widget.AbsListView.OnScrollListener;

import android.widget.AdapterView.OnItemClickListener;

import android.widget.AdapterView;

import android.widget.BaseAdapter;

import android.widget.Button;

import android.widget.DatePicker;

import android.widget.EditText;

import android.widget.LinearLayout;

import android.widget.ListView;

import android.widget.PopupWindow;

import android.widget.ProgressBar;

import android.widget.SimpleAdapter;

import android.widget.Spinner;

import android.widget.TextView;

import android.widget.Toast;

public class EditOneCashActivity extends Activity implements

OnScrollListener {

private ListView listView;

private Context context;

private View top_title;

private TextView tvtitle;

private PopupWindow popupWindow;

private View view;

private View bar1;

private View bar2;

private Spinner sp_depart;

private EditText ed_iounnub;

private EditText ed_purpose;

private EditText ed_date_from;

private EditText ed_date_over;

private Button btn_date_from;

private Button btn_date_over;

private EditText ed_iousum;

private Spinner sp_checkstate;

private EditText ed_borrower;

private Button btn_query;

private Handler handler;

private static final int DATE_DIALOG_ID = 1;

private static final int SHOW_DATAPICK = 0;

private int mYear;

private int mMonth;

private int mDay;

private DeleteCashListAdapter adapter;

private List<ApplyCashEntity> listdata = new ArrayList<ApplyCashEntity>();

private InputMethodManager imm;

private Button btn_left;

private Button btn_right;

private List<ApplyCashEntity> loadDatas; // 载入数据

// private ChooseCheckmanAdapter adapters; //适配器

private LinearLayout loadingLayout;// 底部载入布局

private Map<Integer, Boolean> isCheckedMap = new HashMap<Integer, Boolean>();;

private boolean over;// 推断数据是否已所有载入

private Thread mThread;// 载入线程

private int unb = 1;

// 设置布局显示属性

private android.widget.LinearLayout.LayoutParams mLayoutParams = new LinearLayout.LayoutParams(

LinearLayout.LayoutParams.WRAP_CONTENT,

LinearLayout.LayoutParams.WRAP_CONTENT);

// 设置布局显示目标最大化属性

private android.widget.LinearLayout.LayoutParams FFlayoutParams = new LinearLayout.LayoutParams(

LinearLayout.LayoutParams.FILL_PARENT,

LinearLayout.LayoutParams.FILL_PARENT);

private ProgressBar progressBar;

private PopupWindow window;

private Intent intent;

private ListView list2;

Handler mhandler = new Handler() {

public void handleMessage(android.os.Message msg) {

switch (msg.what) {

case 1:// 推断是否数据已所有载入

if (!over) {

adapter.notifyDataSetChanged();

} else {

listView.removeFooterView(loadingLayout);

Toast.makeText(context, "数据载入完成", Toast.LENGTH_SHORT)

.show();

}

break;

case 2:

adapter.notifyDataSetChanged();

break;

}

};

};





@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

this.requestWindowFeature(Window.FEATURE_NO_TITLE);

setContentView(R.layout.activity_data_list);

context = getApplicationContext();

handler = new Handler();





// 初始化底部载入视图

LinearLayout layout = new LinearLayout(context);

layout.setOrientation(LinearLayout.HORIZONTAL);

progressBar = new ProgressBar(context);

progressBar.setPadding(0, 0, 15, 0);

layout.addView(progressBar, mLayoutParams);

TextView textView = new TextView(context);

textView.setText("载入中...");

textView.setGravity(Gravity.CENTER_VERTICAL);

layout.addView(textView, FFlayoutParams);

loadingLayout = new LinearLayout(context);

loadingLayout.addView(layout, mLayoutParams);

loadingLayout.setGravity(Gravity.CENTER);

// 初始化ListView并设定事件

initView();

       getListener();

}

private void getListener() {

btn_left.setOnClickListener(new OnClickListener() {

@Override

public void onClick(View v) {

// TODO Auto-generated method stub

finish();

}

});

}



private void initView() {

// TODO Auto-generated method stub

top_title = this.findViewById(R.id.top_title);

tvtitle = (TextView) top_title.findViewById(R.id.tvtitle);

btn_left = (Button) top_title.findViewById(R.id.btn_title_left);

btn_right = (Button) top_title.findViewById(R.id.btn_title_right);

listView = (ListView) findViewById(R.id.data_enterlist);

listView.addFooterView(loadingLayout);

//   listView.addFooterView()方法一定要在其setadapter()方法之前使用。不然报错

adapter = new DeleteCashListAdapter(EditOneCashActivity.this,

listdata, true);

listView.setAdapter(adapter);

listView.setOnScrollListener(EditOneCashActivity.this);

over = false;

}

@Override

public void onScroll(AbsListView view, int firstVisibleItem,

int visibleItemCount, int totalItemCount) {

if (firstVisibleItem + visibleItemCount == totalItemCount) {

if (mThread == null || !mThread.isAlive()) {

mThread = new Thread() {

public void run() {

//从网上读取要获得的数据   这是我自己的读取server的数据,个人因须要自己写自己的联网读取数据

HttpService service = new HttpServiceImpl();

String i = (10 * (unb - 1) + 1) + "";   //   i 是下标,决定从哪一条数据開始读,10代表每一次读取数据的条数

loadDatas = service.getApplyCashList(param1, i);

// 假设载入数据不为空,则将载入得到的数据加入到已有的mData数据中.否则数据载入全然

if (loadDatas != null && loadDatas.size() > 0) {

listdata.addAll(loadDatas);

loadDatas.clear();

} else {

unb = unb - 1;

over = true;

}

unb++;

mhandler.sendEmptyMessage(1);//更新UI

};

};

mThread.start();

}

}



}



@Override

public void onScrollStateChanged(AbsListView view, int scrollState) {

// TODO Auto-generated method stub



}



}

android listView 滑动载入数据 该数据是服务端获取的的更多相关文章

  1. Android ListView分页载入(服务端+android端)Demo

    Android ListView分页载入功能 在实际开发中经经常使用到,是每一个开发人员必须掌握的内容,本Demo给出了服务端+Android端的两者的代码,并成功通过了測试. 服务端使用MyEcli ...

  2. Android ListView滑动过程中图片显示重复错乱闪烁问题解决

    最新内容建议直接访问原文:Android ListView滑动过程中图片显示重复错乱闪烁问题解决 主要分析Android ListView滚动过程中图片显示重复.错乱.闪烁的原因及解决方法,顺带提及L ...

  3. Android从服务端获取json解析显示在客户端上面

    Android从服务端获取json解析显示在客户端上面 百度经验:jingyan.baidu.com 首先说一下Json数据的最基本的特点,Json数据是一系列的键值对的集合,和XML数据来比,Jso ...

  4. post数据过大到服务端,接收不到的问题

    在页面把datagrid上的数据post到服务端,解析提供导出.datagrid的数据大概有1w. 结果能post过去,但在服务端接收的数据显示null.但是如果post6000条左右就没问题. 经过 ...

  5. Java通过URL 从web服务端获取数据

    1.Java 通过HttpURLConnection Post方式提交json,并从服务端返回json数据 package Demo.Test; import java.io.ByteArrayOut ...

  6. 基于NIO的同步非阻塞编程完整案例,客户端发送请求,服务端获取数据并返回给客户端数据,客户端获取返回数据

    这块还是挺复杂的,挺难理解,但是多练几遍,多看看研究研究其实也就那样,就是一个Selector轮询的过程,这里想要双向通信,客户端和服务端都需要一个Selector,并一直轮询, 直接贴代码: Ser ...

  7. Android实时获得经纬度,发送给c++服务端

    Android 客户端: package com.example.admin.gpsget; import android.Manifest; import android.content.Conte ...

  8. 采用MQTT协议实现android消息推送(2)MQTT服务端与客户端软件对比、android客户端示列表

    1.服务端软件对比 https://github.com/mqtt/mqtt.github.io/wiki/servers 名称(点名进官网) 特性 简介 收费 支持的客户端语言 IBM MQ 完整的 ...

  9. Android ListView分页,动态添加数据

    1.ListView分页的实现,重点在于实现OnScrollListener接口,判断滑动到最后一项时,是否还有数据可以加载, 我们可以利用listView.addFootView(View v)方法 ...

随机推荐

  1. Leetcode 543.二叉树的直径

    二叉树的直径 给定一棵二叉树,你需要计算它的直径长度.一棵二叉树的直径长度是任意两个结点路径长度中的最大值.这条路径可能穿过根结点. 示例 :给定二叉树 1 / \ 2 3 / \ 4 5 返回 3, ...

  2. github pages+阿里云域名绑定搭建个人博客

    1.选择mast 配置cname 设置域名 同时在github设置里面进行绑定 2.获取github pages的ip地址 打开你的电脑的命令行工具,ping你的github地址,忽略"/& ...

  3. TOJ 3974: Region n条直线m个圆最多将圆分为几个区域

    3974: Region  Time Limit(Common/Java):1000MS/3000MS     Memory Limit:65536KByteTotal Submit: 33     ...

  4. Spring 简单而强大的事务管理功能

    开始之前 关于本教程 本教程将深入讲解 Spring 简单而强大的事务管理功能,包括编程式事务和声明式事务.通过对本教程的学习,您将能够理解 Spring 事务管理的本质,并灵活运用之. 先决条件 本 ...

  5. var和function定义方法的区别

    在JS中有两种定义函数的方式,1是var aaa=function(){...}2是function aaa(){...}var 方式定义的函数,不能先调用函数,后声明,只能先声明函数,然后调用.fu ...

  6. eclipse中xml文件报错异常处理

    最近一个Javaweb工程中常出现xml文件的xsd验证失败信息,异常如下: <?xml version="1.0" encoding="UTF-8"?& ...

  7. Linux中Source的用法

    source命令:source命令的功能:使Shell读入指定的Shell程序文件并依次执行文件中的所有语句source命令通常用于重新执行刚修改的初始化文件,使之立即生效,而不必注销并重新登录.用法 ...

  8. BZOJ 1452:[JSOI2009]Count(二维树状数组)

    [JSOI2009]Count 描述 输入 输出 1 2 分析: 裸二维bit,对每个颜色建一颗bit. program count; var bit:..,..,..]of longint; a:. ...

  9. 【bzoj3601】一个人的数论 莫比乌斯反演+高斯消元

    题目描述 题解 莫比乌斯反演+高斯消元 (前方高能:所有题目中给出的幂次d,公式里为了防止混淆,均使用了k代替) #include <cstdio> #include <cstrin ...

  10. 使用PropTypes进行类型检测

    PropTypes 是react提供的用于检验数据类型的typechecking,避免应用越来越大的时候出现意料之外的bug class Greeting extends React.Componen ...