編輯:關於Android編程
國慶回了趟家,昨天真不想走,離家近的感覺太好。唉,不扯這些,說說今天的正事吧。
上篇博客中介紹了自定義AutoCompleteTextView ,但是用到了一個很蹩腳的技術,就是我們事先把每個漢字的拼音當作一個字段輸入進去了,在實際的開發中肯定不會這樣做,我們要通過代碼自動生成漢字的拼音,就像我們的手機通訊錄,比如我們要查找“張三”這個人,我們只需要輸入“zs”、“cs”或者“zhangsan”、“changsan”就能搜索到該人,那麼我們該怎麼來實現這樣的功能呢?
本文所述案例是在上篇博客的基礎上實現的,如果還沒閱讀上篇博客,請看android開發之自定義AutoCompleteTextView。
本文要實現的整體效果如下圖所示:
vcrH1Nq5udTst723qNbQs/XKvLuvxrTS9Lyvus+jujwvcD4NCjxwPrjE1Oy687XEubnU7Le9t6ijujwvcD4NCjxwcmUgY2xhc3M9"brush:java;">
public MyActAdapter(Context context, List
這個方法主要是初始化兩個List集合,一個是pinYinList 另一個是pinYinAllList ,前者是所有書的作者姓名拼音的首字母集合,後者是所有書的作者姓名拼音全拼集合。
private void initPinYinList() {
pinYinList = new ArrayList>();
pinYinAllList = new ArrayList>();
PinYin4j pinyin = new PinYin4j();
for (int i = 0; i < books.size(); i++) {
pinYinList.add(pinyin.getPinyin(books.get(i).getAuthor().toString()));
pinYinAllList.add(pinyin.getAllPinyin(books.get(i).getAuthor().toString()));
}
}
這裡還涉及到兩個類,如下:
PinYin4j.java
package com.example.myact;
import java.util.Arrays;
import java.util.HashSet;
import java.util.Set;
public class PinYin4j {
public PinYin4j(){
}
/**
* 字符串集合轉換字符串(逗號分隔)
*
* @author wangsong
* @param stringSet
* @return
*/
public String makeStringByStringSet(Set stringSet) {
StringBuilder str = new StringBuilder();
int i = 0;
for (String s : stringSet) {
if (i == stringSet.size() - 1) {
str.append(s);
} else {
str.append(s + ,);
}
i++;
}
return str.toString().toLowerCase();
}
/**
* 獲取漢字拼音全拼
*
* @author wangsong
* @param src
* @return Set
*/
public Set getAllPinyin(String src) {
char[] srcChar;
srcChar = src.toCharArray();
String[][] temp = new String[src.length()][];
for (int i = 0; i < srcChar.length; i++) {
char c = srcChar[i];
if (String.valueOf(c).matches([\u4E00-\u9FA5]+)) {
String[] t = PinyinHelper.getUnformattedHanyuPinyinStringArray(c);
temp[i] = new String[t.length];
for(int j=0;j= 65 && (int) c <= 90)
|| ((int) c >= 97 && (int) c <= 122)||c>=48&&c<=57||c==42) {
temp[i] = new String[] { String.valueOf(srcChar[i]) };
} else {
temp[i] = new String[] {null!};
}
}
String[] pingyinArray = paiLie(temp);
return array2Set(pingyinArray);
}
/**
* 獲取漢字拼音首字母集合
*
* @author wangsong
* @param src
* @return Set
*/
public Set getPinyin(String src) {
char[] srcChar;
srcChar = src.toCharArray();
String[][] temp = new String[src.length()][];
for (int i = 0; i < srcChar.length; i++) {
char c = srcChar[i];
if (String.valueOf(c).matches([\u4E00-\u9FA5]+)) {
String[] t = PinyinHelper.getUnformattedHanyuPinyinStringArray(c);
temp[i] = new String[t.length];
for(int j=0;j= 65 && (int) c <= 90)
|| ((int) c >= 97 && (int) c <= 122)||c>=48&&c<=57||c==42) {
temp[i] = new String[] { String.valueOf(srcChar[i]) };
} else {
temp[i] = new String[] {null!};
}
}
String[] pingyinArray = paiLie(temp);
return array2Set(pingyinArray);
}
/*
* 求2維數組所有排列組合情況
* 比如:{{1,2},{3},{4},{5,6}}共有2中排列,為:1345,1346,2345,2346
*/
private String[] paiLie(String[][] str){
int max=1;
for(int i=0;i Set array2Set(T[] tArray) {
Set tSet = new HashSet(Arrays.asList(tArray));
// TODO 沒有一步到位的方法,根據具體的作用,選擇合適的Set的子類來轉換。
return tSet;
}
}
PinyinHelper.java
package com.example.myact;
import java.io.BufferedInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.Properties;
public class PinyinHelper {
private static PinyinHelper instance;
private Properties properties = null;
public static String[] getUnformattedHanyuPinyinStringArray(char ch) {
return getInstance().getHanyuPinyinStringArray(ch);
}
private PinyinHelper() {
initResource();
}
public static PinyinHelper getInstance() {
if (instance == null) {
instance = new PinyinHelper();
}
return instance;
}
private void initResource() {
try {
final String resourceName = /assets/unicode_to_hanyu_pinyin.txt;
// final String resourceName = /assets/unicode_py.ini;
properties = new Properties();
properties.load(getResourceInputStream(resourceName));
} catch (FileNotFoundException ex) {
ex.printStackTrace();
} catch (IOException ex) {
ex.printStackTrace();
}
}
private BufferedInputStream getResourceInputStream(String resourceName) {
return new BufferedInputStream(
PinyinHelper.class.getResourceAsStream(resourceName));
}
private String[] getHanyuPinyinStringArray(char ch) {
String pinyinRecord = getHanyuPinyinRecordFromChar(ch);
if (null != pinyinRecord) {
int indexOfLeftBracket = pinyinRecord.indexOf(Field.LEFT_BRACKET);
int indexOfRightBracket = pinyinRecord
.lastIndexOf(Field.RIGHT_BRACKET);
String stripedString = pinyinRecord.substring(indexOfLeftBracket
+ Field.LEFT_BRACKET.length(), indexOfRightBracket);
return stripedString.split(Field.COMMA);
} else
return null;
}
private String getHanyuPinyinRecordFromChar(char ch) {
int codePointOfChar = ch;
String codepointHexStr = Integer.toHexString(codePointOfChar)
.toUpperCase();
String foundRecord = properties.getProperty(codepointHexStr);
return foundRecord;
}
class Field {
static final String LEFT_BRACKET = (;
static final String RIGHT_BRACKET = );
static final String COMMA = ,;
}
public static String[] toHanyuPinyinStringArray(char ch) {
return getUnformattedHanyuPinyinStringArray(ch);
}
}
這裡是初始化拼音集合。
第二個改造的地方就是在過濾器中增加過濾的條件。
這是最新的過濾器,和上文相比,這裡只是增加了一個else分支,在else分支中判斷搜索條件是否符合要求。
private class ArrayFilter extends Filter {
@Override
protected FilterResults performFiltering(CharSequence constraint) {
FilterResults results = new FilterResults();
if (mFilterBooks == null) {
mFilterBooks = new ArrayList(books);
}
// 如果沒有過濾條件則不過濾
if (constraint == null || constraint.length() == 0) {
results.values = mFilterBooks;
results.count = mFilterBooks.size();
} else {
List retList = new ArrayList();
// 過濾條件
String str = constraint.toString().toLowerCase();
Book book;
// 循環變量數據源,如果有屬性滿足過濾條件,則添加到result中
for (int i = 0; i < mFilterBooks.size(); i++) {
book = mFilterBooks.get(i);
if (book.getAuthor().contains(str)
|| book.getName().contains(str)
|| (book.getId() + ).contains(str)
|| (book.getPrice() + ).contains(str)
|| book.getPinyin().contains(str)) {
retList.add(book);
} else {
//查看作者姓名拼音首字母是否符合過濾條件
Set pinyinSet = pinYinList.get(i);
Iterator pinyin = pinyinSet.iterator();
while (pinyin.hasNext()) {
if (pinyin.next().toString().contains(str)) {
retList.add(book);
break;
}
}
//查看作者姓名拼音全拼是否符合過濾條件
Set pinyinAllSet = pinYinAllList.get(i);
Iterator pinyinAll = pinyinAllSet.iterator();
while (pinyinAll.hasNext()) {
if (pinyinAll.next().toString().contains(str)) {
retList.add(book);
break;
}
}
}
// if (maxMatch > 0) {
// if (retList.size() > maxMatch - 1) {
// break;
// }
// }
}
results.values = retList;
results.count = retList.size();
}
return results;
}
// 在這裡返回過濾結果
@Override
protected void publishResults(CharSequence constraint,
FilterResults results) {
// notifyDataSetInvalidated(),會重繪控件(還原到初始狀態)
// notifyDataSetChanged(),重繪當前可見區域
books = (List) results.values;
if (results.count > 0) {
notifyDataSetChanged();
} else {
notifyDataSetInvalidated();
}
}
}
直接上效果圖 功能特色: 1、可以設置刮開後顯示文字或圖片 2、可以統計已刮開區域所占百分比 Demo下載地址:RubberDem
前言安卓開發中,在寫布局代碼的時候,ide可以看到布局的預覽效果。但是有些效果則必須在運行之後才能看見,比如這種情況:TextView在xml中沒有設置任何字符,而是在a
volley介紹開發android應用很多時候都要涉及網絡操作,Android SDK中提供了HttpClient 和 HttpUrlConnection兩種方式用來處理
0、基礎回顧PropertyAnimation,屬性動畫,顧名思義就是利用對象的屬性變化形成動畫的效果。屬性動畫的類可以用Animator這個抽象類來表示,通常使用它的子