- 浏览: 196913 次
- 性别:
- 来自: 杭州
文章分类
最新评论
-
guoshijie1990:
写的不错
Android Https通信 -
xiaochi_84:
你好,我想问一下。为什么我在java工程里测试没有问题。但是到 ...
Android导出xls文件 -
Visual_chenpeng:
Android Https通信 -
jasonpeak:
求jasonpeak 写道我的为什么按返回键还是不关闭呢?求破 ...
Android关于ProgressDialog按返回键关闭 -
jasonpeak:
我的为什么按返回键还是不关闭呢?
Android关于ProgressDialog按返回键关闭
前段时间在做一个项目的后期维护时,对方提出了把短信做成可以批量删除、、然后冥思苦想,终于想到了一个可执行方案、、那边的要求时这样的、、进入短信的草稿箱,然后点击一条短信,弹出批量删除对话框,然后有一个全选框,可以进行多项选择,进行删除、、、、
实现过程如下:首先建立一个主布局文件,主要有两个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();
发表评论
-
Android获取设备信息
2012-11-22 00:10 1330转http://blog.csdn.net/gumanr ... -
Android列表索引实现
2012-07-15 10:47 6626最近做一个项目用到了列表索引,所以在网上找了一下,发现一个博客 ... -
Android开发环境搭建(Windows)
2012-07-03 13:37 757什么都不说来,直接下载附件好了,这个图文的不好发布 -
Linux下Android环境搭建
2012-07-03 13:34 1182--以Ubuntu为例 Linux下Android环境 ... -
Android ListView 滑动背景为黑色的解决办法
2012-06-28 22:08 1008转至:http://blog.163.com/zh ... -
Android蓝牙开发
2012-06-26 15:38 1464今天查了一些资料,然后发现一篇文章挺好,关于蓝牙的,原文网址: ... -
Android自定义对话框
2012-06-22 11:36 2453这时我封装的一个对话框工具类 package com. ... -
Android语音采集
2012-06-18 10:55 15465Android端的语音采集主要是调用AudioRecord,首 ... -
Android语音识别
2012-06-18 09:28 2225Android由于有了Google的支持,那么他的语音识别做起 ... -
Android监控
2012-06-08 20:04 1431Android的监控一般都是需要用到Jni的,然后进行NDK编 ... -
Android视频播放
2012-05-24 19:55 1853视频播放优好多种,一种是播放系统可以播放的视频文件,一种是播放 ... -
重写android返回键
2012-05-24 19:23 21865在Activity里面加入下面代码: @Overrid ... -
Android图像处理工具类
2012-04-09 09:37 2477还是最近整理代码、、发现了一个师兄写的图片工具类,感觉还是蛮有 ... -
Android导出xls文件
2012-04-08 15:45 6534整理硬盘的时候找到了这些代码,看了一下,发现还有点用处,所以就 ... -
android的文字跑马灯效果
2012-04-03 21:04 7266今天问了解决文本内容过长的显示问题,而用了一个android自 ... -
Android超级简单的TabView实现
2012-04-03 20:56 7120可能很多人都有想要实现一个导航栏,但是不知道改怎么弄,因为an ... -
ImageView的属性android:scaleType
2012-04-03 20:04 1999ImageView的属性android:scaleType ... -
关于Android程序的全屏显示
2012-04-03 19:53 972对于Android开发来说,全屏和无标题是我们常用的几行代码, ... -
Android文件下载
2012-03-19 16:45 1313嘿嘿,也不知道什么时候写的代码,清理硬盘的时候发现了,而且还能 ... -
Android视图的截图
2012-03-19 16:38 6853在pc上的截图软件很多,但是android上的比较少,所以就自 ...
相关推荐
Android版短信 筛选/批量删除 程序(支持Android2.3~4.4)
Android例子源码可以定时批量发送短信的短信时光机是一个可以自定义定时批量短信发送例子源码(类似于短信时光机),编辑的短信可以一键选择多个联系人进行定时发送,批量发送祝福短信这种情况在节假日是普遍存在的...
Android例子源码可以定时批量发送短信的短信时光机是一个可以自定义定时批量短信发送例子源码(类似于短信时光机),编辑的短信可以一键选择多个联系人进行定时发送,批量发送祝福短信这种情况在节假日是普遍存在的...
实验项目名称 通讯录 实验目的与要求: 目的:练习掌握 Android 软件开发基本编程技术、Android 系统 SQLite 数据库的使用、通话、短信的使用等,设计制作一 Android 通讯录软件。 要求: (1)每位同学独立设计...
android通讯录, 能够实现打电话 发短信 批量删除 删除等操作,采用的是自定义对话框,一个很使用的android实例,数据采用的是sqlite。
系统软件和本地软件,可以显示软件的详细信息,启动,删除应用程序.连接获取服务器上软件的评分信息等功能。程序锁可以指定要保护的程序, 用户进入要保护的程序之前必须输入密码。 任务管理: 显示当前系统运行的进程...
应用程序自动随着手机旋转 ·短信、Gmail、日暦,浏览器的用户接口大幅改进,如Gmail可以批量删除邮件 ·相机启动速度加快,拍摄图片可以直接上传到Picasa ·来电照片显示 3) Android 1.6 代表机型HTC Hero G3 在...
基于Android的在线云通讯录设计毕业设计,论文(设计)的主要任务与具体要求 主要任务:1) 联系人的新增、编辑、删除功能。...5) 长按联系人可进行批量删除联系人6) 在搜索联系人界面下,可按拼音或汉字等搜索快速搜索
|--短信之根据id删除及查询短信 |--短信发送小demo |--短信的截取 |--系统之SD卡清理 |--系统之获取所有开机启动应用 |--系统之重启实现 |--系统信息之获取SD卡内存信息 |--系统信息之获取动态内存RAM信息 |--系统...
它管理自己的拦截消息列表,您可以批量删除、将发件人添加到联系人或移动到普通的消息应用程序。 但是,随着 Android (API 级别 19 KITKAT)中的除非将该应用程序设为默认消息应用程序,否则无法拦截 SMS 消息。 ...
通讯清理:分类整理通话与短信内容,方便批量删除。 深度清理:准确扫描程序卸载后的残留文件与目录,清理施放存储空间。 痕迹清理:发现各类手机使用痕迹,清理保护您的个人隐私。 2.1.0更新内容: 1...
短信:接收,发送,转发或删除短信。 应用程序:安装,卸载,备份,搜索应用程序,做批量处理。 照片:预览,删除,上传,下载,设置为墙纸和照片幻灯片放映桌面。 剪贴板:共享剪贴板中的文本之间的桌面和设备。...
Android上最快的数据备份工具!您可以将应用和通讯录以及短信和通话记录和书签和日历备份到SD卡/ Gmail。您永远不会再丢失数据!这是Super Backup的广告免费版本 重要的提醒!!! 如果您的手机具有内置存储,则...
能批量移动手机上的软件到SD卡,批量删除软件;实时显示剩余电量和可用时间;实时监控手机流量;免打扰功能让手机在 预设的日期、时间段内处于静音、振动或是离线状态,休息时间不怕打扰,睡眠时间减少辐射。 功能...
- 未读计数:不再错过短信、电话、电子邮件等重要消息,支持在托盘、主屏幕、抽屉和文件夹中显示(需要插件) - 更多滚动效果 更新: -棒棒糖式抽屉(设置抽屉-显示页面的卡) -重命名旧圆动画圈擦拭,添加棒棒糖式...
Android 上最快的数据备份工具!您可以将应用程序和联系人,短信和通话记录,书签和日历备份到 SD 卡/Gmail。您再也不会丢失数据!这是超级备份的免费无广告版本,如果您需要经常对手机系统中的重要数据进行备份,您...
DataFiller是一个集多种数据填充功能为一体的辅助测试工具,主要功能是可进行批量填充与批量删除多种数据格式,如短信、彩信、联系人、日历事件、通话记录、存储空间等,极大的提高开发、测试的效率。
强大的跟踪橡皮擦可删除敏感的个人信息,如短信和通话记录,浏览器历史记录,剪贴板数据,保存的密码泄露,增加安全性和保护隐私免受间谍活动。 - 阅读设备信息 列表手机存储; 一个地方的CPU,电池,屏幕,网络,根...
–从SD卡批量还原应用程序(需要根) –一键共享APK文件 –备份联系人和短信和通话记录,书签和日历到SD卡 – 从SD卡还原联系人和SMS和通话记录以及书签和日历 –可以选择要备份的SMS对话 –删除SD卡上的备份...
1◊批量复制/粘贴,压缩,删除,移动,共享和流式传输文件和文件夹 ◊更改文件/文件夹权限和所有权 ◊全部访问您的Samba网络共享 ►应用程序管理器* 1◊备份和验证应用程序apk /数据(多个版本),短信和呼叫日志 ◊...