当页面条目过多的时候需要分页,要在布局中显示出分页的相关布局,使用android:layout_weight="11"
activity_call_safe.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<TextView
style="@style/TitleStyle"
android:text="黑名单管理"
/>
<FrameLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_weight="11"
>
<LinearLayout
android:id="@+id/ll_pb"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:visibility="invisible"
android:orientation="vertical"
>
<ProgressBar
android:layout_width="wrap_content"
android:layout_height="wrap_content"
/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="玩命加载中..."
/>
</LinearLayout>
<include
android:id="@+id/list_view_callsafe"
layout="@layout/list_view_callsafe"/>
</FrameLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
>
<Button
android:onClick="prePage"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="上一页"
android:layout_weight="1"
/>
<Button
android:onClick="nextPage"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="下一页"
android:layout_weight="1"
/>
<Button
android:onClick="jump"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="跳转"
android:layout_weight="1"
/>
<EditText
android:id="@+id/et_page_number"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
/>
<TextView
android:id="@+id/tv_page_number"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="0/12"
android:textSize="20sp"
android:layout_weight="1"
/>
</LinearLayout>
</LinearLayout>
BlackNumberDao.java黑名单数据库的逻辑文件
package com.ldw.safe.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 com.ldw.safe.bean.BlackNumberInfo;
/*
* 黑名单数据库的逻辑文件
*/
public class BlackNumberDao {
private BlackNumberOpenHelper helper;
public BlackNumberDao(Context context){
helper = new BlackNumberOpenHelper(context);
}
//添加黑名单
//number黑名单号码,mode拦截模式,"blacknumber"是表名
public boolean add(String number, String mode){
SQLiteDatabase db = helper.getWritableDatabase();
ContentValues contentValues = new ContentValues();
contentValues.put("number", number);
contentValues.put("mode", mode);
long blacknumber = db.insert("blacknumber", null, contentValues);
if(blacknumber == -1){
//添加失败
return false;
}else{
return true;
}
}
//通过电话号码删除黑命单
//number电话号码,"blacknumber"是表名
public boolean delete(String number){
SQLiteDatabase db = helper.getWritableDatabase();
int rowNumber = db.delete("blacknumber", "number=?", new String[]{number});
if(rowNumber == 0){
//删除失败
return false;
}else{
return true;
}
}
//修改黑名单的模式
public boolean changeNumberMode(String number, String mode){
SQLiteDatabase db = helper.getWritableDatabase();
ContentValues contentValues = new ContentValues();
contentValues.put("mode", mode);
int rowNumber = db.update("blacknumber", contentValues, "number=?", new String[]{number});
if(rowNumber == 0){
//修改失败
return false;
}else{
return true;
}
}
//通过电话号码查找黑名单拦截模式
public String findNumber(String number){
String mode = "";
SQLiteDatabase db = helper.getWritableDatabase();
Cursor cursor = db.query("blacknumber", 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.getWritableDatabase();
List<BlackNumberInfo> blackNumberInfos = new ArrayList<BlackNumberInfo>();
Cursor cursor = db.query("blacknumber", new String[]{"number", "mode"}, null, null, null, null, null);
//查询所有的所有用while
while(cursor.moveToNext()){
BlackNumberInfo blackNumberInfo = new BlackNumberInfo();
blackNumberInfo.setNumber(cursor.getString(0));
blackNumberInfo.setMode(cursor.getString(1));
blackNumberInfos.add(blackNumberInfo);
}
cursor.close();
db.close();
return blackNumberInfos;
}
/*数据分页
* param pageNumber 表示当前是哪一页
* param pageSize 表示每一页有多少条数据
* return limit 表示限制当前有多少数据
* offset 表示跳过 从第几条开始
*/
public List<BlackNumberInfo> findPar(int pageNumber, int pageSize){
SQLiteDatabase db = helper.getWritableDatabase();
//分页查找数据
Cursor cursor = db.rawQuery("select number, mode from blacknumber limit ? offset ?",
new String[]{String.valueOf(pageSize),
String.valueOf(pageSize * pageNumber)});
ArrayList<BlackNumberInfo> blackNumberInfos = new ArrayList<BlackNumberInfo>();
while(cursor.moveToNext()){
BlackNumberInfo blackNumberInfo = new BlackNumberInfo();
blackNumberInfo.setNumber(cursor.getString(0));
blackNumberInfo.setMode(cursor.getString(1));
blackNumberInfos.add(blackNumberInfo);
}
cursor.close();
return blackNumberInfos;
}
/*
* 分批加载,网上拉的时候数据会自动加载
* startIndex 开始的位置
* maxCount 每页展示的最大的条目
*/
public List<BlackNumberInfo> findPar2(int startIndex, int maxCount) {
SQLiteDatabase db = helper.getReadableDatabase();
Cursor cursor = db.rawQuery("select number,mode from blacknumber limit ? offset ?", new String[]{String.valueOf(maxCount),
String.valueOf(startIndex)});
List<BlackNumberInfo> blackNumberInfos = new ArrayList<BlackNumberInfo>();
while (cursor.moveToNext()) {
BlackNumberInfo blackNumberInfo = new BlackNumberInfo();
blackNumberInfo.setMode(cursor.getString(1));
blackNumberInfo.setNumber(cursor.getString(0));
blackNumberInfos.add(blackNumberInfo);
}
cursor.close();
db.close();
return blackNumberInfos;
}
//获取总共有多少条数据
public int getTotalNumber(){
SQLiteDatabase db = helper.getReadableDatabase();
Cursor cursor = db.rawQuery("select count(*) from blacknumber", null);
cursor.moveToNext();
int count = cursor.getInt(0);
cursor.close();
db.close();
return count;
}
}
逻辑文件,实现分页显示,页面的跳转,页数的显示,数据的删除同时更新ListView
package com.ldw.safe.Activity;
import java.util.List;
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.text.TextUtils;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.Adapter;
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.ldw.safe.R;
import com.ldw.safe.adapter.MyBaseAdapter;
import com.ldw.safe.bean.BlackNumberInfo;
import com.ldw.safe.db.dao.BlackNumberDao;
public class CallSafeActivity extends Activity {
private ListView list_view_callsafe;
private List<BlackNumberInfo> blackNumberInfos;
private LinearLayout ll_pb;
private BlackNumberDao dao;
private TextView tv_page_number;
private int pageNumber;
private int mPageSize = 20;//每一页显示多少数据
private int mCurrentPageNumber = 0;//当前页面
private int totalPage;
private CallSafeAdapter adapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_call_safe);
initUi();
initData();
}
//初始化数据
private Handler handler = new Handler(){
@Override
public void handleMessage(Message msg) {
//通过总数,和每页显示多少条显示有多少条数据
tv_page_number.setText(mCurrentPageNumber + "/" + totalPage);
//数据初始化结束,关闭家在全的展示
ll_pb.setVisibility(View.INVISIBLE);
adapter = new CallSafeAdapter(blackNumberInfos, CallSafeActivity.this);
//配置适配器
list_view_callsafe.setAdapter(adapter);
}
};
private EditText et_page_number;
//初始化数据
private void initData() {
//防止阻塞主线程,在子线程中初始化数据(后期数据会很多)
new Thread(){
@Override
public void run(){
dao = new BlackNumberDao(CallSafeActivity.this);
//获取到总条数和页数
totalPage = dao.getTotalNumber() / mPageSize;
//获取到表的所有数据
//blackNumberInfos = dao.findAll();
//分页显示数据
blackNumberInfos = dao.findPar(mCurrentPageNumber, mPageSize);
handler.sendEmptyMessage(0);
}
}.start();
}
//初始化UI
private void initUi() {
ll_pb = (LinearLayout) findViewById(R.id.ll_pb);
//初始化的时候展示加载的圆圈
ll_pb.setVisibility(View.VISIBLE);
list_view_callsafe = (ListView) findViewById(R.id.list_view_callsafe);
tv_page_number = (TextView) findViewById(R.id.tv_page_number);
et_page_number = (EditText) findViewById(R.id.et_page_number);
}
//对代码进行优化,继承自定义MyBaseAdapter,MyBaseAdapter继承自BaseAdapter封装一些常用的方法
private class CallSafeAdapter extends MyBaseAdapter<BlackNumberInfo>{
private CallSafeAdapter(List lists, Context mContext){
super(lists, mContext);
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
//谷歌推出的优化方案
ViewHolder holder;
if(convertView == null){
convertView = View.inflate(CallSafeActivity.this, R.layout.item_call_safe, null);
holder = new ViewHolder();
holder.tv_number = (TextView) convertView.findViewById(R.id.tv_number);
holder.tv_mode = (TextView) convertView.findViewById(R.id.tv_mode);
holder.iv_delete = (ImageView) convertView.findViewById(R.id.iv_delete);
convertView.setTag(holder);
}else{
holder = (ViewHolder) convertView.getTag();
}
holder.tv_number.setText(lists.get(position).getNumber());
String mode = lists.get(position).getMode();
if(mode.equals("1")){
holder.tv_mode.setText("电话和短信拦截");
}else if(mode.equals("2")){
holder.tv_mode.setText("电话拦截");
}else if(mode.equals("3")){
holder.tv_mode.setText("短信拦截");
}
final BlackNumberInfo info = lists.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(CallSafeActivity.this, "删除成功", Toast.LENGTH_SHORT).show();
lists.remove(info);
//更新ListView
adapter.notifyDataSetChanged();
}else{
Toast.makeText(CallSafeActivity.this, "删除失败", Toast.LENGTH_SHORT).show();
}
}
});
return convertView;
/*
//谷歌推出的优化方案
ViewHolder holder;
if(convertView == null){
convertView = View.inflate(CallSafeActivity.this, R.layout.item_call_safe, null);
holder = new ViewHolder();
holder.tv_number = (TextView) convertView.findViewById(R.id.tv_number);
holder.tv_mode = (TextView) convertView.findViewById(R.id.tv_mode);
convertView.setTag(holder);
}else{
holder = (ViewHolder) convertView.getTag();
}
holder.tv_number.setText(blackNumberInfos.get(position).getNumber());
String mode = blackNumberInfos.get(position).getMode();
if(mode.equals("1")){
holder.tv_mode.setText("电话和短信拦截");
}else if(mode.equals("2")){
holder.tv_mode.setText("电话拦截");
}else if(mode.equals("3")){
holder.tv_mode.setText("短信拦截");
}
return convertView;
*/
/*初步的优化
convertView = View.inflate(CallSafeActivity.this, R.layout.item_call_safe, null);
TextView tv_number = (TextView) convertView.findViewById(R.id.tv_number);
TextView tv_mode = (TextView) convertView.findViewById(R.id.tv_mode);
tv_number.setText(blackNumberInfos.get(position).getNumber());
String mode = blackNumberInfos.get(position).getMode();
if(mode.equals("1")){
tv_mode.setText("电话和短信拦截");
}else if(mode.equals("2")){
tv_mode.setText("电话拦截");
}else if(mode.equals("3")){
tv_mode.setText("短信拦截");
}
return convertView;
*/
/*传统的方式
View view = View.inflate(CallSafeActivity.this, R.layout.item_call_safe, null);
TextView tv_number = (TextView) view.findViewById(R.id.tv_number);
TextView tv_mode = (TextView) view.findViewById(R.id.tv_mode);
tv_number.setText(blackNumberInfos.get(position).getNumber());
String mode = blackNumberInfos.get(position).getMode();
if(mode.equals("1")){
tv_mode.setText("电话和短信拦截");
}else if(mode.equals("2")){
tv_mode.setText("电话拦截");
}else if(mode.equals("3")){
tv_mode.setText("短信拦截");
}
return view;
*/
}
}
static class ViewHolder{
TextView tv_number;
TextView tv_mode;
ImageView iv_delete;
}
/*
* 上一页
*/
public void prePage(View v){
//页码不能超过范围
if(mCurrentPageNumber <= 0){
Toast.makeText(this, "这已经是第一页", Toast.LENGTH_SHORT).show();
return;
}
mCurrentPageNumber --;
initData();
}
/*
* 下一页
*/
public void nextPage(View v){
//页码不能超过范围
if(mCurrentPageNumber >= totalPage - 1){
Toast.makeText(this, "这已经是最后一页", Toast.LENGTH_SHORT).show();
return;
}
mCurrentPageNumber ++;
initData();
}
/*
* 跳转页面
*/
public void jump(View v){
String jump_page = et_page_number.getText().toString();
if(TextUtils.isEmpty(jump_page)){
Toast.makeText(this, "请输入正确的页码", Toast.LENGTH_SHORT).show();
}else{
//读取的字符串转换成int
int pageNumber = Integer.parseInt(jump_page);
if(pageNumber >=0 && pageNumber<= totalPage - 1){
mCurrentPageNumber = pageNumber;
initData();
}else{
Toast.makeText(this, "请输入正确的页码", Toast.LENGTH_SHORT).show();
}
}
}
}