博客
关于我
[android] 手机卫士黑名单功能(ListView结合SQLite增删改)
阅读量:656 次
发布时间:2019-03-15

本文共 1053 字,大约阅读时间需要 3 分钟。

在现有的Android活动中添加黑名单功能,需求包括顶部横条添加添加按钮和自定义对话框。添加按钮的点击将打开自定义对话框,用户输入电话号码和拦截模式后数据保存至数据库。以下为实现该功能的详细步骤:

  • 首先定义一个ViewHolder类来存储列表项中的每个控件。ViewHolder类包含三个成员:

    • phoneView:用于显示存入黑名单的电话号码
    • modeView:用于显示当前拦截模式(电话拦截、短信拦截或全部拦截)
    • iv_delete:用于删除当前记录的图片按钮
  • 创建一个ListAdapter类用于管理和显示列表项。ListAdapter类继承自BaseAdapter类,主要实现以下方法:

    • getCount():获取数据项的数量
    • getView():获取或创建用来显示每一项的布局
    • getItem():获取对应项的数据
    • getItemId():获取对应项的唯一标识符
  • 在Activity类中初始化UI元素:

    • 使用findViewById获取ListView控件
    • 初始化ListAdapter并将其设为ListView的适配器
    • 获取BlackNumberAdo对象用于数据库操作
    • 从数据库中获取所有黑名单记录并设置到ListView上
  • 实现添加功能的点击事件处理。例如,在添加按钮的点击事件中:

    • 创建一个自定义对话框,使用AlertDialog.Builder
    • 添加OK和取消按钮,并为OK按钮设置点击事件
    • 获取用户输入的电话号码和拦截模式,并调用BlackNumberAdo的add方法将数据保存到数据库
    • 创建新的信息Map并将其添加到infors集合的最前面,确保新添加的记录会立即显示出来
    • 通知适配器数据发生变化,确保UI界面能够及时反映新添加的记录
  • 在每个列表项中实现删除操作。例如,在删除按钮的点击事件中:

    • 创建一个确认删除的对话框,展示警告信息
    • 如果用户确认删除操作,调用BlackNumberAdo的delete方法从数据库中删除对应的记录
    • 调用ListAdapter的notifyDataSetChanged方法,确保UI界面更新显示新的数据
  • 提供多种拦截模式的选择。例如:

    • 当用户选择拦截电话和短信时,设置为全部拦截模式
    • 当用户仅选择拦截电话时,设置为电话拦截模式
    • 当用户仅选择拦截短信时,设置为短信拦截模式
    • 提供错误提示处理,确保用户输入合法电话号码并选择拦截模式
  • 通过以上实现,用户能够轻松添加和删除黑名单记录,根据选择的拦截模式拦截相应的通信类型,从而实现对重要号码的保护功能。

    转载地址:http://bbnmz.baihongyu.com/

    你可能感兴趣的文章
    Nginx配置参数中文说明
    查看>>
    nginx配置域名和ip同时访问、开放多端口
    查看>>
    Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
    查看>>
    Nginx配置如何一键生成
    查看>>
    Nginx配置实例-负载均衡实例:平均访问多台服务器
    查看>>
    Nginx配置文件nginx.conf中文详解(总结)
    查看>>
    Nginx配置负载均衡到后台网关集群
    查看>>
    ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
    查看>>
    NHibernate学习[1]
    查看>>
    NHibernate异常:No persister for的解决办法
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>