Android基于RecyclerView实现高亮搜索列表
话不多说先看今天的实现的效果:
相信这种效果很多项目都会用到,今天就讲讲利用recycleview来实现他,博主把此篇文章定位初级篇,可能因为这确实很简单,所以我要更要讲的详细一点让新手也可以能看的懂。
饭要开始做了,我们要准备哪些食材呢。
1.一个recyclerview或是listview或是其他可以显示多item的控件(主要的干货)
2.搞清楚edittext的实时监听
3.让一个textview出现不同的颜色
4.如何穿过adpter找出textview中key值(也就是高亮字符串)
当你打通这四个技术点后,如果还不能实现这种效果,那么你能说你现在的学习太死板,不会活学活用。如果你看到效果立马想到这四个技术点说明你有一定的项目组织能力了。接下来我们就解析一下这个四个食材。
1.recyclerview犹豫这里比较简单可以使用原声的recyclerview,但是笔者一直在用封装好的recyclerview所以还用我之前封装好的来实现,如果对recyclerview还不熟悉的传送门送你走:
2.edittext事实输入监听,其实就是个借口每次editext中的字符发生改变会回调这个接口:
textwatcher textwatcher = new textwatcher() { @override public void beforetextchanged(charsequence charsequence, int i, int i1, int i2) { } @override public void ontextchanged(charsequence charsequence, int i, int i1, int i2) { } @override public void aftertextchanged(editable editable) { } };
啪啪啪一注册接口,ontextchanged就是我们想要的方法了:
editmobile.addtextchangedlistener(textwatcher);
3.textview显示不同颜色,其实这有很多种实现方式,最笨的就是用两个或者说是用三个textview左右挨着实现高亮颜色,然而这并不科学,我们使用stringformatutil这样一个工具类来实现高亮颜色。
stringformatutil spanstr3 = new //分别是上下文,原串,key,高亮颜色。 stringformatutil(mcontext, data.name, mkey, r.color.blue).fillcolor(); customerholder.tvname.settext(spanstr3.getresult());
4.adapter如何知道key。
在构造方法去传入就可以了:
public customercampanysearchadapter(list<customer> list, context context, string key) { super(list); mcontext = context; mkey = key; this.list = list; }
好的4个食材我们就准备好了
烹饪逻辑如下:
1.注册生产所有类。
2.在实时监控edittext的回调接口中重新构造customercampanysearchadapter传入新的key值。
public void showcustomer(list<customer> list, string key) { if (list == null || list.size() == 0) return; customerlist.clear(); customerlist.addall(list); adapter = new customercampanysearchadapter(customerlist, this, key); superrecyclerview.setadapter(adapter); superrecyclerview.showdata(); adapter.setonitemclicklistener(new baserecycleradapter.onitemclicklistener() { @override public void onitemclick(view view, int position, long id) { // } }); }
3.在customercampanysearchadapter中的onbindviewholder方法中改变textview的高亮key值。
@override public void onbindviewholder(baserecyclerviewholder holder, int position, final customer data) { customerholder customerholder = (customerholder) holder; customerholder.tvname.settext(data.name); stringformatutil spanstr3 = new stringformatutil(mcontext, data.name, mkey, r.color.blue).fillcolor(); if (spanstr3 != null) customerholder.tvname.settext(spanstr3.getresult()); else customerholder.tvname.settext(data.name); }
效果就这样完美实现了,也提倡大家在分析的时候一定要冷静,首先看懂自己要什么效果,之后就是你需要什么子效果,然后是怎么把这些子效果串起来实现最终的效果。
本文github:欢迎star https://github.com/androidmsky/searchview
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
推荐阅读
-
Android基于RecyclerView实现高亮搜索列表
-
Android基于RecyclerView实现高亮搜索列表
-
Android单个RecyclerView实现列表嵌套的效果
-
Android中RecyclerView实现多级折叠列表效果(二)
-
Android中RecyclerView实现多级折叠列表效果(TreeRecyclerView)
-
Android单个RecyclerView实现列表嵌套的效果
-
Android使用RecyclerView实现列表数据选择操作
-
Android中RecyclerView实现多级折叠列表效果(TreeRecyclerView)
-
Android中RecyclerView实现多级折叠列表效果(二)
-
基于Vue实现关键词实时搜索高亮显示关键词