android SpannableString使用详解

标签:androidlayoutbuttonimageencodingurl 15308人阅读 评论(3) 收藏 举报 分类: Android(25) [java] view plain copy
  1. importandroid.app.Activity;
  2. importandroid.graphics.Color;
  3. importandroid.graphics.Typeface;
  4. importandroid.graphics.drawable.Drawable;
  5. importandroid.os.Bundle;
  6. importandroid.text.Spannable;
  7. importandroid.text.SpannableString;
  8. importandroid.text.style.AbsoluteSizeSpan;
  9. importandroid.text.style.BackgroundColorSpan;
  10. importandroid.text.style.ForegroundColorSpan;
  11. importandroid.text.style.ImageSpan;
  12. importandroid.text.style.StrikethroughSpan;
  13. importandroid.text.style.StyleSpan;
  14. importandroid.text.style.URLSpan;
  15. importandroid.text.style.UnderlineSpan;
  16. importandroid.view.View;
  17. importandroid.view.View.OnClickListener;
  18. importandroid.widget.Button;
  19. importandroid.widget.EditText;
  20. publicclassSpannableStringActivityextendsActivityimplements
  21. OnClickListener{
  22. privateEditTexttv;
  23. privateButtonunderline_btn;
  24. privateButtonstrike_btn;
  25. privateButtonstyle_btn;
  26. privateButtonfont_btn;
  27. privateButtoncolor_btn1;
  28. privateButtoncolor_btn2;
  29. privateButtonurl_btn;
  30. privateButtonimage_btn;
  31. /**Calledwhentheactivityisfirstcreated.*/
  32. @Override
  33. publicvoidonCreate(BundlesavedInstanceState){
  34. super.onCreate(savedInstanceState);
  35. setContentView(R.layout.main);
  36. tv=(EditText)this.findViewById(R.id.tv);
  37. underline_btn=(Button)this.findViewById(R.id.underline_btn);
  38. strike_btn=(Button)this.findViewById(R.id.strike_btn);
  39. style_btn=(Button)this.findViewById(R.id.style_btn);
  40. font_btn=(Button)this.findViewById(R.id.font_btn);
  41. color_btn1=(Button)this.findViewById(R.id.color_btn1);
  42. color_btn2=(Button)this.findViewById(R.id.color_btn2);
  43. url_btn=(Button)this.findViewById(R.id.url_btn);
  44. image_btn=(Button)this.findViewById(R.id.image_btn);
  45. underline_btn.setOnClickListener(this);
  46. strike_btn.setOnClickListener(this);
  47. style_btn.setOnClickListener(this);
  48. font_btn.setOnClickListener(this);
  49. color_btn1.setOnClickListener(this);
  50. color_btn2.setOnClickListener(this);
  51. url_btn.setOnClickListener(this);
  52. image_btn.setOnClickListener(this);
  53. }
  54. @Override
  55. publicvoidonClick(Viewv){
  56. switch(v.getId()){
  57. caseR.id.underline_btn:
  58. addUnderLineSpan();
  59. break;
  60. caseR.id.strike_btn:
  61. addStrikeSpan();
  62. break;
  63. caseR.id.style_btn:
  64. addStyleSpan();
  65. break;
  66. caseR.id.font_btn:
  67. addFontSpan();
  68. break;
  69. caseR.id.color_btn1:
  70. addForeColorSpan();
  71. break;
  72. caseR.id.color_btn2:
  73. addBackColorSpan();
  74. break;
  75. caseR.id.url_btn:
  76. addUrlSpan();
  77. break;
  78. caseR.id.image_btn:
  79. addImageSpan();
  80. break;
  81. <SPANstyle="WHITE-SPACE:pre"></SPAN>}
  82. }
  83. /**
  84. *超链接
  85. */
  86. privatevoidaddUrlSpan(){
  87. SpannableStringspanString=newSpannableString("超链接");
  88. URLSpanspan=newURLSpan("tel:0123456789");
  89. spanString.setSpan(span,0,3,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
  90. tv.append(spanString);
  91. }
  92. /**
  93. *文字背景颜色
  94. */
  95. privatevoidaddBackColorSpan(){
  96. SpannableStringspanString=newSpannableString("颜色2");
  97. BackgroundColorSpanspan=newBackgroundColorSpan(Color.YELLOW);
  98. spanString.setSpan(span,0,3,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
  99. tv.append(spanString);
  100. }
  101. /**
  102. *文字颜色
  103. */
  104. privatevoidaddForeColorSpan(){
  105. SpannableStringspanString=newSpannableString("颜色1");
  106. ForegroundColorSpanspan=newForegroundColorSpan(Color.BLUE);
  107. spanString.setSpan(span,0,3,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
  108. tv.append(spanString);
  109. }
  110. /**
  111. *字体大小
  112. */
  113. privatevoidaddFontSpan(){
  114. SpannableStringspanString=newSpannableString("36号字体");
  115. AbsoluteSizeSpanspan=newAbsoluteSizeSpan(36);
  116. spanString.setSpan(span,0,5,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
  117. tv.append(spanString);
  118. }
  119. /**
  120. *粗体,斜体
  121. */
  122. privatevoidaddStyleSpan(){
  123. SpannableStringspanString=newSpannableString("BIBI");
  124. StyleSpanspan=newStyleSpan(Typeface.BOLD_ITALIC);
  125. spanString.setSpan(span,0,2,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
  126. tv.append(spanString);
  127. }
  128. /**
  129. *删除线
  130. */
  131. privatevoidaddStrikeSpan(){
  132. SpannableStringspanString=newSpannableString("删除线");
  133. StrikethroughSpanspan=newStrikethroughSpan();
  134. spanString.setSpan(span,0,3,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
  135. tv.append(spanString);
  136. }
  137. /**
  138. *下划线
  139. */
  140. privatevoidaddUnderLineSpan(){
  141. SpannableStringspanString=newSpannableString("下划线");
  142. UnderlineSpanspan=newUnderlineSpan();
  143. spanString.setSpan(span,0,3,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
  144. tv.append(spanString);
  145. }
  146. /**
  147. *图片
  148. */
  149. privatevoidaddImageSpan(){
  150. SpannableStringspanString=newSpannableString("");
  151. Drawabled=getResources().getDrawable(R.drawable.ic_launcher);
  152. d.setBounds(0,0,d.getIntrinsicWidth(),d.getIntrinsicHeight());
  153. ImageSpanspan=newImageSpan(d,ImageSpan.ALIGN_BASELINE);
  154. spanString.setSpan(span,0,1,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
  155. tv.append(spanString);
  156. }
  157. }

xml布局文件

[html] view plain copy
  1. <?xmlversion="1.0"encoding="utf-8"?>
  2. <LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="fill_parent"
  4. android:layout_height="fill_parent"
  5. android:background="#ff333333"
  6. android:orientation="vertical">
  7. <EditText
  8. android:id="@+id/tv"
  9. android:layout_width="wrap_content"
  10. android:layout_height="wrap_content"
  11. android:singleLine="false"
  12. android:inputType="none"/>
  13. <GridLayout
  14. android:layout_width="wrap_content"
  15. android:layout_height="wrap_content"
  16. android:columnCount="4">
  17. <Button
  18. android:id="@+id/image_btn"
  19. android:layout_width="wrap_content"
  20. android:layout_height="wrap_content"
  21. android:text="@string/image"/>
  22. <Button
  23. android:id="@+id/url_btn"
  24. android:layout_width="wrap_content"
  25. android:layout_height="wrap_content"
  26. android:text="@string/url"/>
  27. <Button
  28. android:id="@+id/color_btn1"
  29. android:layout_width="wrap_content"
  30. android:layout_height="wrap_content"
  31. android:text="@string/color1"/>
  32. <Button
  33. android:id="@+id/color_btn2"
  34. android:layout_width="wrap_content"
  35. android:layout_height="wrap_content"
  36. android:text="@string/color2"/>
  37. <Button
  38. android:id="@+id/font_btn"
  39. android:layout_width="wrap_content"
  40. android:layout_height="wrap_content"
  41. android:text="@string/font"/>
  42. <Button
  43. android:id="@+id/style_btn"
  44. android:layout_width="wrap_content"
  45. android:layout_height="wrap_content"
  46. android:text="@string/style"/>
  47. <Button
  48. android:id="@+id/strike_btn"
  49. android:layout_width="wrap_content"
  50. android:layout_height="wrap_content"
  51. android:text="@string/strike"/>
  52. <Button
  53. android:id="@+id/underline_btn"
  54. android:layout_width="wrap_content"
  55. android:layout_height="wrap_content"
  56. android:text="@string/underline"/>
  57. </GridLayout>
  58. </LinearLayout>


SpannableString属性详解

1、BackgroundColorSpan 背景色
2、ClickableSpan 文本可点击,有点击事件

3、ForegroundColorSpan 文本颜色(前景色)
4、MaskFilterSpan 修饰效果,如模糊(BlurMaskFilter)、浮雕(EmbossMaskFilter)
5、MetricAffectingSpan 父类,一般不用
6、RasterizerSpan 光栅效果
7、StrikethroughSpan 删除线(中划线)
8、SuggestionSpan 相当于占位符
9、UnderlineSpan 下划线
10、AbsoluteSizeSpan 绝对大小(文本字体)
11、DynamicDrawableSpan 设置图片,基于文本基线或底部对齐。
12、ImageSpan 图片
13、RelativeSizeSpan 相对大小(文本字体)
14、ReplacementSpan 父类,一般不用
15、ScaleXSpan 基于x轴缩放
16、StyleSpan 字体样式:粗体、斜体等
17、SubscriptSpan 下标(数学公式会用到)
18、SuperscriptSpan 上标(数学公式会用到)
19、TextAppearanceSpan 文本外貌(包括字体、大小、样式和颜色)
20、TypefaceSpan 文本字体

21、URLSpan 文本超链接



BackgroundColorSpan背景色
SpannableString spanText = new SpannableString("benzlocke");
spanText.setSpan(new BackgroundColorSpan(Color.GREEN), 0, spanText.length(),
Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
mTVText.append("\n");
mTVText.append(spanText);


ForegroundColorSpan文本颜色(前景色)
spanText = new SpannableString("benzlocke");
spanText.setSpan(new ForegroundColorSpan(Color.BLUE), 6, spanText.length(),
Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
mTVText.append("\n");
mTVText.append(spanText);


MaskFilterSpan修饰效果,如模糊(BlurMaskFilter)、浮雕(EmbossMaskFilter)
spanText = new SpannableString("benzlocke");
int length = spanText.length();
//模糊(BlurMaskFilter)
MaskFilterSpan maskFilterSpan = new MaskFilterSpan(new BlurMaskFilter(3, Blur.OUTER));
spanText.setSpan(maskFilterSpan, 0, length - 10, Spannable.
SPAN_INCLUSIVE_EXCLUSIVE);
//浮雕(EmbossMaskFilter)
maskFilterSpan = new MaskFilterSpan(new EmbossMaskFilter(new float[]{1,1,3}, 1.5f, 8, 3));
spanText.setSpan(maskFilterSpan, length - 10, length, Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
mTVText.append("\n");
mTVText.append(spanText);

RasterizerSpan光栅效果
spanText = new SpannableString("StrikethroughSpan");
spanText.setSpan(new StrikethroughSpan(), 0, 7, Spannable.
SPAN_INCLUSIVE_EXCLUSIVE);
mTVText.append("\n");
mTVText.append(spanText);

StrikethroughSpan删除线
spanText = new SpannableString("StrikethroughSpan");
spanText.setSpan(new StrikethroughSpan(), 0, 7, Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
mTVText.append("\n");
mTVText.append(spanText);

SuggestionSpan
相当于占位符,一般用在EditText输入框中。当双击此文本时,会弹出提示框选择一些建议(推荐的)文字,选中的文本将替换此占位符。在输入法上用的较多。

UnderlineSpan下划线
spanText = new SpannableString("UnderlineSpan");
spanText.setSpan(new UnderlineSpan(), 0, spanText.length(),
Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
mTVText.append("\n");
mTVText.append(spanText);

AbsoluteSizeSpan绝对大小(文本字体)
spanText = new SpannableString("AbsoluteSizeSpan");
spanText.setSpan(new AbsoluteSizeSpan(20, true), 0, spanText.length(),
Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
mTVText.append("\n");
mTVText.append(spanText);

DynamicDrawableSpan设置图片,基于文本基线或底部对齐。
DynamicDrawableSpan drawableSpan = new DynamicDrawableSpan(DynamicDrawableSpan.ALIGN_BASELINE) {
@Override
public Drawable getDrawable() {
Drawable d = getResources().getDrawable(R.drawable.ic_launcher);
d.setBounds(0, 0, 50, 50);
return d;
}
};
DynamicDrawableSpan drawableSpan2 = new DynamicDrawableSpan(
DynamicDrawableSpan.ALIGN_BOTTOM) {
@Override
public Drawable getDrawable() {
Drawable d = getResources().getDrawable(R.drawable.ic_launcher);
d.setBounds(0, 0, 50, 50);
return d;
}
};
spanText.setSpan(drawableSpan, 3, 4, Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
spanText.setSpan(drawableSpan2, 7, 8, Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
mTVText.append("\n");
mTVText.append(spanText);
//左边图片基于基线对齐,右边图片基于底部对齐

ImageSpan图片
spanText = new SpannableString("ImageSpan");
Drawable d = getResources().getDrawable(R.drawable.ic_launcher);
d.setBounds(0, 0, 50, 50);
spanText.setSpan(new ImageSpan(d), 3, 4, Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
mTVText.append("\n");
mTVText.append(spanText);
//和DynamicDrawableSpan差别不大

RelativeSizeSpan相对大小(文本字体)
spanText = new SpannableString("RelativeSizeSpan");
//参数proportion:比例大小
spanText.setSpan(new RelativeSizeSpan(2.5f), 3, 4,
Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
mTVText.append("\n");
mTVText.append(spanText);
//相对大小的比例是基于当前文本字体大小

ScaleXSpan基于x轴缩放
spanText = new SpannableString("benzlocke");
//参数proportion:比例大小
spanText.setSpan(new ScaleXSpan(3.8f), 3, 7, Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
mTVText.append("\n");
mTVText.append(spanText);

StyleSpan字体样式:粗体、斜体等
spanText = new SpannableString("benzlocke");
//Typeface.BOLD_ITALIC:粗体+斜体
spanText.setSpan(new StyleSpan(Typeface.BOLD_ITALIC), 3, 7,
Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
mTVText.append("\n");
mTVText.append(spanText);

SubscriptSpan下标(数学公式会用到)
spanText = new SpannableString("benzlocke");
spanText.setSpan(new SubscriptSpan(), 6, 7, Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
mTVText.append("\n");
mTVText.append(spanText);

SuperscriptSpan上标(数学公式会用到)
spanText = new SpannableString("benzlocke");
spanText.setSpan(new SuperscriptSpan(), 6, 7, Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
mTVText.append("\n");
mTVText.append(spanText);

TextAppearanceSpan文本外貌(包括字体、大小、样式和颜色)
spanText = new SpannableString("benzlocke");
//若需自定义TextAppearance,可以在系统样式上进行修改
spanText.setSpan(new TextAppearanceSpan(this, android.R.style.TextAppearance_Medium), 6, 7, Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
mTVText.append("\n");
mTVText.append(spanText);
//系统还提供了相关值TextAppearance_Small, TextAppearance_Large等。如有需要可在以上样式基础上修改。

TypefaceSpan文本字体
spanText = new SpannableString("benzlocke");
//若需使用自定义字体,可能要重写类TypefaceSpan
spanText.setSpan(new TypefaceSpan("monospace"), 3, 10,
Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
mTVText.append("\n");
mTVText.append(spanText);
//关于自定义字体的设置,后面将介绍如何使用

URLSpan文本超链接
spanText = new SpannableString("benzlocke");
spanText.setSpan(new URLSpan("http://orgcent.com"), 10, spanText.length(),
Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
mTVText.append("\n");
mTVText.append(spanText);
//让URLSpan可以点击
mTVText.setMovementMethod(new LinkMovementMethod());


更多相关文章

  1. android SpannableString使用详解
  2. Android设置文本框单行多行显示
  3. android颜色对应的xml配置值
  4. android 自定义表盘控件
  5. Android(安卓)内存管理工具
  6. Android一些常用的颜色值
  7. android TextView 改变颜色
  8. Android(安卓)Glide RadiusTransform
  9. android 常用颜色对照表

随机推荐

  1. Android 动态设置全屏,退出全屏
  2. android.os.NetworkOnMainThreadExceptio
  3. Android(安卓)Camera2 Opengles2.0 图像
  4. PopupWindow与PopupMenu的用法
  5. Android开源项目发现--- 工具类依赖注入D
  6. android 8.0 wifi-host ap 开关操作
  7. MUI调用自定义插件(Android)
  8. Android kotlin高级特性
  9. android 模拟按键单值/多值输入
  10. android edittxet 设置可点击不可编辑状