昨晚研读 ApiDemo 源码至 com.example.android.apis.text.Link 类。首先,看一下其运行效果: 
 
要给 TextView 加上效果,方式主要有几种:

第一种,自动应用效果,使用 android:autolink 属性,如:

  1. <TextView xmlns:android="http://schemas.android.com/apk/res/android"
  2. android:id="@+id/text1"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. android:autoLink="all"
  6. android:text="@string/link_text_auto"
  7. />

第二种,在文本中使用 <a> 标签,如:

  1. <string name="link_text_manual"><b>text2:</b> This is some other
  2. text, with a <a href="http://www.google.com">link</a> specified
  3. via an &lt;a&gt; tag.  Use a \"tel:\" URL
  4. to <a href="tel:4155551212">dial a phone number</a>
  5. </string>

第三种,和第二种其实是一样的,只不过将文本改在 JAVA 代码中,如:

  1. TextView t3 = (TextView) findViewById(R.id.text3);
  2. t3.setText(
  3. Html.fromHtml(
  4. "<b>text3:</b>  Text with a " +
  5. "<a href=\"http://www.google.com\">link</a> " +
  6. "created in the Java source code using HTML."));
  7. t3.setMovementMethod(LinkMovementMethod.getInstance());

第四种,前面三种可以说都是自动的,而第四种就是纯“手工”的了。通过创建 SpanableString 字符串,并在之上创 建一个或多个 Span 来实现丰富的效果。例子如下:

  1. SpannableString ss = new SpannableString("text4: Click here to dial the phone.");
  2. ss.setSpan(new StyleSpan(Typeface.BOLD), 0, 6,Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
  3. ss.setSpan(new URLSpan("tel:4155551212"), 13, 17,Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
  4. TextView t4 = (TextView) findViewById(R.id.text4);
  5. t4.setText(ss);
  6. t4.setMovementMethod(LinkMovementMethod.getInstance());

完整的代码见 ApiDemo 吧,下面我提几点需要注意的:

.setMovementMethod,此方法在需要响应用户事件时使用,如点击一个电话号码就跳转到拨号页面。如果不执行这个方法是不会响应事件的,即便文本看着已经是下划线蓝色字了。 
.Spanned.SPAN_EXCLUSIVE_EXCLUSIVE,这是在 setSpan 时需要指定的 flag,它的意义我试了很久也没试出来,睡个觉,今天早上才突然有点想法,试之,果然。它是用来标识在 Span 范围内的文本前后输入新的字符时是否把它们也应用这个效果。分别有 Spanned.SPAN_EXCLUSIVE_EXCLUSIVE(前后都不包括)、Spanned.SPAN_INCLUSIVE_EXCLUSIVE(前面包括,后面不包括)、Spanned.SPAN_EXCLUSIVE_INCLUSIVE(前面不包括,后面包括)、Spanned.SPAN_INCLUSIVE_INCLUSIVE(前后都包括)。看个截图就更明白了:

 
对比一下 

以下转自:http://blog.csdn.net/yang_hui1986527/article/details/6776629 
在Android中,TextView是我们最常用的用来显示文本的控件。

一般情况下,TextView中的文本都是一个样式。那么如何对于TextView中各个部分的文本来设置字体,大小,颜色,样式,以及超级链接等属性呢?下面我们通过SpannableString的具体实例操作来演示一下。

res-layout-main.xml:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_height="wrap_content" android:layout_width="wrap_content" android:orientation="horizontal">
  4. <TextView
  5. android:id="@+id/myTextView"
  6. android:layout_width="fill_parent"
  7. android:layout_height="wrap_content"
  8. />
  9. </LinearLayout>

res-color-color.xml

res-color-linkcolor.xml:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <selector  xmlns:android="http://schemas.android.com/apk/res/android">
  3. <item android:state_pressed="true"
  4. android:color="#ffffff00"/> <!-- pressed -->
  5. <item android:state_focused="true"
  6. android:color="#ff00ffff"/> <!-- focused -->
  7. <item android:color="#ff0ff000"/> <!-- default -->
  8. </selector>

TextViewLinkActivity:

  1. import java.io.IOException;
  2. import org.xmlpull.v1.XmlPullParserException;
  3. import android.app.Activity;
  4. import android.content.res.ColorStateList;
  5. import android.content.res.XmlResourceParser;
  6. import android.graphics.Bitmap;
  7. import android.graphics.BitmapFactory;
  8. import android.graphics.Color;
  9. import android.graphics.drawable.Drawable;
  10. import android.os.Bundle;
  11. import android.text.SpannableString;
  12. import android.text.Spanned;
  13. import android.text.method.LinkMovementMethod;
  14. import android.text.style.AbsoluteSizeSpan;
  15. import android.text.style.BackgroundColorSpan;
  16. import android.text.style.BulletSpan;
  17. import android.text.style.DrawableMarginSpan;
  18. import android.text.style.ForegroundColorSpan;
  19. import android.text.style.IconMarginSpan;
  20. import android.text.style.ImageSpan;
  21. import android.text.style.RelativeSizeSpan;
  22. import android.text.style.ScaleXSpan;
  23. import android.text.style.StrikethroughSpan;
  24. import android.text.style.StyleSpan;
  25. import android.text.style.SubscriptSpan;
  26. import android.text.style.SuperscriptSpan;
  27. import android.text.style.TextAppearanceSpan;
  28. import android.text.style.TypefaceSpan;
  29. import android.text.style.URLSpan;
  30. import android.text.style.UnderlineSpan;
  31. import android.widget.TextView;
  32. public class TextViewLinkActivity extends Activity {
  33. TextView mTextView = null;
  34. SpannableString msp = null;
  35. /** Called when the activity is first created. */
  36. @Override
  37. public void onCreate(Bundle savedInstanceState) {
  38. super.onCreate(savedInstanceState);
  39. setContentView(R.layout.main);
  40. mTextView = (TextView)findViewById(R.id.myTextView);
  41. //创建一个 SpannableString对象
  42. msp = new SpannableString("字体测试字体大小一半两倍前景色背景色正常粗体斜体粗斜体下划线删除线x1x2电话邮件网站短信彩信地图X轴综合/bot");
  43. //设置字体(default,default-bold,monospace,serif,sans-serif)
  44. msp.setSpan(new TypefaceSpan("monospace"), 0, 2, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
  45. msp.setSpan(new TypefaceSpan("serif"), 2, 4, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
  46. //设置字体大小(绝对值,单位:像素)
  47. msp.setSpan(new AbsoluteSizeSpan(20), 4, 6, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
  48. msp.setSpan(new AbsoluteSizeSpan(20,true), 6, 8, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //第二个参数boolean dip,如果为true,表示前面的字体大小单位为dip,否则为像素,同上。
  49. //设置字体大小(相对值,单位:像素) 参数表示为默认字体大小的多少倍
  50. msp.setSpan(new RelativeSizeSpan(0.5f), 8, 10, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //0.5f表示默认字体大小的一半
  51. msp.setSpan(new RelativeSizeSpan(2.0f), 10, 12, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //2.0f表示默认字体大小的两倍
  52. //设置字体前景色
  53. msp.setSpan(new ForegroundColorSpan(Color.MAGENTA), 12, 15, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //设置前景色为洋红色
  54. //设置字体背景色
  55. msp.setSpan(new BackgroundColorSpan(Color.CYAN), 15, 18, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //设置背景色为青色
  56. //设置字体样式正常,粗体,斜体,粗斜体
  57. msp.setSpan(new StyleSpan(android.graphics.Typeface.NORMAL), 18, 20, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //正常
  58. msp.setSpan(new StyleSpan(android.graphics.Typeface.BOLD), 20, 22, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //粗体
  59. msp.setSpan(new StyleSpan(android.graphics.Typeface.ITALIC), 22, 24, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //斜体
  60. msp.setSpan(new StyleSpan(android.graphics.Typeface.BOLD_ITALIC), 24, 27, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //粗斜体
  61. //设置下划线
  62. msp.setSpan(new UnderlineSpan(), 27, 30, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
  63. //设置删除线
  64. msp.setSpan(new StrikethroughSpan(), 30, 33, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
  65. //设置上下标
  66. msp.setSpan(new SubscriptSpan(), 34, 35, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //下标
  67. msp.setSpan(new SuperscriptSpan(), 36, 37, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);   //上标
  68. //超级链接(需要添加setMovementMethod方法附加响应)
  69. msp.setSpan(new URLSpan("tel:4155551212"), 37, 39, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //电话
  70. msp.setSpan(new URLSpan("mailto:webmaster@google.com"), 39, 41, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //邮件
  71. msp.setSpan(new URLSpan("http://www.baidu.com"), 41, 43, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //网络
  72. msp.setSpan(new URLSpan("sms:4155551212"), 43, 45, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //短信   使用sms:或者smsto:
  73. msp.setSpan(new URLSpan("mms:4155551212"), 45, 47, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //彩信   使用mms:或者mmsto:
  74. msp.setSpan(new URLSpan("geo:38.899533,-77.036476"), 47, 49, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //地图
  75. //设置字体大小(相对值,单位:像素) 参数表示为默认字体宽度的多少倍
  76. msp.setSpan(new ScaleXSpan(2.0f), 49, 51, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //2.0f表示默认字体宽度的两倍,即X轴方向放大为默认字体的两倍,而高度不变
  77. //设置字体(依次包括字体名称,字体大小,字体样式,字体颜色,链接颜色)
  78. ColorStateList csllink = null;
  79. ColorStateList csl = null;
  80. XmlResourceParser xppcolor=getResources().getXml (R.color.color);
  81. try {
  82. csl= ColorStateList.createFromXml(getResources(),xppcolor);
  83. }catch(XmlPullParserException e){
  84. // TODO: handle exception
  85. e.printStackTrace();
  86. }catch(IOException e){
  87. // TODO: handle exception
  88. e.printStackTrace();
  89. }
  90. XmlResourceParser xpplinkcolor=getResources().getXml(R.color.linkcolor);
  91. try {
  92. csllink= ColorStateList.createFromXml(getResources(),xpplinkcolor);
  93. }catch(XmlPullParserException e){
  94. // TODO: handle exception
  95. e.printStackTrace();
  96. }catch(IOException e){
  97. // TODO: handle exception
  98. e.printStackTrace();
  99. }
  100. msp.setSpan(new TextAppearanceSpan("monospace",android.graphics.Typeface.BOLD_ITALIC, 30, csl, csllink), 51, 53, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
  101. //设置项目符号
  102. msp.setSpan(new BulletSpan(android.text.style.BulletSpan.STANDARD_GAP_WIDTH,Color.GREEN), 0 ,msp.length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //第一个参数表示项目符号占用的宽度,第二个参数为项目符号的颜色
  103. //设置图片
  104. Drawable drawable = getResources().getDrawable(R.drawable.icon);
  105. drawable.setBounds(0, 0, drawable.getIntrinsicWidth(), drawable.getIntrinsicHeight());
  106. msp.setSpan(new ImageSpan(drawable), 53, 57, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
  107. mTextView.setText(msp);
  108. mTextView.setMovementMethod(LinkMovementMethod.getInstance());
  109. }
  110. }

效果预览:

android中用Spannable在TextView中设置超链接、颜色、字体的更多相关文章

  1. Android Studio 如何在TextView中设置图标并按需调整图标大小

    •任务 相信大家对这张图片都不陌生,没错,就是 QQ动态 向我们展示的界面. 如何实现呢? •添加文字并放入图标 新建一个 Activity,取名为 QQ,Android Studio 自动为我们生成 ...

  2. Android 一个TextView中设置多种不同大小的字体,设置超链接

    以前项目中要是遇到这样的UI设计,都是傻不拉唧的分为三个TextView来实现,今天在微信中无意中看了一篇公众号文章,发现原来只要一个TextView就可以搞定啦,人生最悲哀的事情莫过于工作了这么久啦 ...

  3. ZT Android布局】在程序中设置android:gravity 和 android:layout_Gravity属性

    Android布局]在程序中设置android:gravity 和 android:layout_Gravity属性 分类: [Android基础] 2011-04-19 16:06 54739人阅读 ...

  4. TextView-属性大全(设置超链接颜色)

    今天想要修改一个textview下的超链接的颜色值,自己当时在网上搜了一下,结果看到的全是怎么给一个textview中的部分内容设置颜色.下划线等.当时就以为在textview属性里面可能不存在设定超 ...

  5. IntelliJ IDEA 中设置左菜单字体, 编辑器字体和控制台的字体

    IntelliJ IDEA 中设置左菜单字体大小 File-Settings,然后选择appearance,下图右侧红色边框中的内容即设置菜单的字体和大小 ​ IntelliJ IDEA 中设置当前编 ...

  6. 一起学android之怎样设置TextView中不同字段的字体颜色(22)

    在这里先看看效果图: OK,有时候,在我们的项目中会要求TextView中文本有一部分的字体颜色不一样.这时我们应该使用 SpannableStringBuilder这个工具类,当然这个类的功能非常强 ...

  7. Android开发技巧——去掉TextView中autolink的下划线

    我们知道,在布局文件中设置textview的autolink及其类型,这时textivew上会显示link的颜色,并且文字下面会有一条下划线,表示可以点击.而在我们在点击textview时,应用将根据 ...

  8. 转--Android如何在java代码中设置margin

    ========  3 在Java代码里设置button的margin(外边距)? 1.获取按钮的LayoutParams LinearLayout.LayoutParams layoutParams ...

  9. 用Java在excel单元格中设置超链接

    (一)问题引入 有时候我们在导入数据到excel中时可能要给某个文件或图片设置超链接,例如链接到外网或者是本地的某个目录.我们可以通过Java代码来实现,借助POI库. (二)解决方案 下面直接给出参 ...

随机推荐

  1. Sqlmap注入技巧集锦

    当我们注射的时候,判断注入 http://site/script?id=10 http://site/script?id=11-1 # 相当于 id=10 http://site/script?id= ...

  2. virtual box ubuntu卡在开机光标

    创建虚拟机的时候选择之前保存的虚拟机盘vdi文件,打开的时候卡在光标.原来是因为虚拟机是64位的,但是新建的时候只有32位的ubuntu可以选择就选择的32位. 解决办法: 在bios设置里,打开cp ...

  3. visio studio2008 删除最近的项目

    visio studio2008  删除最近的项目 创建move.bat: @echo off @REG Delete HKCU\Software\Microsoft\VisualStudio\9.0 ...

  4. multipart/form-data请求与文件上传

    要上传文件,需要用post方法,并且设置enctype为multipart/form-data. <form action="/upload" method="po ...

  5. PHP 开发 APP 接口 学习笔记与总结 - Redis 缓存

    Redis 可以定期将数据备份到磁盘中(持久化),同时不仅仅支持简单的key/value 类型的数据,同时还提供list,set,hash等数据结构的存储:Memcache 只是简单的key/valu ...

  6. Xamarin迁移到 Unified API 注意事项

    参考官方文档: Migrating to Unified API for Components #if __UNIFIED__ ... // Mappings Unified CoreGraphic ...

  7. 使用Xpath对XML进行模糊查询

    如果要对XML文件进行模糊查找的话是一个比较麻烦的事情,Xpath表达式中没有像文件系统中的“*”或"?" 或者有像SQL表达式中的"%",这样的模糊查找的通配 ...

  8. jeecg的cq查询方式

    @RequestMapping(params = "datagrid")    public void datagrid(TbStudentDepEntity tbStudentD ...

  9. pro8

    1.本次课学到的知识点 函数程序设计 结构化程序设计思想 程序解析 局部变量和全局变量 2.实验过程中遇到的问题及解决方法 实验过程中会遇到自定义函数的逻辑错误 与缺少定义变量 从主函数开始理清函数关 ...

  10. Bluetooth ATT介绍

    目录 1 介绍 2 详细内容 2.1 Attribute Type 2.2 Attribute Handle 2.3 Attribute Handle Grouping 2.4 Attribute V ...