android 搜索自動匹配關鍵字並且標紅


                                                           

 

這個效果主要是為了着重表現搜索關鍵字的 。

 

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;
	}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM