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 分页加载的更多相关文章

  1. java攻城狮之路(Android篇)--widget_webview_metadata_popupwindow_tabhost_分页加载数据_菜单

    一.widget:桌面小控件1 写一个类extends AppWidgetProvider 2 在清单文件件中注册: <receiver android:name=".ExampleA ...

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

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

  3. Android ListView分页加载时图片显示问题

    场景:Android ListView需要分页加载,每个item中会有图片,图片又是从网络下载的. 问题:在滑动加载下一页时,上一页的图片明明已经下载完成了,但是无法显示出来. Bug重现: 1,加载 ...

  4. Android中ListView分页加载数据

    public class MainActivity extends Activity { private ListView listView=null; //listview的数据填充器 privat ...

  5. ListView上拉刷新和分页加载完整的Dome

    很多人工作的过程中都会碰到ListView下拉刷新和分页加载,然后大多数公司都已经把框架写好了,大家直接用就可以了,有些人一直对这个事情处于迷茫状态,为了让大家对上拉刷新和分页加载有一个比较全面的认识 ...

  6. 【Android进阶】Listview分页加载数据的实现

    Listview分页加载数据的实现 public class MainActivity extends Activity { protected static final int SUCCESS_GE ...

  7. Jetpack 架构组件 Paging 分页加载 MD

    Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...

  8. [转]微信小程序之加载更多(分页加载)实例 —— 微信小程序实战系列(2)

    本文转自;http://blog.csdn.net/michael_ouyang/article/details/56846185 loadmore 加载更多(分页加载) 当用户打开一个页面时,假设后 ...

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

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

随机推荐

  1. HDU 5768 Lucky7 容斥原理+中国剩余定理(互质)

    分析: 因为满足任意一组pi和ai,即可使一个“幸运数”被“污染”,我们可以想到通过容斥来处理这个问题.当我们选定了一系列pi和ai后,题意转化为求[x,y]中被7整除余0,且被这一系列pi除余ai的 ...

  2. IOS PUSH 实践操作~~~~

    1.推送过程简介        (1)App启动过程中,使用UIApplication::registerForRemoteNotificationTypes函数与苹果的APNS服务器通信,发出注册远 ...

  3. sgu 176 Flow construction(有源汇的上下界最小流)

    [题目链接] http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=11025 [模型] 有源汇点的上下界最小流.即既满足上下界又满足 ...

  4. 用VMware 8安装Ubuntu 12.04详细过程(图解)

    转载 http://www.cnblogs.com/achillesyang/archive/2012/06/21/2557152.html

  5. [Hive - Tutorial] Type System 数据类型

    数据类型Type System Hive supports primitive and complex data types, as described below. See Hive Data Ty ...

  6. 第二百八十六天 how can I 坚持

    bug不断啊,头疼. 今天早上到的倒是挺早. 中午吃的黄焖鸡,晚上加了会班. 勇江的鱼都死了,杨建的还剩3条,晚上到家都快十点了,还洗了衣服,没捞出来呢, 希望可以请下来假吧. 晾上衣服睡觉.

  7. 什么是USBMini接口

    USB的接口有四种.一种是大头,有A型和B型两种,其中A型最常见,就是我们用的最多的标准的USB接头:一种是小头的,也就是USB Mini,也有A型和B型两种,其中B型应用最多,主要应用于手机.MP4 ...

  8. jquery.loadmask.js

    Quick Start 下载之后的目录结构如下图所示: 使用此插件非常简单,如下步骤所示: 1.  引用jquery,1.2.3以上版本 <script type="text/java ...

  9. Codeforces Round #271 (Div. 2) D. Flowers (递推)

    题目链接:http://codeforces.com/problemset/problem/474/D 用RW组成字符串,要求w的个数要k个连续出现,R任意,问字符串长度为[a, b]时,字符串的种类 ...

  10. type=INNODB和engine=INNODB的区别

    我在网站下载了一份源码,学习中, 发现type=INNODB,这个数据库引擎老实出错,,后来才一查资料才是: 在MYSQL5.5及以后版本中type=InnoDB 由ENGINE=InnoDB 代替. ...