美文网首页
SpannableString字体更改工具类

SpannableString字体更改工具类

作者: 玖玖君 | 来源:发表于2019-08-26 15:42 被阅读0次

    导读:

    SpannableString(标签文本),可以用来显示复合文本,我们可以通过SpannableString给文本设置各种各样的样式。比如部分文本变色,商城打折的删除线,粗体,斜体,不同大小的文字,文字混合表情,文字点击链接等。TextView通过设置SpannableString后功能就异常强大了,在自定义的Span的情况下,可以说就要上天了。
    SpannableStringBuilder支持字符串拼接

    认识:

    SpannableString继承于CharSequence,所以通过textView.setText(spannableString)的方式使用。SpannableString构造方法参数传入需要设置样式的文本。

    public void setSpan(Object what, int start, int end, int flags)
    what为各种类型Span,start为起始位置,end为结束位置,flags为开闭区间的标致。

    flags类型:
    Spanned.SPAN_INCLUSIVE_EXCLUSIVE 从起始下标到终了下标,包括起始下标
    Spanned.SPAN_INCLUSIVE_INCLUSIVE 从起始下标到终了下标,同时包括起始下标和终了下标
    Spanned.SPAN_EXCLUSIVE_EXCLUSIVE 从起始下标到终了下标,但都不包括起始下标和终了下标
    Spanned.SPAN_EXCLUSIVE_INCLUSIVE 从起始下标到终了下标,包括终了下标
     
    

    下面我们一一解读几种Span常用的格式:
    ForegroundColorSpan,为文本设置前景色,效果和TextView的setTextColor()类似,实现方法如下:

    SpannableString span = new SpannableString("设置文字的前景色为淡蓝色");
    ForegroundColorSpan colorSpan = new ForegroundColorSpan(Color.parseColor("#0099EE"));
    span.setSpan(colorSpan, 9, spannableString.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE); 
    textView.setText(span);
    

    BackgroundColorSpan,为文本设置背景色,效果和TextView的setBackground()类,实现方法如下:

    SpannableString span = new SpannableString("设置文字的背景色为淡绿色");
    BackgroundColorSpan colorSpan = new BackgroundColorSpan(Color.parseColor("#AC00FF30"));
    span.setSpan(colorSpan, 9, spannableString.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
    textView.setText(span);
    
    • RelativeSizeSpan
      RelativeSizeSpan,设置文字相对大小,在TextView原有的文字大小的基础上,相对设置文字大小,实现方法如下:
    SpannableString spannableString = new SpannableString("万丈高楼平地起");
    
    RelativeSizeSpan sizeSpan01 = new RelativeSizeSpan(1.2f);
    RelativeSizeSpan sizeSpan02 = new RelativeSizeSpan(1.4f);
    RelativeSizeSpan sizeSpan03 = new RelativeSizeSpan(1.6f);
    RelativeSizeSpan sizeSpan04 = new RelativeSizeSpan(1.8f);
    RelativeSizeSpan sizeSpan05 = new RelativeSizeSpan(1.6f);
    RelativeSizeSpan sizeSpan06 = new RelativeSizeSpan(1.4f);
    RelativeSizeSpan sizeSpan07 = new RelativeSizeSpan(1.2f);
    
    spannableString.setSpan(sizeSpan01, 0, 1, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
    spannableString.setSpan(sizeSpan02, 1, 2, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
    spannableString.setSpan(sizeSpan03, 2, 3, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
    spannableString.setSpan(sizeSpan04, 3, 4, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
    spannableString.setSpan(sizeSpan05, 4, 5, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
    spannableString.setSpan(sizeSpan06, 5, 6, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
    spannableString.setSpan(sizeSpan07, 6, 7, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
    textView.setText(spannableString);
    
    • StrikethroughSpan
      StrikethroughSpan,为文本设置中划线,也就是常说的删除线,实现方法如下:
    SpannableString spannableString = new SpannableString("为文字设置删除线");
    StrikethroughSpan strikethroughSpan = new StrikethroughSpan();
    spannableString.setSpan(strikethroughSpan, 5, spannableString.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
    textView.setText(spannableString);
    
    • SuperscriptSpan
      UnderlineSpan,为文本设置下划线,具体实现方法如下:
    SpannableString span= new SpannableString("为文字设置下划线");
    UnderlineSpan underlineSpan = new UnderlineSpan();
    span.setSpan(underlineSpan, 5, spannableString.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
    textView.setText(span);
    
    • SubscriptSpan
      SuperscriptSpan,设置上标,具体实现方法如下:
    SpannableString span = new SpannableString("为文字设置上标");
    SuperscriptSpan superscriptSpan = new SuperscriptSpan();
    span.setSpan(superscriptSpan, 5, spannableString.length(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
    textView.setText(span);
    
    • StyleSpan
      StyleSpan,为文字设置风格(粗体、斜体),和TextView属性textStyle类似,实现方法如下:
    SpannableString span = new SpannableString("为文字设置粗体、斜体风格");
    StyleSpan styleSpan_B  = new StyleSpan(Typeface.BOLD);
    StyleSpan styleSpan_I  = new StyleSpan(Typeface.ITALIC);
    span.setSpan(styleSpan_B, 5, 7, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
    spannableString.setSpan(styleSpan_I, 8, 10, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
    textView.setHighlightColor(Color.parseColor("#36969696"));
    textView.setText(span);
    
    • ImageSpan
      ImageSpan,设置文本图片,实现方法如下:
    SpannableString span = new SpannableString("在文本中添加表情(表情)");
    Drawable drawable = getResources().getDrawable(R.mipmap.a9c);
    drawable.setBounds(0, 0, 42, 42);
    ImageSpan imageSpan = new ImageSpan(drawable);
    span.setSpan(imageSpan, 6, 8, Spanned.SPAN_INCLUSIVE_EXCLUSIVE);
    textView.setText(span);
    

    这一个是不是很炫酷?再加一个解析算法,将文本中特定的文本转换成特定的表情图片,分分钟实现聊天表情显示效果有木有啊朋友们!

    • ClickableSpan
      ClickableSpan,设置可点击的文本,设置这个属性的文本可以相应用户点击事件,至于点击事件用户可以自定义,就像效果图显示一样,用户可以实现点击跳转页面的效果,具体实现方法如下:
    
    //设置字体的点击事件
    
     private class TextClick extends ClickableSpan {
            @Override
            public void onClick(View widget) {
                //在此处理点击事件
            
            }
      @Override
        public void updateDrawState(TextPaint ds) {
          //设置是否有下划线
            ds.setUnderlineText(false);
        }
    }
    
    spannable.setSpan (new TextClick (), 213, 258
                    , Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
    
    //设置字体的颜色
     spannable.setSpan (new ForegroundColorSpan (Color.RED), 213, 258
                    , Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
    
    Tip:

    如果想要TextView点击有效果,则必须添加方法,否则没有点击相应,至于setHighlightColor方法则是控制点击是的背景色。

     TextView.setMovementMethod (LinkMovementMethod.getInstance ());
    

    除此之外,还有MaskFilterSpan可以实现模糊和浮雕效果,RasterizerSpan可以实现光栅效果,因为以上两个使用频率不高,而且效果也不是很明显,就不做详细说明,有兴趣的小伙伴不妨去试一试。

    文章很短,路还漫长,大家好,我是玖玖君,一个帅气与才华并存的男人,我们下期再见

    相关文章

      网友评论

          本文标题:SpannableString字体更改工具类

          本文链接:https://www.haomeiwen.com/subject/pszrectx.html