[android] 手机卫士黑名单功能(列表展示)

2024-03-17 21:32

本文主要是介绍[android] 手机卫士黑名单功能(列表展示),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

先把要拦截的电话号码保存到数据库中,拦截模式用个字段区分,1 电话拦截,2 短信拦截,3全部拦截

 

新建ActivityCallSmsSafeActivity.java

新建布局文件activity_call_sms_safe.xml

列表展示所有的黑名单手机号码

在布局文件中添加<ListView>控件,定义一个id

获取ListView对象

调用ListView对象的setAdapter()方法,参数:ListAdapter对象

 

定义内部类CallSmsSafeAdapter继承系统的BaseAdapter

实现四个方法,重要的有两个getCount()getView()

实现getCount()方法,返回集合的长度

实现getView()方法

调用View.inflate()方法,转换布局文件为View对象,参数:上下文,布局资源,null

查找到相应的控件,设置文件

 

 

数据库操作

db包下新建一个BlackNumberDBOpenHelper类继承SQLiteOpenHelper

实现构造方法

调用父类的构造方法,super(),参数:上下文,数据库名称,游标工厂(null,版本号(1

 

重写onCreate()方法,传递进来参数SQLiteDatabase对象

调用SQLiteDatabase对象的execSQL()方法,参数:Stringsql语句(例如:create table blacknumber (id integer primary key autoincrement,phone varchar(20) ,mode varchar(2))

重写onUpgrade()方法

 

dao

db.dao包下新建一个BlackNumberDao

定义构造方法,传递进来参数:Context对象

获取BlackNumberDBOpenHelper对象,参数:Context对象

 

查询单条

定义方法find(),查询一条记录,参数:String类型电话号码

调用helper对象的getReadableDatabase()方法,获取到SQLiteDatabase对象

调用SQLiteDatabase对象的rawQuery()方法,获取到Cursor对象,参数:String类型SQL语句,String[]参数值数组

调用Cursor对象的moveToNext()方法,如果为真,说明有数据,

调用Cursor对象的getString()方法,获取到值,参数:字段索引

返回Map集合

 

查询全部

定义方法findAll(),查询全部数据

调用helper对象的getReadableDatabase()方法,获取到SQLiteDatabase对象

调用SQLiteDatabase对象的rawQuery()方法,获取到Cursor对象,参数:String类型SQL语句

新建一个domain包,新建一个业务beanBlackNumberInfo

while循环Cursor对象调用moveToNext()

返回List集合

 

插入一条

定义方法add(),插入一条记录,参数:String电话号码,Stringmode模式

调用helper对象的getWritableDatabase()方法,获取到SQLiteDatabase对象

调用SQLiteDatabase对象的insert()方法,插入一条记录,参数:String表名,允许为null的列,ContentValues对象

获取ContentValues对象,new出来

调用ContentValues对象的put()方法,参数:keyvalue

 

修改记录

定义方法update(),修改记录,参数:String电话号码,Stringmode模式

调用helper对象的getWritableDatabase()方法,获取到SQLiteDatabase对象

调用SQLiteDatabase对象的update()方法,修改表记录,参数:String表名,ContentValues对象,String的条件(“number=?”),String[]参数值数组

 

删除记录

定义delete()方法,删除记录,参数:String电话号码

调用helper对象的getWritableDatabase()方法,获取到SQLiteDatabase对象

调用SQLiteDatabase对象的delete()方法,删除表记录,参数:String表名,String的条件(“number=?”),String[]参数值数组

调用SQLiteDatabase对象的close()方法,关闭数据库

 

CallSmsSafeActivity.java

 

package com.qingguow.mobilesafe;import java.util.List;
import java.util.Map;import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.TextView;import com.qingguow.mobilesafe.db.ado.BlackNumberAdo;/*** 通讯卫士* * @author taoshihan* */
public class CallSmsSafeActivity extends Activity {private ListView listview;private List<Map<String, String>> infos;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_call_sms_safe);listview = (ListView) findViewById(R.id.lv_blacknumber);BlackNumberAdo ado = new BlackNumberAdo(this);infos = ado.findAll();listview.setAdapter(new MyAdapter());// //添加100条测试数据// Random random=new Random();// for(int i=1;i<=100;i++){// ado.add("18805419000"+i, String.valueOf(random.nextInt(3)+1));// }
        }private class MyAdapter extends BaseAdapter {@Overridepublic int getCount() {// TODO Auto-generated method stubreturn infos.size();}@Overridepublic View getView(int position, View convertView, ViewGroup parent) {View view = View.inflate(CallSmsSafeActivity.this,R.layout.list_call_sms_safe_item, null);TextView phoneView = (TextView) view.findViewById(R.id.tv_main_phone);TextView modeView = (TextView) view.findViewById(R.id.tv_block_mode);phoneView.setText(infos.get(position).get("phone"));switch (infos.get(position).get("mode")) {case "1":modeView.setText("电话拦截");break;case "2":modeView.setText("短信拦截");break;case "3":modeView.setText("全部拦截");break;default:break;}return view;}@Overridepublic Object getItem(int position) {// TODO Auto-generated method stubreturn null;}@Overridepublic long getItemId(int position) {// TODO Auto-generated method stubreturn 0;}}
}

 

BlackNumberAdo.java

package com.qingguow.mobilesafe.db.ado;import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;import com.qingguow.mobilesafe.db.BlackNumberDBOpenHelper;public class BlackNumberAdo {private BlackNumberDBOpenHelper helper;public BlackNumberAdo(Context context) {helper=new BlackNumberDBOpenHelper(context);}/*** 插入数据* @param phone* @param mode*/public void add(String phone,String mode) {SQLiteDatabase db=helper.getWritableDatabase();ContentValues values=new ContentValues();values.put("phone", phone);values.put("mode", mode);db.insert("blacknumber", null, values);db.close();}/*** 查询全部* @return*/public List<Map<String,String>> findAll(){SQLiteDatabase db=helper.getReadableDatabase();Cursor cursor=db.rawQuery("select phone,mode from blacknumber", null);List<Map<String,String>> list=new ArrayList<Map<String,String>>();while(cursor.moveToNext()){Map<String,String> info=new HashMap<String, String>();String phone=cursor.getString(0);String mode=cursor.getString(1);info.put("phone", phone);info.put("mode", mode);list.add(info);}cursor.close();db.close();return list;}/*** 修改数据* @param phone* @param mode*/public void update(String phone,String mode) {SQLiteDatabase db=helper.getWritableDatabase();ContentValues values=new ContentValues();values.put("phone", phone);values.put("mode", mode);db.update("blacknumber", values,"phone=?",new String[]{phone});db.close();}/*** 删除数据* @param phone*/public void delete(String phone){SQLiteDatabase db=helper.getWritableDatabase();db.delete("blacknumber", "phone=?", new String[]{phone});db.close();}
}

 

 

BlackNumberDBOpenHelper.java

package com.qingguow.mobilesafe.db;import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;/*** 黑名单数据库帮助类* * @author taoshihan* */
public class BlackNumberDBOpenHelper extends SQLiteOpenHelper {public BlackNumberDBOpenHelper(Context context) {super(context, "blacknumber", null, 1);}@Overridepublic void onCreate(SQLiteDatabase db) {db.execSQL("create table blacknumber (id integer primary key autoincrement,phone varchar(20),mode varchar(2))");}@Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {}}

 

 

这篇关于[android] 手机卫士黑名单功能(列表展示)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/820235

相关文章

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

Go语言实现将中文转化为拼音功能

《Go语言实现将中文转化为拼音功能》这篇文章主要为大家详细介绍了Go语言中如何实现将中文转化为拼音功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 有这么一个需求:新用户入职 创建一系列账号比较麻烦,打算通过接口传入姓名进行初始化。想把姓名转化成拼音。因为有些账号即需要中文也需要英

基于WinForm+Halcon实现图像缩放与交互功能

《基于WinForm+Halcon实现图像缩放与交互功能》本文主要讲述在WinForm中结合Halcon实现图像缩放、平移及实时显示灰度值等交互功能,包括初始化窗口的不同方式,以及通过特定事件添加相应... 目录前言初始化窗口添加图像缩放功能添加图像平移功能添加实时显示灰度值功能示例代码总结最后前言本文将

Python实现将实体类列表数据导出到Excel文件

《Python实现将实体类列表数据导出到Excel文件》在数据处理和报告生成中,将实体类的列表数据导出到Excel文件是一项常见任务,Python提供了多种库来实现这一目标,下面就来跟随小编一起学习一... 目录一、环境准备二、定义实体类三、创建实体类列表四、将实体类列表转换为DataFrame五、导出Da

使用Python实现批量访问URL并解析XML响应功能

《使用Python实现批量访问URL并解析XML响应功能》在现代Web开发和数据抓取中,批量访问URL并解析响应内容是一个常见的需求,本文将详细介绍如何使用Python实现批量访问URL并解析XML响... 目录引言1. 背景与需求2. 工具方法实现2.1 单URL访问与解析代码实现代码说明2.2 示例调用

最好用的WPF加载动画功能

《最好用的WPF加载动画功能》当开发应用程序时,提供良好的用户体验(UX)是至关重要的,加载动画作为一种有效的沟通工具,它不仅能告知用户系统正在工作,还能够通过视觉上的吸引力来增强整体用户体验,本文给... 目录前言需求分析高级用法综合案例总结最后前言当开发应用程序时,提供良好的用户体验(UX)是至关重要

python实现自动登录12306自动抢票功能

《python实现自动登录12306自动抢票功能》随着互联网技术的发展,越来越多的人选择通过网络平台购票,特别是在中国,12306作为官方火车票预订平台,承担了巨大的访问量,对于热门线路或者节假日出行... 目录一、遇到的问题?二、改进三、进阶–展望总结一、遇到的问题?1.url-正确的表头:就是首先ur

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

你的华为手机升级了吗? 鸿蒙NEXT多连推5.0.123版本变化颇多

《你的华为手机升级了吗?鸿蒙NEXT多连推5.0.123版本变化颇多》现在的手机系统更新可不仅仅是修修补补那么简单了,华为手机的鸿蒙系统最近可是动作频频,给用户们带来了不少惊喜... 为了让用户的使用体验变得很好,华为手机不仅发布了一系列给力的新机,还在操作系统方面进行了疯狂的发力。尤其是近期,不仅鸿蒙O

如何评价Ubuntu 24.04 LTS? Ubuntu 24.04 LTS新功能亮点和重要变化

《如何评价Ubuntu24.04LTS?Ubuntu24.04LTS新功能亮点和重要变化》Ubuntu24.04LTS即将发布,带来一系列提升用户体验的显著功能,本文深入探讨了该版本的亮... Ubuntu 24.04 LTS,代号 Noble NumBAT,正式发布下载!如果你在使用 Ubuntu 23.