android142 360 分页加载
dao:
package com.itheima.mobileguard.db.dao; import java.util.ArrayList;
import java.util.List; import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.SystemClock; import com.itheima.mobileguard.db.BlackNumberDBOpenHelper;
import com.itheima.mobileguard.domain.BlackNumberInfo; /**
* 黑名单数据库的增删改查工具类
*
* @author Administrator
*
*/
public class BlackNumberDao {
private BlackNumberDBOpenHelper helper; public BlackNumberDao(Context context) {
helper = new BlackNumberDBOpenHelper(context);
} /**
* 添加黑名单号码
*
* @param number
* 号码
* @param mode
* 拦截模式
* @return 是否添加成功
*/
public boolean add(String number, String mode) {
// 获取到可写的数据库
SQLiteDatabase db = helper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("number", number);
values.put("mode", mode);
long rowid = db.insert("blackinfo", null, values);
if (rowid == -1) {
return false;
} else {
return true;
}
} /**
* 删除黑名单号码
*
* @param number
* 号码
* @return 是否删除成功
*/
public boolean delete(String number) {
// 获取到可写的数据库
SQLiteDatabase db = helper.getWritableDatabase();
int rownumber = db.delete("blackinfo", "number=?",
new String[] { number });
if (rownumber == 0) {
return false;
} else {
return true;
}
} /**
* 修改黑名单号码的拦截模式
*
* @param number
* 号码
* @param newmode
* 新的拦截模式
* @return 是否修改成功
*/
public boolean changeBlockMode(String number, String newmode) {
// 获取到可写的数据库
SQLiteDatabase db = helper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("mode", newmode);
int rownumber =db.update("blackinfo", values, "number=?", new String[]{number});
if (rownumber == 0) {
return false;
} else {
return true;
}
}
/**
* 返回一个黑名单号码拦截模式
* @param number 要查询的黑名单号码
* @return 0不是黑名单号码不拦截 1全部拦截 2短信拦截 3电话拦截
*/
public String findBlockMode(String number){
String mode = "0";
// 获取到可读的数据库
SQLiteDatabase db = helper.getReadableDatabase();
Cursor cursor = db.query("blackinfo", new String[]{"mode"}, "number=?", new String[]{number}, null, null, null);
if(cursor.moveToNext()){
mode = cursor.getString(0);
}
cursor.close();
db.close();
return mode;
} /**
* 查询全部的黑名单号码
*/
public List<BlackNumberInfo> findAll(){
// 得到可读的数据库
SQLiteDatabase db = helper.getReadableDatabase();
Cursor cursor = db.query("blackinfo", new String[]{"number","mode"}, null, null, null, null, null);
List<BlackNumberInfo> blackNumberInfos = new ArrayList<BlackNumberInfo>();
while(cursor.moveToNext()){
BlackNumberInfo info = new BlackNumberInfo();
String number = cursor.getString(0);
String mode = cursor.getString(1);
info.setMode(mode);
info.setNumber(number);
blackNumberInfos.add(info);
}
cursor.close();
db.close();
SystemClock.sleep(3000);
return blackNumberInfos;
} /**
* 分页查询数据库的记录
* @param pagenumber 第几页,页码 从第0页开始
* @param pagesize 每一个页面的大小
*/
public List<BlackNumberInfo> findPart(int pagenumber,int pagesize){
// 得到可读的数据库
SQLiteDatabase db = helper.getReadableDatabase();
Cursor cursor = db.rawQuery("select number,mode from blackinfo limit ? offset ?", new String[]{String.valueOf(pagesize),
String.valueOf(pagesize*pagenumber)
});
List<BlackNumberInfo> blackNumberInfos = new ArrayList<BlackNumberInfo>();
while(cursor.moveToNext()){
BlackNumberInfo info = new BlackNumberInfo();
String number = cursor.getString(0);
String mode = cursor.getString(1);
info.setMode(mode);
info.setNumber(number);
blackNumberInfos.add(info);
}
cursor.close();
db.close();
SystemClock.sleep(30);
return blackNumberInfos;
} /**
* 分批加载数据
* @param startIndex 从哪个位置开始加载数据
* @param maxCount 最多加载几条数据
*/
public List<BlackNumberInfo> findPart2(int startIndex,int maxCount){
// 得到可读的数据库
SQLiteDatabase db = helper.getReadableDatabase();
Cursor cursor = db.rawQuery("select number,mode from blackinfo order by _id desc limit ? offset ?", new String[]{String.valueOf(maxCount),
String.valueOf(startIndex)
});
List<BlackNumberInfo> blackNumberInfos = new ArrayList<BlackNumberInfo>();
while(cursor.moveToNext()){
BlackNumberInfo info = new BlackNumberInfo();
String number = cursor.getString(0);
String mode = cursor.getString(1);
info.setMode(mode);
info.setNumber(number);
blackNumberInfos.add(info);
}
cursor.close();
db.close();
SystemClock.sleep(30);
return blackNumberInfos;
} /**
* 获取数据库的总条目个数
* @param pagenumber 第几页,页码 从第0页开始
* @param pagesize 每一个页面的大小
*/
public int getTotalNumber(){
// 得到可读的数据库
SQLiteDatabase db = helper.getReadableDatabase();
Cursor cursor = db.rawQuery("select count(*) from blackinfo",null);
cursor.moveToNext();
int count = cursor.getInt(0);
cursor.close();
db.close();
return count;
}
}
选择页码跳页加载 activity:
package com.itheima.mobileguard.activities; import java.util.List; import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.text.TextUtils;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.EditText;
import android.widget.LinearLayout;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast; import com.itheima.mobileguard.R;
import com.itheima.mobileguard.db.dao.BlackNumberDao;
import com.itheima.mobileguard.domain.BlackNumberInfo; public class CallSmsSafeActivity2 extends Activity {
private ListView lv_callsms_safe;
private LinearLayout ll_add_number_tips;
private LinearLayout ll_loading;
/**
* 页面输入框
*/
private EditText et_page_number; /**
* 页码信息
*/
private TextView tv_page_info; /**
* 页面大小
*/
private static final int pageSize = 20;
/**
* 当前页码号
*/
private int curentPgeNumber = 0;
/**
* 一共有多少页
*/
private int totalPage = 0; private BlackNumberDao dao;
private List<BlackNumberInfo> infos;
/**
* 消息处理器
*/
private Handler handler = new Handler(){
public void handleMessage(android.os.Message msg) {
ll_loading.setVisibility(View.INVISIBLE);
if (infos.size() == 0) {
// 没有数据,设置添加数据的提醒
ll_add_number_tips.setVisibility(View.VISIBLE);
} else {
lv_callsms_safe.setAdapter(new CallSmsSafeAdapter());
}
};
}; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
initUI();
fillData();
} /**
* 填充数据
*/
private void fillData() {
dao = new BlackNumberDao(this);
//数据库的总条目个数 / 每个页面最多显示多少条数据
totalPage = dao.getTotalNumber()/pageSize;
tv_page_info.setText(curentPgeNumber+"/"+totalPage);
//耗时的操作 逻辑应该放在子线程里面执行。
ll_loading.setVisibility(View.VISIBLE);
new Thread(){
public void run() {
infos = dao.findPart(curentPgeNumber, pageSize);
handler.sendEmptyMessage(0);
};
}.start();
} /**
* 初始化ui的逻辑块
*/
private void initUI() {
setContentView(R.layout.activity_callsms_safe);
ll_add_number_tips = (LinearLayout) findViewById(R.id.ll_add_number_tips);
ll_loading = (LinearLayout) findViewById(R.id.ll_loading);
lv_callsms_safe = (ListView) findViewById(R.id.lv_callsms_safe);
et_page_number = (EditText) findViewById(R.id.et_page_number);
tv_page_info = (TextView) findViewById(R.id.tv_page_info);
} private class CallSmsSafeAdapter extends BaseAdapter { @Override
public int getCount() {
return infos.size();
} //这个方法要被执行很多次, 有多个条目 就要执行多少次
@Override
public View getView(int position, View convertView, ViewGroup parent) {
System.out.println("getview:"+position);
View view;
ViewHolder holder;
if (convertView == null) {
view = View.inflate(CallSmsSafeActivity2.this,
R.layout.item_callsms, null);
holder = new ViewHolder(); //减少子孩子查询的次数
holder.tv_phone = (TextView) view
.findViewById(R.id.tv_item_phone);
holder.tv_mode = (TextView) view.findViewById(R.id.tv_item_mode);
//把孩子id的引用 存放在holder里面,设置给父亲 view
view.setTag(holder);
} else {
view = convertView; //使用历史缓存view对象, 减少view对象被创建的次数
holder = (ViewHolder) view.getTag();
} BlackNumberInfo info = infos.get(position);
holder.tv_phone.setText(info.getNumber());
// 1 全部拦截 2 短信拦截 3 电话拦截
String mode = info.getMode();
if ("1".equals(mode)) {
holder.tv_mode.setText("全部拦截");
} else if ("2".equals(mode)) {
holder.tv_mode.setText("短信拦截 ");
} else if ("3".equals(mode)) {
holder.tv_mode.setText("电话拦截 ");
}
return view;
} @Override
public Object getItem(int position) {
return null;
} @Override
public long getItemId(int position) {
return 0;
}
} /**
* 家庭组 view对象的容器
* @author Administrator
*
*/
class ViewHolder{
TextView tv_phone;
TextView tv_mode;
} /**
* 上一页
* @param view
*/
public void prePage(View view){
if(curentPgeNumber<=0){
Toast.makeText(this, "已经是第一页", 0).show();
return;
}
curentPgeNumber--;
fillData();
} /**
* 下一页
* @param view
*/
public void nextPage(View view){
if(curentPgeNumber>(totalPage-1)){
Toast.makeText(this, "已经是最后一页", 0).show();
return;
}
curentPgeNumber++;
fillData();
} /**
* 跳转
* @param view
*/
public void jump(View view){
String str_pagenumber = et_page_number.getText().toString().trim();
if(TextUtils.isEmpty(str_pagenumber)){
Toast.makeText(this, "请输入页面号", 0).show();
}else{
int number = Integer.parseInt(str_pagenumber);
if(number>=0&&number<totalPage){
curentPgeNumber=number;
fillData();
}else{
Toast.makeText(this, "请输入正确的页面号", 0).show();
}
}
}
}
没有页码滑动分批加载Activity:
package com.itheima.mobileguard.activities; import java.util.List; import android.app.Activity;
import android.app.AlertDialog;
import android.app.AlertDialog.Builder;
import android.os.Bundle;
import android.os.Handler;
import android.text.TextUtils;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.AbsListView.OnScrollListener;
import android.widget.BaseAdapter;
import android.widget.CheckBox;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast; import com.itheima.mobileguard.R;
import com.itheima.mobileguard.db.dao.BlackNumberDao;
import com.itheima.mobileguard.domain.BlackNumberInfo; public class CallSmsSafeActivity extends Activity {
private ListView lv_callsms_safe;
private LinearLayout ll_add_number_tips;
private LinearLayout ll_loading; private BlackNumberDao dao;
private List<BlackNumberInfo> infos; // 代表就是当前界面的集合。 private CallSmsSafeAdapter adapter; /**
* 开始获取数据的位置
*/
private int startIndex = 0; /**
* 一次最多获取几条数据
*/
private int maxCount = 20; private int totalCount = 0; /**
* 消息处理器
*/
private Handler handler = new Handler() {
public void handleMessage(android.os.Message msg) {
ll_loading.setVisibility(View.INVISIBLE);
if (infos.size() == 0) {
// 没有数据,设置添加数据的提醒
ll_add_number_tips.setVisibility(View.VISIBLE);
} else {
if (adapter == null) {
adapter = new CallSmsSafeAdapter();
lv_callsms_safe.setAdapter(adapter);
} else {// 数据适配器是已经存在的。
// 因为数据适配器里面的数据 已经变化。刷新界面。
adapter.notifyDataSetChanged();
}
}
};
}; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
initUI();
fillData();
} /**
* 填充数据
*/
private void fillData() {
dao = new BlackNumberDao(this);
totalCount = dao.getTotalNumber();
// 数据库的总条目个数 / 每个页面最多显示多少条数据
// 耗时的操作 逻辑应该放在子线程里面执行。
ll_loading.setVisibility(View.VISIBLE);
new Thread() {
public void run() {
if (infos == null) {
infos = dao.findPart2(startIndex, maxCount);
} else {
// 集合里面原来有数据,新的数据应该放在旧的集合的后面。
infos.addAll(dao.findPart2(startIndex, maxCount));
}
handler.sendEmptyMessage(0);
};
}.start();
} /**
* 初始化ui的逻辑块
*/
private void initUI() {
setContentView(R.layout.activity_callsms_safe);
ll_add_number_tips = (LinearLayout) findViewById(R.id.ll_add_number_tips);
ll_loading = (LinearLayout) findViewById(R.id.ll_loading);
lv_callsms_safe = (ListView) findViewById(R.id.lv_callsms_safe); lv_callsms_safe.setOnScrollListener(new OnScrollListener() {
// 滚动状态发生变化调用的方法。
// OnScrollListener.SCROLL_STATE_FLING 惯性滑动
// OnScrollListener.SCROLL_STATE_TOUCH_SCROLL 触摸滑动
// OnScrollListener.SCROLL_STATE_IDLE 静止
@Override
public void onScrollStateChanged(AbsListView view, int scrollState) {
switch (scrollState) {
case OnScrollListener.SCROLL_STATE_IDLE: // 静止状态
// 判断是否是最后一个条目。
int lastPosition = lv_callsms_safe.getLastVisiblePosition();
System.out.println("最后一个可见条目的位置:" + lastPosition);
if (lastPosition == infos.size() - 1) { // //20条数据
// 加载下20条数据。 更改加载数据的开始位置
startIndex += maxCount;
if (startIndex >= totalCount) {//已经到达最后
Toast.makeText(getApplicationContext(),
"没有更多的数据了。", 0).show();
return;
}
fillData();
}
break;
}
} // 只要listview发生滚动 就会调用下面的方法
@Override
public void onScroll(AbsListView view, int firstVisibleItem,
int visibleItemCount, int totalItemCount) { }
}); } private class CallSmsSafeAdapter extends BaseAdapter { @Override
public int getCount() {
return infos.size();
} // 这个方法要被执行很多次, 有多个条目 就要执行多少次
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View view;
ViewHolder holder;
if (convertView == null) {
view = View.inflate(CallSmsSafeActivity.this,
R.layout.item_callsms, null);
holder = new ViewHolder(); // 减少子孩子查询的次数
holder.tv_phone = (TextView) view
.findViewById(R.id.tv_item_phone);
holder.tv_mode = (TextView) view
.findViewById(R.id.tv_item_mode);
holder.iv_delete = (ImageView) view
.findViewById(R.id.iv_delete);
// 把孩子id的引用 存放在holder里面,设置给父亲 view
view.setTag(holder);
} else {
view = convertView; // 使用历史缓存view对象, 减少view对象被创建的次数
holder = (ViewHolder) view.getTag();
} final BlackNumberInfo info = infos.get(position);
holder.iv_delete.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
String number = info.getNumber();
// 从数据库删除黑名单号码
boolean result = dao.delete(number);
if (result) {
Toast.makeText(getApplicationContext(), "删除成功", 0)
.show();
// 从界面ui里面删除信息
infos.remove(info);
// 通知界面刷新
adapter.notifyDataSetChanged();
} else {
Toast.makeText(getApplicationContext(), "删除失败", 0)
.show();
}
}
});
holder.tv_phone.setText(info.getNumber());
// 1 全部拦截 2 短信拦截 3 电话拦截
String mode = info.getMode();
if ("1".equals(mode)) {
holder.tv_mode.setText("全部拦截");
} else if ("2".equals(mode)) {
holder.tv_mode.setText("短信拦截 ");
} else if ("3".equals(mode)) {
holder.tv_mode.setText("电话拦截 ");
}
return view;
} @Override
public Object getItem(int position) {
return null;
} @Override
public long getItemId(int position) {
return 0;
}
} /**
* 家庭组 view对象的容器
*
* @author Administrator
*
*/
class ViewHolder {
TextView tv_phone;
TextView tv_mode;
ImageView iv_delete;
} /**
* 添加黑名单号码
*
* @param view
*/
public void addBlackNumber(View view) {
AlertDialog.Builder builder = new Builder(this);
View dialogView = View.inflate(this, R.layout.dialog_add_blacknumber,
null);
final AlertDialog dialog = builder.create();
final EditText et_black_number = (EditText) dialogView
.findViewById(R.id.et_black_number);
final CheckBox cb_phone = (CheckBox) dialogView
.findViewById(R.id.cb_phone);
final CheckBox cb_sms = (CheckBox) dialogView.findViewById(R.id.cb_sms);
dialogView.findViewById(R.id.bt_cancel).setOnClickListener(
new OnClickListener() {
@Override
public void onClick(View v) {
dialog.dismiss();
}
});
dialogView.findViewById(R.id.bt_ok).setOnClickListener(
new OnClickListener() {
@Override
public void onClick(View v) {
String blackNumber = et_black_number.getText()
.toString().trim();
if (TextUtils.isEmpty(blackNumber)) {
Toast.makeText(getApplicationContext(), "号码不能为空", 1)
.show();
return;
}
String mode = "0";
// 1 全部拦截 2 短信拦截 3 电话拦截
if (cb_phone.isChecked() && cb_sms.isChecked()) {
mode = "1";
} else if (cb_phone.isChecked()) {
mode = "3";
} else if (cb_sms.isChecked()) {
mode = "2";
} else {
Toast.makeText(getApplicationContext(), "请选择拦截模式",
1).show();
return;
}
// 把数据添加到数据库
boolean result = dao.add(blackNumber, mode);
// 刷新界面。 把数据加入到infos集合里面。
if (result) {
BlackNumberInfo info = new BlackNumberInfo();
info.setMode(mode);
info.setNumber(blackNumber);
infos.add(0, info);// 界面的数据集合发生了变化。
// 通知界面刷新。
if (adapter != null) {
adapter.notifyDataSetChanged();
} else {
adapter = new CallSmsSafeAdapter();
lv_callsms_safe.setAdapter(adapter);
}
} dialog.dismiss();
}
}); dialog.setView(dialogView, 0, 0, 0, 0);
dialog.show();
} }
android142 360 分页加载的更多相关文章
- java攻城狮之路(Android篇)--widget_webview_metadata_popupwindow_tabhost_分页加载数据_菜单
一.widget:桌面小控件1 写一个类extends AppWidgetProvider 2 在清单文件件中注册: <receiver android:name=".ExampleA ...
- Android基本控件之listView(三)<用ListView实现分页加载>
我们之前讨论了ListView的基本使用方法和ListView的优化 今天我们再来讨论一个关于ListView的一个新的东西~就是分页加载.那么什么是分页加载呢?简单点说,就是"下拉刷新&q ...
- Android ListView分页加载时图片显示问题
场景:Android ListView需要分页加载,每个item中会有图片,图片又是从网络下载的. 问题:在滑动加载下一页时,上一页的图片明明已经下载完成了,但是无法显示出来. Bug重现: 1,加载 ...
- Android中ListView分页加载数据
public class MainActivity extends Activity { private ListView listView=null; //listview的数据填充器 privat ...
- ListView上拉刷新和分页加载完整的Dome
很多人工作的过程中都会碰到ListView下拉刷新和分页加载,然后大多数公司都已经把框架写好了,大家直接用就可以了,有些人一直对这个事情处于迷茫状态,为了让大家对上拉刷新和分页加载有一个比较全面的认识 ...
- 【Android进阶】Listview分页加载数据的实现
Listview分页加载数据的实现 public class MainActivity extends Activity { protected static final int SUCCESS_GE ...
- Jetpack 架构组件 Paging 分页加载 MD
Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...
- [转]微信小程序之加载更多(分页加载)实例 —— 微信小程序实战系列(2)
本文转自;http://blog.csdn.net/michael_ouyang/article/details/56846185 loadmore 加载更多(分页加载) 当用户打开一个页面时,假设后 ...
- ListView实现分页加载(三)实现分页加载
在上一篇中,我们实现了底部布局(即带上了进度条).没有读过的朋友可以点击下面的链接: http://www.cnblogs.com/fuly550871915/p/4866966.html 但是进度条 ...
随机推荐
- 改变DEV控件的字体 z
改变所有的组件字体,使用AppearanceObject.DefaultFont属性:static void Main() { DevExpress.Utils.AppearanceObject ...
- leveldb源码笔记
关于KV数据库leveldb的介绍,网上已经太多了,这里只是自己再学习源码过程中,整理的笔记,磁盘存储和内存存储的结构用了伪代码表示出来了,首先是内存中存储结构,然后是log文件存储结构和磁盘数据ss ...
- hdu1722 bjfu1258 辗转相除法
这题就是个公式,代码极简单.但我想,真正明白这题原理的人并不多.很多人只是随便网上一搜,找到公式a了就行,其实这样对自己几乎没有提高. 鉴于网上关于这题的解题报告中几乎没有讲解原理的,我就多说几句,也 ...
- Cloudera CDH5 部署实战指南(离线安装)
配置软件源服务器 1.安装createreporpm -ivh deltarpm-3.5-0.5.20090913git.el6.x86_64.rpm rpm -ivh python-deltarpm ...
- 优秀java开源项目与解决方案推荐与概论
http://www.oschina.net/project/lang/19/java http://www.open-open.com/ http://java-source.net/ https: ...
- 第四次作业——WORDSEARCH小游戏
“谁想出来的这么缺德的题目啊!!!!”一个声音在我心中回荡 这个题目很早就在课堂上公布了,我和我的小伙伴都惊呆了! 这是个毛?根本无从下手的感觉 总是觉得这个小游戏不是程序能给出答案的,因为我的第一印 ...
- JDBC学习笔记(8)——数据库连接池(dbcp&C3P0)
JDBC数据库连接池的必要性 一.在使用开发基于数据库的web程序时,传统的模式基本是按一下步骤: 1)在主程序(如servlet/beans)中建立数据库连接 2)进行sql操作 3)断开数据库连接 ...
- 使用MySQL正则表达式查询
MySQL用WHERE子句对正则表达式提供了初步的支持,允许你指定用正则表达式过滤SELECT检索出的数据. REGEXP后所跟的东西作为正则表达式处理. 代码 SELECT prod_name FR ...
- 分析nginx access log日志的命令
统计访问最多的ip 1. tail -n 10000 xxaccess_log | cut -d " " -f 1 |sort|uniq -c|sort -rn|head -10 ...
- Linux下移植pjsip,使用QT开发
1.移植pjsip env:fedora14 arm-linuc-gcc:gcc version 4.5.1 (ctng-1.8.1-FA) #./configure \ CC=arm-linux-g ...