美文网首页
Spannable丰富Android文本

Spannable丰富Android文本

作者: 寻味Android | 来源:发表于2017-10-11 14:27 被阅读0次

            在项目中很常用到Spannable,既丰富了文本又精简了布局。SpannableString、SpannableStringBuilder是Spannable的具体实现类,我们就是用它们来丰富文本的;来一段代码看看它们的使用:

    String str="12315465科技生活,人文娱乐,科技创新";

    SpannableStringBuilder spanTextInterest =new SpannableStringBuilder(str);

    spanTextInterest.setSpan(new AbsoluteSizeSpan(18,true),0,1,Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

    tv_content.setText(spanTextInterest);

    我们就是使用setSpan这个方法来标识文本的样式,方法意义:给SpannableString或SpannableStringBuilder特定范围的字符串设定Span样式,可以设置多个(比如同时加上下划线和删除线等),Falg参数标识了当在所标记范围前和标记范围后紧贴着插入新字符时的动作,即是否对新插入的字符应用同样的样式。

    参数说明:

    object what:对应的各种Span,后面会提到;

    int start:开始应用指定Span的位置,索引从0开始

    int end:结束应用指定Span的位置,特效并不包括这个位置。比如如果这里数为3(即第4个字符),第4个字符不会有任何特效。

    int flags:取值有如下四个

    Spannable.SPAN_EXCLUSIVE_EXCLUSIVE:前后都不包括,即在指定范围的前面和后面插入新字符都不会应用新样式

    Spannable.SPAN_EXCLUSIVE_INCLUSIVE:前面不包括,后面包括。即仅在范围字符的后面插入新字符时会应用新样式

    Spannable.SPAN_INCLUSIVE_EXCLUSIVE:前面包括,后面不包括。

    Spannable.SPAN_INCLUSIVE_INCLUSIVE:前后都包括。

    各种的Span:

    1.URLSpan

    功能:点击文字,可以打开一个URL。

    String  str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder  spannableStringBuilder = new  SpannableStringBuilder(str);

    spannableStringBuilder.setSpan(new  URLSpan("https://www.baidu.com/"),0,5,Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    // 在单击链接时凡是有要执行的动作,都必须设置MovementMethod对象

    tv_content.setMovementMethod(LinkMovementMethod.getInstance());

    // 设置点击后的颜色,这里涉及到ClickableSpan的点击背景

    tv_content.setHighlightColor(0xff8FABCC);

    2.UnderlineSpan

    功能:设置文字下划线。

    String  str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder  spannableStringBuilder =new  SpannableStringBuilder(str);

    spannableStringBuilder.setSpan(new  UnderlineSpan(),0,5,Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    3.TypefaceSpan

    功能:设置文字字体。

    TypefaceSpan(String family)构造方法源码中的注释提示了三种系统字体:

    monospace

    serif

    sans-serif

    String   str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder   spannableStringBuilder =new   SpannableStringBuilder(str);

    spannableStringBuilder.setSpan(new  TypefaceSpan("serif"),0,5,Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    4.TextAppearanceSpan

    功能:设置文字字体、文字样式(粗体、斜体、等等)、文字颜色状态、文字下划线颜色状态等等。

    TextAppearanceSpan的三个构造方法

    TextAppearanceSpan(Context context, int appearance)

    TextAppearanceSpan(Context context, int appearance, int colorList)

    TextAppearanceSpan(String family, int style, int  size,ColorStateList color, ColorStateList linkColor)

    family:monospace、serif、sans-serif

    style:Typeface.NORMAL、Typeface.BOLD、Typeface.ITALIC、Typeface.BOLD_ITALIC

    size:表示字体大小(单位px)

    String  str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder  spannableStringBuilder =new  SpannableStringBuilder(str);

    ColorStateList  colorStateList =null;

    if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {

    colorStateList =getColorStateList(R.color.selector_apperarance_span);

    }else{

    try{

    colorStateList = ColorStateList.createFromXml(getResources(), getResources().getXml(R.color.selector_apperarance_span));

    }catch(XmlPullParserException | IOException e) {

    e.printStackTrace();

    }

    }

    spannableStringBuilder.setSpan(new TextAppearanceSpan("serif",Typeface.BOLD_ITALIC,getResources().getDimensionPixelSize(R.dimen.text_appearance_span),colorStateList,colorStateList),0,5,Spannable.SPAN_INCLUSIVE_INCLUSIVE);

    5.TabStopSpan.Standard

    功能:每行的MarginLeft的偏移量(跟 \t 和 \n 有关系)。

    String  str="科技生活, 人文娱乐, 科技创新";

    String[]  subs = str.split(" ");

    SpannableStringBuilder   spannableStringBuilder =new  SpannableStringBuilder();

    /**

    * TabStopSpan. Standard related to \t and \n

    * TabStopSpan.Standard 跟 \t 和 \n 有关系

    */

    for(Stringsub1 : subs) {

    spannableStringBuilder.append("\t").append(sub1).append(" ");

    spannableStringBuilder.append("\n");

    }

    spannableStringBuilder.setSpan(new TabStopSpan.Standard(126),0,spannableStringBuilder.length(),Spannable.SPAN_INCLUSIVE_INCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    6.SuperscriptSpan

    功能:文字设置为上标,数学公式中用到。

    String  str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder spannableStringBuilder =new SpannableStringBuilder(str);

    Parcel parcel = Parcel.obtain();

    parcel.writeInt(1);

    spannableStringBuilder.setSpan(new  SuperscriptSpan(parcel),1,2,Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    7.SubscriptSpan

    功能:文字设置为下标,化学式中用到。

    String   str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder spannableStringBuilder =new  SpannableStringBuilder(str);

    Parcel  parcel = Parcel.obtain();

    parcel.writeInt(1);

    spannableStringBuilder.setSpan(new SubscriptSpan(parcel),1,2,Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    8.StrikethroughSpan

    功能:文字设置删除线。

    String  str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder spannableStringBuilder =new  SpannableStringBuilder(str);

    spannableStringBuilder.setSpan(new  StrikethroughSpan(),0,5,Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    9.ScaleXSpan

    功能:文字横向缩放。

    String  str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder  spannableStringBuilder =new  SpannableStringBuilder(str);

    spannableStringBuilder.setSpan(new  ScaleXSpan(2.0f),0,5,Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    10.StyleSpan

    功能:文字设置样式(正常、粗体、斜体、粗斜体)。

    String  str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder  spannableStringBuilder =new  SpannableStringBuilder(str);

    spannableStringBuilder.setSpan(new  StyleSpan(Typeface.BOLD_ITALIC),0,5,Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    11.RelativeSizeSpan

    功能:设置文字相对大小,指相对于文本设定的大小的相对比例。

    String  str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder  spannableStringBuilder =new  SpannableStringBuilder(str);

    spannableStringBuilder.setSpan(new RelativeSizeSpan(3f),0,5,Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    12.QuoteSpan

    功能:设置文字左侧显示引用样式(一条竖线)。

    String  str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder  spannableStringBuilder =new  SpannableStringBuilder(str);

    spannableStringBuilder.setSpan(new QuoteSpan(0xffff5566),0,5,Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    13.MaskFilterSpan

    功能:设置文字模糊效果和浮雕效果。

    String  str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder  spannableStringBuilder =new  SpannableStringBuilder(str);

    spannableStringBuilder.setSpan(new MaskFilterSpan(newBlurMaskFilter(3,BlurMaskFilter.Blur.OUTER)),0,5,Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    14.LeadingMarginSpan.Standard

    功能:设置文本缩进。

    LeadingMarginSpan.Standard(int first, int rest)

    first:首行的 margin left 偏移量。

    rest:其他行的 margin left 偏移量。

    String  str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder  spannableStringBuilder =new  SpannableStringBuilder(str);

    spannableStringBuilder.append(spannableStringBuilder.toString());

    spannableStringBuilder.setSpan(new LeadingMarginSpan.Standard(100,0),0,spannableStringBuilder.length(),Spannable.SPAN_INCLUSIVE_INCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    15.ImageSpan

    功能:文本插入图片。

    String  str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder  spannableStringBuilder =new  SpannableStringBuilder(str);

    spannableStringBuilder.setSpan(new ImageSpan(this,R.mipmap.ic_launcher,ImageSpan.ALIGN_BASELINE),0,5,Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    16.IconMarginSpan

    功能:文本插入图片+Margin。

    String  str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder  spannableStringBuilder =new  SpannableStringBuilder(str);

    Bitmapbitmap = BitmapFactory.decodeResource(getResources(),R.mipmap.ic_launcher);

    spannableStringBuilder.setSpan(new IconMarginSpan(bitmap,60),0,5,Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    17.ForegroundColorSpan

    功能:设置文字颜色。

    String  str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder  spannableStringBuilder =new  SpannableStringBuilder(str);

    spannableStringBuilder.setSpan(new ForegroundColorSpan(0xffff5566),0,5,Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    18.DrawableMarginSpan

    功能:文本插入图片+Margin。

    String  str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder  spannableStringBuilder =new  SpannableStringBuilder(str);

    spannableStringBuilder.setSpan(new DrawableMarginSpan(getResources().getDrawable(R.mipmap.ic_launcher),6),0,5,Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    19.BulletSpan

    功能:类似于HTML中的圆点效果。

    String  str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder  spannableStringBuilder =new  SpannableStringBuilder(str);

    spannableStringBuilder.setSpan(new BulletSpan(66,0xffff5566),0,5,Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    20.BackgroundColorSpan

    功能:设置背景色。

    String  str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder  spannableStringBuilder =new  SpannableStringBuilder(str);

    spannableStringBuilder.setSpan(new BackgroundColorSpan(0xffff5566),0,5,Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    21.AlignmentSpan.Standard

    功能:设置文字对齐方式。

    String  str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder  spannableStringBuilder =new  SpannableStringBuilder(str);

    spannableStringBuilder.setSpan(new AlignmentSpan.Standard(Layout.Alignment.ALIGN_CENTER),0,5,Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    22.AbsoluteSizeSpan

    功能:设置文字绝对大小。

    String  str="科技生活,人文娱乐,科技创新";

    SpannableStringBuilder  spannableStringBuilder =new  SpannableStringBuilder(str);

    spannableStringBuilder.setSpan(new AbsoluteSizeSpan(26,true),0,5,Spannable.SPAN_INCLUSIVE_EXCLUSIVE);

    tv_content.setText(spannableStringBuilder);

    23.ClickableSpan

    功能:文字可点击。抽象类,需要自己去实现。

    这23种Span讲完了,这23种可以组合使用哦。

    相关文章

      网友评论

          本文标题:Spannable丰富Android文本

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