像按照 拼音首字母搜索功能、zs -> 张三
       全拼音搜索功能,如张三,输入zhang或者输入san都可以找到
       同音字搜索功能,只要输入“梦”,“盟”等字,就可以找到张孟这怎么实现啊。急

解决方案 »

  1.   

    去把系统自带的google拼音源码弄出来,然后用里面的拼音识别库来完成你的功能吧
      

  2.   

    public class StringUtil {private static Log logger = LogFactory.getLog(StringUtil.class);// 国标码和区位码转换常量
    static final int GB_SP_DIFF = 160;
    //存放国标一级汉字不同读音的起始区位码
    static final int[] secPosValueList = {
    1601, 1637, 1833, 2078, 2274, 2302, 2433, 2594, 2787,
    3106, 3212, 3472, 3635, 3722, 3730, 3858, 4027, 4086,
    4390, 4558, 4684, 4925, 5249, 5600};//存放国标一级汉字不同读音的起始区位码对应读音
    static final char[] firstLetter = {
    'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'j',
    'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's',
    't', 'w', 'x', 'y', 'z'};//获取一个字符串的拼音码
    public static String getFirstLetter(String oriStr) {
    String str = oriStr.toLowerCase();
    StringBuffer buffer = new StringBuffer();
    char ch;
    char[] temp;
    for (int i = 0; i < str.length(); i++) { //依次处理str中每个字符
    ch = str.charAt(i);
    temp = new char[] {ch};
    byte[] uniCode = new String(temp).getBytes();
    if (uniCode[0] < 128 && uniCode[0] > 0) { // 非汉字
    buffer.append(temp);
    } else {
    buffer.append(convert(uniCode));
    }
    }
    return buffer.toString();
    }/** 获取一个汉字的拼音首字母。
    * GB码两个字节分别减去160,转换成10进制码组合就可以得到区位码
    * 例如汉字“你”的GB码是0xC4/0xE3,分别减去0xA0(160)就是0x24/0x43
    * 0x24转成10进制就是36,0x43是67,那么它的区位码就是3667,在对照表中读音为‘n’
    */static char convert(byte[] bytes) {char result = '-';
    int secPosValue = 0;
    int i;
    for (i = 0; i < bytes.length; i++) {
    bytes[i] -= GB_SP_DIFF;
    }
    secPosValue = bytes[0] * 100 + bytes[1];
    for (i = 0; i < 23; i++) {
    if (secPosValue >= secPosValueList[i] && secPosValue < secPosValueList[i + 1]) {
    result = firstLetter[i];
    break;
    }
    }
    return result;
    }
    public static void main(String[] args) {
    System.out.println(StringUtil.getFirstLetter("I love u"));
    System.out.println(StringUtil.getFirstLetter("我爱北京天安门"));
    System.out.println(StringUtil.getFirstLetter("I love 北京天安门"));
    }
    }运行输出:
    i love u
    wabjtam
    i love bjtam
      

  3.   

    从谷歌源码里找到的方法,简单又实用,满足首拼,全拼搜索
    public Cursor searchContact(Context ctxt, CharSequence constraint) {
    Uri uri = Uri.withAppendedPath(ContactsContract.CommonDataKinds.Phone.CONTENT_FILTER_URI, Uri.encode(cons));
    return ctxt.getContentResolver().query(uri,
                        PROJECTION_PHONE,
                        null, //selection,
                        null,
                        SORT_ORDER);
    }