1. 單關鍵字 比對
如果隻是單關鍵字的話,那麼我們先計算出他的下标,它的長度,然後就可以标記下标到下标+長度的這一段為特殊顔色即可,代碼如下:
if (name != null && name.contains(keyWord)) {
int index = name.indexOf(keyWord);
int len = keyWord.length();
Spanned temp = Html.fromHtml(name.substring(, index)
+ "<font color=#FF0000>"
+ name.substring(index, index + len) + "</font>"
+ name.substring(index + len, name.length()));
}
temp 即是改變後的字,keyWord就加了紅色。
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() - ; i>= ;i--) {
String theNext=inputs.get(i);
int theIndex=str.indexOf(theNext);
if(theIndex==-){//過濾掉無效關鍵字
inputs.remove(i);
}else if(theIndex<index){
index=theIndex;//替換下标
next=theNext;
}
}
//如果條件成立,表示串中已經沒有可以被替換的關鍵字,否則遞歸處理
if(index==str.length()){
resStr.append(str);
}else{
resStr.append(str.substring(,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;
}