这个效果主要是为了着重表现搜索关键字的 。
1. 单关键字匹配
若只需匹配 搜索内容可以写的简单一些,代码如下:
if(name!=null&&name.contains(mKeyWord)){
intindex=name.indexOf(mKeyWord);
intlen=mKeyWord.length();
Spannedtemp=Html.fromHtml(name.substring(0,index)
+""
+name.substring(index,index+len)+""
+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集合
*/
StringBufferstr=newStringBuffer("");
str=Utils.addChild(name,keyList,str);
holder.contentTv.setText(Html.fromHtml(str.toString()));
匹配方法:
/**
*多关键字查询表红,避免后面的关键字成为特殊的HTML语言代码
*@paramstr检索结果
*@paraminputs关键字集合
*@paramresStr表红后的结果
*/
publicstaticStringBufferaddChild(Stringstr,Listinputs,StringBufferresStr){
intindex=str.length();//用来做为标识,判断关键字的下标
Stringnext="";//保存str中最先找到的关键字
for(inti=inputs.size()-1;i>=0;i--){
StringtheNext=inputs.get(i);
inttheIndex=str.indexOf(theNext);
if(theIndex==-1){//过滤掉无效关键字
inputs.remove(i);
}elseif(theIndex<index){
index=theIndex;//替换下标
next=theNext;
}
}
//如果条件成立,表示串中已经没有可以被替换的关键字,否则递归处理
if(index==str.length()){
resStr.append(str);
}else{
resStr.append(str.substring(0,index));
resStr.append("<fontcolor='#FF0000'>"+str.substring(index,index+next.length())+"</font>");
Stringstr1=str.substring(index+next.length(),str.length());
addChild(str1,inputs,resStr);//剩余的字符串继续替换
}
returnresStr;
}