這個效果主要是為了着重表現搜索關鍵字的 。
1. 單關鍵字匹配
若只需匹配 搜索內容 可以寫的簡單一些,代碼如下:
if (name != null && name.contains(mKeyWord)) {
int index = name.indexOf(mKeyWord);
int len = mKeyWord.length();
Spanned temp = Html.fromHtml(name.substring(0, index)
+ "<font color=#FF0000>"
+ name.substring(index, index + len) + "</font>"
+ name.substring(index + len, name.length()));
holder.tv_name.setText(temp);
} else {
holder.tv_name.setText(name);
}
上面的name是你要顯示整個item內容, mKeyWord 是搜索的關鍵字 holder.tv_name 是當前textview控件
2.多關鍵字匹配
有的時候我們做搜索的時候 是需要將 用戶輸入的關鍵字 在服務端做拆分 ,拆分為多個關鍵字去搜索。那么服務端返回數據的時候 關鍵字被拆分為多個。也就是返回的是一個 關鍵字數組。
這種情況我們在客戶端做 關鍵字匹配的時候就要寫一個算法,將段落中的多個關鍵字全部匹配並且標出來。
代碼如下:
adapter里面邏輯:
/**
name 是item顯示內容 當前item顯示字符串內容
keyList 是指存放 多個關鍵字的list集合
*/
StringBuffer str = new StringBuffer("");
str = Utils.addChild(name, keyList, str);
holder.contentTv.setText(Html.fromHtml(str.toString()));
匹配方法:
/**
* 多關鍵字查詢表紅,避免后面的關鍵字成為特殊的HTML語言代碼
* @param str 檢索結果
* @param inputs 關鍵字集合
* @param resStr 表紅后的結果
*/
public static StringBuffer addChild(String str,List<String> inputs,StringBuffer resStr){
int index=str.length();//用來做為標識,判斷關鍵字的下標
String next="";//保存str中最先找到的關鍵字
for (int i = inputs.size() -1 ; i>= 0;i--) {
String theNext=inputs.get(i);
int theIndex=str.indexOf(theNext);
if(theIndex==-1){//過濾掉無效關鍵字
inputs.remove(i);
}else if(theIndex<index){
index=theIndex;//替換下標
next=theNext;
}
}
//如果條件成立,表示串中已經沒有可以被替換的關鍵字,否則遞歸處理
if(index==str.length()){
resStr.append(str);
}else{
resStr.append(str.substring(0,index));
resStr.append("<font color='#FF0000'>"+str.substring(index,index+next.length())+"</font>");
String str1=str.substring(index+next.length(),str.length());
addChild(str1,inputs,resStr);//剩余的字符串繼續替換
}
return resStr;
}
