`
弄月吟风
  • 浏览: 196913 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Android短信批量删除效果

阅读更多

前段时间在做一个项目的后期维护时,对方提出了把短信做成可以批量删除、、然后冥思苦想,终于想到了一个可执行方案、、那边的要求时这样的、、进入短信的草稿箱,然后点击一条短信,弹出批量删除对话框,然后有一个全选框,可以进行多项选择,进行删除、、、、

 

实现过程如下:首先建立一个主布局文件,主要有两个listview,然后是4个按钮,我们要做的是把四个按钮中的3个设为不可见,一个设为可见,listview也是只有一个可见,其他三个设为不可见

主xml文件:sms_store.xml

 

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >

    <include layout="@layout/head" />
    <!-- 动态显示界面 -->

    <LinearLayout
        android:id="@+id/body"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:layout_weight="0.95"
        android:orientation="vertical"
         android:background="#F5F8FD"
        >

        

            <ListView
                android:id="@+id/smslist"
                android:layout_width="fill_parent"
                android:layout_height="wrap_content" 
                android:visibility="visible"/>
            <!-- 批量删除下的列表 -->
             <ListView
                android:id="@+id/smslist2"
                android:layout_width="fill_parent"
                android:layout_height="wrap_content" 
                android:visibility="gone"/>
       
    </LinearLayout>

    <include layout="@layout/sms_foot" />

</LinearLayout>

 sms_foot.xml文件

 

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/bottomlist"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:background="@drawable/tab_botton"
    android:orientation="vertical" >

    <LinearLayout
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal" 
        >

        <Button
            android:id="@+id/btn_choceall"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:background="@drawable/bt_background"
            android:gravity="center"
            android:text="全标记"
            android:textColor="#ffffffff"
            android:visibility="gone" 
            android:width="50dp"
            android:layout_weight="1"/>

        <Button
            android:id="@+id/btn_delete"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:background="@drawable/bt_background"
            android:gravity="center"
            android:text="删除"
            android:layout_weight="1"
            android:textColor="#ffffffff"
            android:visibility="gone" 
            android:width="50dp"/>

        <Button
            android:id="@+id/backbefore"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:background="@drawable/bt_background"
            android:gravity="center"
            android:text="返回"
            android:layout_weight="1"
            android:textColor="#ffffffff"
            android:visibility="gone" 
            android:width="50dp"/>
    </LinearLayout>

    <Button
        android:id="@+id/smsback"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@drawable/bt_background"
        android:gravity="center"
        android:layout_gravity="right"
        android:text="返回"
        android:textColor="#ffffffff"
        android:visibility="visible" 
        android:width="50dp"/>
</LinearLayout>

 接下载建立两个listview的主体,一个是普通的文本,一个是多选框的文本

smslist.xml

 

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >

    <TextView
        android:id="@+id/title"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:textSize="25dip"
        android:ellipsize="end"
        android:singleLine="true"
        android:textColor="@color/black"
        android:text="TextView" />

</LinearLayout>

 sms_delete.xml

 

<?xml version="1.0" encoding="utf-8"?>
<CheckedTextView xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/content"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:checkMark="?android:attr/listChoiceIndicatorMultiple"
    android:ellipsize="end"
    android:singleLine="true"
    android:textColor="@color/black"
    android:textSize="20dip" >

</CheckedTextView>

 在Activity里面建立

Button smsback, smsbackbrfore,btChoseall, btDelete;

ListView listv, listv2;

并且setContentView(R.layout.sms_store);

然后findid一下

 

smsback = (Button) findViewById(R.id.smsback);

smsbackbrfore = (Button) findViewById(R.id.backbefore);

btChoseall = (Button) findViewById(R.id.btn_choceall);// 全选按钮

btDelete = (Button) findViewById(R.id.btn_delete);// 删除按钮

listv = (ListView) findViewById(R.id.smslist);

listv2 = (ListView) findViewById(R.id.smslist2);

然后创建一个方法更新视图

 

private void updataview() {

listv.setVisibility(View.VISIBLE);

smsback.setVisibility(View.VISIBLE);

listv2.setVisibility(View.GONE);

smsbackbrfore.setVisibility(View.GONE);

btChoseall.setVisibility(View.GONE);

btDelete.setVisibility(View.GONE);

list = getData(status);

if (list == null) {

// 表示没有数据,显示数据为空

} else {

// 表示有数据

listViewAdapter = new ListViewAdapter(MsgStoreActivity.this, list,

R.layout.smslist, new String[] { "content" },

new int[] { R.id.title });

listv.setAdapter(listViewAdapter);

}

}

得到数据库的返回数据

 

private List<Map<String, String>> getData(String status) {

Cursor cursor = new DatabaseHelper().fetchData(MsgStoreActivity.this,

DataDefine.TABLE_MSG, Integer.valueOf(status));

List<Map<String, String>> list = new ArrayList<Map<String, String>>();

int i = 1;

System.out.println(cursor.getCount());

if (cursor != null && cursor.getCount() > 0) {

// 有数据

do {

Map<String, String> map = new HashMap<String, String>();

map.put("id", cursor.getString(cursor

.getColumnIndex(DataDefine.KEY_MSG_ID_AUTO_INCREMENT)));

String s = cursor.getString(cursor

.getColumnIndex(DataDefine.KEY_MSG_CONTENT));

// if(s.length()>10){

// s=s.substring(0,10)+"......";

// }

map.put("content", (i++) + ". " + s);

list.add(map);

} while (cursor.moveToNext());

cursor.close();

return list;

} else {

cursor.close();

Map<String, String> map = new HashMap<String, String>();

map.put("id", null);

map.put("content", "当前没有短信!");

list.add(map);

return list;

}

 

}

 

当点击批量删除时

 

listv.setVisibility(View.GONE);

smsback.setVisibility(View.GONE);

listv2.setVisibility(View.VISIBLE);

smsbackbrfore.setVisibility(View.VISIBLE);

btChoseall.setVisibility(View.VISIBLE);

btDelete.setVisibility(View.VISIBLE);

ListViewAdapter adapter = new ListViewAdapter(MsgStoreActivity.this, list, R.layout.sms_delete,

new String[] { "content" }, new int[] { R.id.content });

listv2.setChoiceMode(ListView.CHOICE_MODE_MULTIPLE);

listv2.setAdapter(adapter);

创建删除和全选按钮事件

 

btChoseall.setOnClickListener(new View.OnClickListener() {

 

@Override

public void onClick(View v) {

CheckedTextView cv;

for (int i = 0; i < listv2.getCount(); i++) {

cv = (CheckedTextView) listv2.getChildAt(i);

cv.setChecked(true);

}

 

}

});

btDelete.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

CheckedTextView cv;

int count = 0;

for (int i = 0; i < listv2.getCount(); i++) {

cv = (CheckedTextView) listv2.getChildAt(i);

if (cv.isChecked()) {

count = 1;

break;

}

}

 

if (count == 1)

adDelete.show();

else

showToast(MsgStoreActivity.this, "未选中信息!");

 

}

});

创建删除按钮点击后的弹出对话框事件

 

adDelete = new AlertDialog.Builder(MsgStoreActivity.this)

.setTitle("删除").setMessage("确定要删除信息?")

.setNegativeButton("取消", new DialogInterface.OnClickListener() {

 

@Override

public void onClick(DialogInterface dialog, int which) {

dialog.dismiss();

 

}

})

.setPositiveButton("确定", new DialogInterface.OnClickListener() {

 

@Override

public void onClick(DialogInterface dialog, int which) {

CheckedTextView cv;

for (int i = 0; i < listv2.getCount(); i++) {

cv = (CheckedTextView) listv2.getChildAt(i);

if (cv.isChecked()) {

Map<?, ?> map = (Map<?, ?>) listv.getAdapter()

.getItem(i);

new DatabaseHelper().delete(

MsgStoreActivity.this,

Integer.valueOf((String) map.get("id")));

}

}

showToast(MsgStoreActivity.this, "信息已删除!");

updataview();

}

}).create();


  • 大小: 32.7 KB
  • 大小: 26.1 KB
  • 大小: 35.8 KB
分享到:
评论
1 楼 h00473 2013-04-30  
希望能分享下你的源码,谢谢了

相关推荐

    Android版短信 筛选/批量删除 程序(支持Android2.3~ 4.4)

    Android版短信 筛选/批量删除 程序(支持Android2.3~4.4)

    Android例子源码可以定时批量发送短信的短信时光机.rar

    Android例子源码可以定时批量发送短信的短信时光机是一个可以自定义定时批量短信发送例子源码(类似于短信时光机),编辑的短信可以一键选择多个联系人进行定时发送,批量发送祝福短信这种情况在节假日是普遍存在的...

    Android例子源码可以定时批量发送短信的短信时光机

    Android例子源码可以定时批量发送短信的短信时光机是一个可以自定义定时批量短信发送例子源码(类似于短信时光机),编辑的短信可以一键选择多个联系人进行定时发送,批量发送祝福短信这种情况在节假日是普遍存在的...

    Android开发实验---通讯录.docx

    实验项目名称 通讯录 实验目的与要求: 目的:练习掌握 Android 软件开发基本编程技术、Android 系统 SQLite 数据库的使用、通话、短信的使用等,设计制作一 Android 通讯录软件。 要求: (1)每位同学独立设计...

    android通讯录

    android通讯录, 能够实现打电话 发短信 批量删除 删除等操作,采用的是自定义对话框,一个很使用的android实例,数据采用的是sqlite。

    android手机安全卫士

    系统软件和本地软件,可以显示软件的详细信息,启动,删除应用程序.连接获取服务器上软件的评分信息等功能。程序锁可以指定要保护的程序, 用户进入要保护的程序之前必须输入密码。 任务管理: 显示当前系统运行的进程...

    Android智能手机调研报告.doc

    应用程序自动随着手机旋转 ·短信、Gmail、日暦,浏览器的用户接口大幅改进,如Gmail可以批量删除邮件 ·相机启动速度加快,拍摄图片可以直接上传到Picasa ·来电照片显示 3) Android 1.6 代表机型HTC Hero G3 在...

    基于android的云通讯录的设计毕业论文.zip

    基于Android的在线云通讯录设计毕业设计,论文(设计)的主要任务与具体要求 主要任务:1) 联系人的新增、编辑、删除功能。...5) 长按联系人可进行批量删除联系人6) 在搜索联系人界面下,可按拼音或汉字等搜索快速搜索

    黑马程序员 安卓学院 万元哥项目经理 分享220个代码实例

    |--短信之根据id删除及查询短信 |--短信发送小demo |--短信的截取 |--系统之SD卡清理 |--系统之获取所有开机启动应用 |--系统之重启实现 |--系统信息之获取SD卡内存信息 |--系统信息之获取动态内存RAM信息 |--系统...

    misbotheringsms:适用于 Android 的短信警报过滤器

    它管理自己的拦截消息列表,您可以批量删除、将发件人添加到联系人或移动到普通的消息应用程序。 但是,随着 Android (API 级别 19 KITKAT)中的除非将该应用程序设为默认消息应用程序,否则无法拦截 SMS 消息。 ...

    一键清理专业版 For Android v2.1.5.zip

     通讯清理:分类整理通话与短信内容,方便批量删除。  深度清理:准确扫描程序卸载后的残留文件与目录,清理施放存储空间。  痕迹清理:发现各类手机使用痕迹,清理保护您的个人隐私。  2.1.0更新内容:  1...

    AirDroid v3.6.4.0.zip

    短信:接收,发送,转发或删除短信。 应用程序:安装,卸载,备份,搜索应用程序,做批量处理。 照片:预览,删除,上传,下载,设置为墙纸和照片幻灯片放映桌面。 剪贴板:共享剪贴板中的文本之间的桌面和设备。...

    Super Backup Pro 2.2.56.apk

    Android上最快的数据备份工具!您可以将应用和通讯录以及短信和通话记录和书签和日历备份到SD卡/ Gmail。您永远不会再丢失数据!这是Super Backup的广告免费版本 重要的提醒!!! 如果您的手机具有内置存储,则...

    正点工具箱 v4.2.433

    能批量移动手机上的软件到SD卡,批量删除软件;实时显示剩余电量和可用时间;实时监控手机流量;免打扰功能让手机在 预设的日期、时间段内处于静音、振动或是离线状态,休息时间不怕打扰,睡眠时间减少辐射。 功能...

    Nova启动器:Nova Launcher Prime

    - 未读计数:不再错过短信、电话、电子邮件等重要消息,支持在托盘、主屏幕、抽屉和文件夹中显示(需要插件) - 更多滚动效果 更新: -棒棒糖式抽屉(设置抽屉-显示页面的卡) -重命名旧圆动画圈擦拭,添加棒棒糖式...

    超级备份 Super Backup Pro 2.2.80 中文多语免费版.zip

    Android 上最快的数据备份工具!您可以将应用程序和联系人,短信和通话记录,书签和日历备份到 SD 卡/Gmail。您再也不会丢失数据!这是超级备份的免费无广告版本,如果您需要经常对手机系统中的重要数据进行备份,您...

    DataFillerS_v2.1.apk

    DataFiller是一个集多种数据填充功能为一体的辅助测试工具,主要功能是可进行批量填充与批量删除多种数据格式,如短信、彩信、联系人、日历事件、通话记录、存储空间等,极大的提高开发、测试的效率。

    All-In-One Toolbox Pro 8.1.5.5.8.apk

    强大的跟踪橡皮擦可删除敏感的个人信息,如短信和通话记录,浏览器历史记录,剪贴板数据,保存的密码泄露,增加安全性和保护隐私免受间谍活动。 - 阅读设备信息 列表手机存储; 一个地方的CPU,电池,屏幕,网络,根...

    Super_Backup_Restore_Premium_v2.2.70_build_140.apk

    –从SD卡批量还原应用程序(需要根) –一键共享APK文件 –备份联系人和短信和通话记录,书签和日历到SD卡 – 从SD卡还原联系人和SMS和通话记录以及书签和日历 –可以选择要备份的SMS对话 –删除SD卡上的备份...

    3C Toolbox Pro 1.9.9.7.6C.apk

    1◊批量复制/粘贴,压缩,删除,移动,共享和流式传输文件和文件夹 ◊更改文件/文件夹权限和所有权 ◊全部访问您的Samba网络共享 ►应用程序管理器* 1◊备份和验证应用程序apk /数据(多个版本),短信和呼叫日志 ◊...

Global site tag (gtag.js) - Google Analytics