`
zhuqiang5138
  • 浏览: 30460 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

android 联系人快速搜索

阅读更多
先来分析下 如果是搜索联系人 大概有多少种条件:
  1、按姓名
  2、按号码
  3、按拼音简拼
  4、按拼音全拼
  5、按拨号盘[也就是上面的都有可能]

如果还有别的搜索策略 也可以很快的扩展的吧。

姓名、号码、全拼和简拼都在联系人表中都是可以分析出来的。
分别是display_name、number、sort_key或者sort_key_alt。
那么 就可以使用sql语句来查询了。
这里只有全拼和简拼是需要转换下,代码如下:

sort_key字段是形如:“ZHU 朱 QIANG 强”,对其解析得到需要的全拼和简拼字符串即可。

public class AnalyticString {
	/**
	 * 字符串解析为字符串数组
	 * @param str
	 * @return
	 */
	public String[] getStrings(String str)
	{
		return str.split(" ");
	}
	
	/***
	 * 是否为字母
	 * @param str
	 * @return
	 */
	public boolean getLetter(String str)
	{
		return str.matches("^[A-Za-z]+$");
	}
	
	/**
	 * 得到全拼或简拼
	 * @param strs 字符串数组
	 * @param type 全拼还是简拼
	 * @return
	 */
	public String getString(String[] strs,int type)
	{
		String[] newStrs = new String[strs.length];
		int j = 0;
		for(int i=0;i<strs.length;i++)
		{
			String firstLetter = strs[i].substring(0,1);
			if(getLetter(firstLetter))
			{
				//type=0 out jp
				if(type==0)
				{
					newStrs[j] = firstLetter;
				}
				//type=1 out qp
				else
				{
					newStrs[j] = strs[i];
				}
				j++;
			}
		}
		StringBuffer sb = new StringBuffer();
		for(int k = 0; k < newStrs.length; k++){
			if(newStrs[k] != null)
			{
				sb.append(newStrs[k]);
			}
		}
		return sb.toString();
	}
	
	public static void main(String [] args)
	{
		AnalyticString as = new AnalyticString();
		System.out.println(as.getString(as.getStrings("ZHU 朱 QIANG 强"),1));
	}
}


上面的代码的结果就是:ZHUQIANG

这里先分离出全拼和简拼,具体的做法如下:
ContentResolver contentResolver;
String projection[] = {Phone.CONTACT_ID,Phone.DISPLAY_NAME,Phone.NUMBER,"sort_key"};
Cursor cursor =  contentResolver.query(Phone.CONTENT_URI, projection, getCondition(str), null, "sort_key COLLATE LOCALIZED asc");
//下面是把cursor中的数据一一的读入一个List中去,其中包括全拼和简拼字段,条件变更就基于第一遍的集合过滤。
public static String getCondition(String value)
	{
		String string = null;
		if ("".equals(value) && null==value) 
		{
			return string;
		}
		else
		{
			string = "display_name like '%"+ value +"%' or data1 like '%"+ value +"%' or sort_key like '%"+ value +"%'";
			return string;
		}
	} 
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics