MMS搜索功能修改
高通平台的MMS源码中提供了搜索功能,但要先选择分类(名字,号码,信息内容,彩信主题),再输入字符,根据分类进行搜索。
而在Contacts中却不需要分类,直接根据输入字符搜索任意匹配字段。相比之下,MMS搜索功能繁琐,用户体验不好。
那么我们来修改一下代码,实现MMS搜索,自动匹配任意字段吧
分析:查看代码TelephonyProvider\src\com\android\providers\telephony\MmsSmsProvider.java中,
从搜索语句sql设计看:名字和号码的搜索属于一类, 信息内容和主题搜索属于一类。
(名字搜索——先根据名字查询对应号码,再根据号码搜索会话)
从搜索结果看:名字和号码的搜索结果为thread表, 信息内容和主题搜索的结果为sms/mms表
具体设计:输入一个字符,可能是名字,也可能是号码,也可能是内容,也可能是主题。所以需要针对每种类型分别搜索,然后将结果合并。
对于名字和号码,在where语句中用or分别匹配;
对于短信/彩信内容和彩信主题搜索,用UNION将三个sql组合(因为查询字段个数一样,可以取同样的别名)
- //---add by antoon
- private Cursor getMsgSearchResult(Uri uri, SQLiteDatabase db) {
- String keyStr = uri.getQueryParameter("key_str");
- String addressStr = uri.getQueryParameter("addressStr");
- Log.i("antoon", LOG_TAG + " , keyStr = " + keyStr);
- Log.i("antoon", LOG_TAG + " , addressStr = " + addressStr);
- String threadIdString = getSearchedThreadIdString(addressStr);
- Log.i("antoon", LOG_TAG + " , threadIdString = " + threadIdString);
- String searchString = "%" + addEscapeCharacter(keyStr) + "%";
- Log.i("antoon", LOG_TAG + " , searchString = " + searchString);
- Cursor cursor;
- if(DEFAULT_STRING_ZERO.equals(threadIdString)){
- cursor = getSmsMmsSearchContent(searchString);
- }else {
- Cursor cursorThread = getSearchedThreadIds(threadIdString);
- Cursor cursorMsg = getSmsMmsSearchContent(searchString);
- cursor = new MergeCursor(new Cursor[]{cursorThread, cursorMsg});
- }
- return cursor;
- }
- private String getSearchedThreadIdString(String keyStr) {
- String[] addresses = keyStr.split(",");
- int count = addresses.length;
- Set<Long> result = new HashSet<Long>(count);
- for (int i = 0; i < count; i++) {
- String address = addresses[i];
- if (address != null && !address.equals(PduHeaders.FROM_INSERT_ADDRESS_TOKEN_STR)) {
- Set<Long> ids = getThreadIdsByAddress(address);
- if (ids != null) {
- result.addAll(ids);
- } else {
- Log.e(LOG_TAG, "Address ID not found for: " + address);
- }
- }
- }
- long[] addressIdSet = getSortedSet(result);
- String threadIdString = getCommaSeparatedId(addressIdSet);
- if (TextUtils.isEmpty(threadIdString)) {
- threadIdString = DEFAULT_STRING_ZERO;
- }
- return threadIdString;
- }
- private Set<Long> getThreadIdsByAddress(String address) {
- String searchString = "%" + addEscapeCharacter(address) + "%";
- boolean isEmail = Mms.isEmailAddress(address);
- String refinedAddress = isEmail ? address.toLowerCase() : address;
- String selection = "address LIKE ?";
- String[] selectionArgs;
- if (isEmail) {
- selectionArgs = new String[] { refinedAddress };
- } else {
- selection += " OR " + String.format("PHONE_NUMBERS_EQUAL(address, ?, %d)",
- (mUseStrictPhoneNumberComparation ? 1 : 0));
- selectionArgs = new String[] { searchString, refinedAddress };
- }
- Cursor cursor = null;
- Set<Long> addressIds = new HashSet<Long>();
- try {
- SQLiteDatabase db = mOpenHelper.getReadableDatabase();
- cursor = db.query(
- "canonical_addresses", ID_PROJECTION,
- selection, selectionArgs, null, null, null);
- if (cursor.getCount() == 0) {
- return null;
- }
- while(cursor.moveToNext()){
- addressIds.add(cursor.getLong(cursor.getColumnIndexOrThrow(BaseColumns._ID)));
- }
- } finally {
- if (cursor != null) {
- cursor.close();
- }
- }
- return addressIds;
- }
- private synchronized Cursor getSearchedThreadIds(String threadIdString) {
- String THREAD_QUERY = String.format(
- "SELECT %s FROM threads WHERE (_id in (%s))",
- THREADS_PROJECTION,
- threadIdString);
- SQLiteDatabase db = mOpenHelper.getReadableDatabase();
- return db.rawQuery(THREAD_QUERY, EMPTY_STRING_ARRAY);
- }
- private synchronized Cursor getSmsMmsSearchContent(String keyStr) {
- String smsQuery = String.format(
- "SELECT %s FROM sms WHERE (body LIKE ? ESCAPE '" +
- SEARCH_ESCAPE_CHARACTER + "') ",
- SMS_CONTENT_PROJECTION);
- String mmsContentQuery = String.format(Locale.US,
- "SELECT %s FROM pdu,part,addr WHERE ((part.mid=pdu._id) AND " +
- "(addr.msg_id=pdu._id) AND " +
- "(addr.type=%d) AND " +
- "(part.ct='text/plain') AND " +
- "(body like ? escape '" + SEARCH_ESCAPE_CHARACTER + "')) GROUP BY pdu._id",
- MMS_CONTENT_PROJECTION,
- PduHeaders.TO);
- String mmsSubjectQuery = String.format(
- "SELECT %s FROM pdu,addr WHERE (" +
- "(addr.msg_id = pdu._id) AND (addr.type=%d) AND " +
- "(body like ? escape '" + SEARCH_ESCAPE_CHARACTER + "')) GROUP BY pdu._id",
- MMS_SUBJECT_PROJECTION,
- PduHeaders.TO);
- String rawQuery = String.format(
- "%s UNION %s UNION %s ORDER BY date ASC",
- smsQuery, mmsContentQuery, mmsSubjectQuery);
- SQLiteDatabase db = mOpenHelper.getReadableDatabase();
- return db.rawQuery(rawQuery, new String[] {keyStr,keyStr,keyStr});
- }
- public static final String THREADS_PROJECTION =
- "'thread' AS transport_type, _id, recipient_ids, message_count, date";
- //下面三个查询字段个数一样,字段名称也一样
- private static final String SMS_CONTENT_PROJECTION =
- "'sms' AS transport_type, _id, address, body, date";
- private static final String MMS_CONTENT_PROJECTION =
- "'mms' AS transport_type, pdu._id, addr.address AS address, part.text as body,"
- + "pdu.date * 1000 AS date";
- private static final String MMS_SUBJECT_PROJECTION =
- "'mms' AS transport_type, pdu._id, addr.address AS address, pdu.sub as body, "
- + "pdu.date * 1000 AS date";
- //---end add
MMS搜索功能修改的更多相关文章
- idea 光标变成粗体且当前文件搜索功能无法使用的问题
今天安装了idea最新版,安装完成后发现光标变成了粗体,并且快捷键在使用时出现了问题,比如:ctrl+F搜索功能无法使用 经过反复修改配置也无法改善情况,后来一次重启看到下面小窗弹出有关vim的一个提 ...
- ILSpy搜索功能加强版
1.修改搜索功能,增加如下的额外搜索选项 A.按文本搜索(默认选项) B.按通配符搜索 C.按正则表达式搜索 2.搜索增加如下特性: A.可以按照名字空间检索特定名字空间下的所有类. B.修正了官方版 ...
- PHP+mysql数据库开发搜索功能:中英文分词+全文检索(MySQL全文检索+中文分词(SCWS))
PHP+mysql数据库开发类似百度的搜索功能:中英文分词+全文检索 中文分词: a) robbe PHP中文分词扩展: http://www.boyunjian.com/v/softd/robb ...
- yii2组件之下拉框带搜索功能(yii-select2)
简单的小功能,但是用起来还是蛮爽的.分享出来让更多的人有更快的开发效率,开开心心快乐编程. 如果你还没有使用过composer,你可就out了,看我的教程分享,composer简直就是必备神奇有木有. ...
- 简单三步-实现dede站内搜索功能
第一步:找到对应的搜索模板的代码 我们都知道,dede有自带的搜索功能,我们只要找到对应的模板,然后把我们想要的代码拿出来就行了.具体如下: 首先进入templets-->default--&g ...
- mac 功能修改。。。。
个人表示 Mac 下的 Spotlight 搜索功能确实是个鸡肋,安装 QuickSilver 才是王道!所以我个人就把 Spotlight 关闭掉了.方法很简单,还是要用到 “终端” 工具. 在 “ ...
- 【Lucene3.6.2入门系列】第03节_简述Lucene中常见的搜索功能
package com.jadyer.lucene; import java.io.File; import java.io.IOException; import java.text.SimpleD ...
- 关于ligerui 中 grid 表格的扩展搜索功能在远程数据加载时无法使用的解决办法
要想使用grid里的扩展搜索功能,除了要引用ligerui主要的js文件外,还必须引入下面的JS文件: 1.Source\demos\filter\ligerGrid.showFilter.js 2. ...
- PHPCMS快速建站系列之搜索功能
默认模板的搜索功能代码 <div class="bd"> <form action="{APP_PATH}index.php" method= ...
随机推荐
- python---常见的数据队列
一.FIFO队列(先进先出) #!/usr/bin/env python # -*- coding:utf-8 -*- __author__ = 'zhoufeng' #FIFO队列 import q ...
- (转)深入理解javascript连续赋值表达式
引入 今天逛园子的时候看到一道javascript面试题,是关于连续赋值的,正好最近读jQuery源码经常看到这种连续赋值的表达式,所以很感兴趣. 废话不多说,来看题: var a = {n: 1} ...
- C# ADO.NET (sql语句连接方式)(查询)
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.We ...
- awk实现join
awk 有时确实比较省事,做些简单的文本处理,还是很方便的,在这介绍下两个文件的join的操作. 原始文本 bb.txt a 10 b 12 cc.txt a 11 b 13 c 15 awk joi ...
- Hibernate和Struts2整合的增、删、改、查
1. 新建一个Web项目,准备好jar包和配置文件. 2. web.xml文件中添加过滤器 <?xml version="1.0" encoding="UTF-8& ...
- EntityFrameWork 使用时碰到的小问题
EntityFrameWork 使用时碰到的小问题 1,在使用orm访问数据库的相目里,也要引用EntityFrameWork.dll,否则无法使用orm 否则,编译错误 错误 5 "Sys ...
- ActiveMQ学习笔记(5)——使用Spring JMS收发消息
摘要 ActiveMQ学习笔记(四)http://my.oschina.net/xiaoxishan/blog/380446 中记录了如何使用原生的方式从ActiveMQ中收发消息.可以看出,每次 ...
- javascript验证香港身份证
var assert = require('assert'); describe('test', function() { it('coc', function() { var testCard01 ...
- ajax data传值
如果要我们要把整个form1表单中的输入框都传过去可以用data:$("#form1").serialize(), 但是我们如果还要传一个不在form中的值呢? 可以使用下面这种方 ...
- 微信公众平台开发 微信JSSDK开发
根据微信开发文档步骤如下: 1.先登录微信公众平台进入“公众号设置”的“功能设置”里填写“JS接口安全域名”. JS接口安全域名设置 mi.com(前面不用带www/http,域名必须备案过) 2.引 ...