实现方式没有引入任何依赖,轻量级实现需求效果
最近遇到一个需求,需要做一个搜索功能。搜索的内容需要加粗显示。
完成了这个功能后,写下此博客,记录一下实现过程
效果图
首先自定义一个StyleSpan,在StyleSpan里做加粗的等匹配状态的设置
@Suppresslint("ParcelCreator")public class SearchStyleSpan extends StyleSpan { public SearchStyleSpan(int style) { super(style); } @OverrIDe public voID updateDrawState(TextPaint ds) { ds.setFakeBoldText(true); //FIXME 这里还可以做其他差异性设置(修改文字大小等) super.updateDrawState(ds); } @OverrIDe public voID updateMeasureState(TextPaint paint) { paint.setFakeBoldText(true); super.updateMeasureState(paint); }}
监听编辑框的内容变化
mEditText.addTextChangedListener(new TextWatcher() { @OverrIDe public voID beforeTextChanged(CharSequence s,int start,int count,int after) { } @OverrIDe public voID onTextChanged(CharSequence s,int before,int count) { } @OverrIDe public voID afterTextChanged(Editable editable) { checkSearchContent(mEditText.getText().toString()); } });
通过循环,将TextVIEw 里的文字根据匹配内容分段
SpannableStringBuilder searchStyle = new SpannableStringBuilder(); int start; while (content.contains(searchContent)) { start = content.indexOf(searchContent); searchStyle.append(getBoldSpannable(content.substring(0,start + searchContent.length()),searchContent)); content = content.substring(start + searchContent.length()); } searchStyle.append(content);
将分段好的文字进行加粗处理
int start = content.indexOf(searchContent); SpannableStringBuilder ssb = new SpannableStringBuilder(content); ssb.setSpan(new SearchStyleSpan(Typeface.norMAL),start,start + searchContent.length(),Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
源码地址:https://github.com/TitleZWC/BoldSpannable
以上所述是小编给大家介绍的AndroID 开发中根据搜索内容实现TextVIEw中的文字部分加粗,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程小技巧网站的支持!
总结以上是内存溢出为你收集整理的Android 开发中根据搜索内容实现TextView中的文字部分加粗全部内容,希望文章能够帮你解决Android 开发中根据搜索内容实现TextView中的文字部分加粗所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)