zoukankan      html  css  js  c++  java
  • 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;
    	}
  • 相关阅读:
    前端框架搭建
    npm的镜像和淘宝互换
    grunt,gulp,webpack前端打包工具的特性
    react 文章
    大数据学习08_HDFS2
    大数据学习07_HDFS1
    大数据学习06_zookeeper3_javaAPI操作
    大数据学习05_zookeeper2
    大数据学习04_zookeeper1
    大数据学习03_Linux集群搭建_辅助工具的安装
  • 原文地址:https://www.cnblogs.com/xgjblog/p/6888633.html
Copyright © 2011-2022 走看看