TextView特殊的使用方法(炫酷)

参考:

1、为TextView添加链接-setMovementMethod -- Android学习笔记6-3   

2、TextView特殊的使用方法     


为TextView添加链接-setMovementMethod

一、前言:


    本文是由《TextView中的图文共存问题》延伸出来的知识点讲解;原文地址:《TextView中的图文共存问题》


二、为TextView设置链接:

  当文字中出现URL、E-mail、电话号码等的时候,我们为TextView设置链接。总结起来,一共有4种方法来为TextView实现链接。我们一一举例介绍;

  1. 在xml里添加android:autoLink属性。
     android:autoLink :的可选值:none/web/email/phone/map/all,分别代表将当前文本设置为:
普通文本/URL/email/电话号码/map/自动识别,文本显示为可点击的链接。其中:设置为all时,系统会自动根据你的文本格式识别文本类型,如:http为web,tel为电话等;当然,以上内容也可以在Java代码中完成,用法为tv.setAutoLinkMask(Linkify.ALL)。
 
  2. 将显示内容写到资源文件,一般为String.xml中,并且用<a>标签来声明链接,然后激活这个链接,激活链接需要在Java代码中使用setMovementMethod()方法设置TextView为可点击。
 
  3. 用Html类的fromHtml()方法格式化要放到TextView里的文字。然后激活这个链接,激活链接需要在Java代码中使用setMovementMethod()方法设置TextView为可点击。
 
  4. 用Spannable或实现它的类,如SpannableString。与其他方法不同的是,Spannable对象可以为个别字符设置链接(当然也可以为个别字符设置颜色、字体等,实现某些字符高亮显示的效果等)。这个方法同样需要在Java代码中使用setMovementMethod()方法设置TextView为可点击。

 
三、例:
    

对于以上内容,我在一个Activity来分别演示:

1.新建set_m_m.xml,这是一个Layout,代码如下:

[html]  view plain  copy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:layout_width="match_parent"  
  4.     android:layout_height="match_parent"  
  5.     android:orientation="vertical">  
  6.   
  7.     <!--用autoLink="none"设置普通文本-->  
  8.     <TextView  
  9.         android:id="@+id/mm_tv1_1"  
  10.         android:layout_width="wrap_content"  
  11.         android:layout_height="wrap_content"  
  12.         android:layout_margin="5dp"  
  13.         android:autoLink="none"/>  
  14.   
  15.     <!--用autoLink="phone"设置电话-->  
  16.     <TextView  
  17.         android:id="@+id/mm_tv1_2"  
  18.         android:layout_width="wrap_content"  
  19.         android:layout_height="wrap_content"  
  20.         android:layout_margin="5dp"  
  21.         android:autoLink="phone"/>  
  22.   
  23.     <!--用autoLink="all"自动识别-->  
  24.     <TextView  
  25.         android:id="@+id/mm_tv1_3"  
  26.         android:layout_width="wrap_content"  
  27.         android:layout_height="wrap_content"  
  28.         android:layout_margin="5dp"  
  29.         android:autoLink="all"/>  
  30.   
  31.     <!--将显示内容写到String.xml中-->  
  32.     <TextView  
  33.         android:id="@+id/mm_tv2"  
  34.         android:layout_width="wrap_content"  
  35.         android:layout_height="wrap_content"  
  36.         android:layout_margin="5dp"  
  37.         android:text="@string/link_string"/>  
  38.   
  39.     <!--用Html类的fromHtml()方法-->  
  40.     <TextView  
  41.         android:id="@+id/mm_tv3"  
  42.         android:layout_width="wrap_content"  
  43.         android:layout_height="wrap_content"  
  44.         android:layout_margin="5dp"/>  
  45.   
  46.     <!--用Spannable或实现它的类-->  
  47.     <TextView  
  48.         android:id="@+id/mm_tv4"  
  49.         android:layout_width="wrap_content"  
  50.         android:layout_height="wrap_content"  
  51.         android:layout_margin="5dp"/>  
  52.   
  53. </LinearLayout>  

2.新建SetMMActivty.java,这是一个活动,代码如下:

[java]  view plain  copy
  1. package cpj.com.UI_TextView;  
  2.   
  3. import android.os.Bundle;  
  4. import android.text.Html;  
  5. import android.text.SpannableString;  
  6. import android.text.Spanned;  
  7. import android.text.method.LinkMovementMethod;  
  8. import android.text.style.URLSpan;  
  9. import android.widget.TextView;  
  10.   
  11. import cpj.com.MyTool.BaseActivity;  
  12. import cpj.com.cpjtest.R;  
  13.   
  14. /** 
  15.  * Created by cpj on 2016/4/27. 
  16.  */  
  17. public class SetMMActivity extends BaseActivity{  
  18.   
  19.     @Override  
  20.     protected void onCreate(Bundle savedInstanceState) {  
  21.         super.onCreate(savedInstanceState);  
  22.         setContentView(R.layout.set_m_m);  
  23.   
  24.         //(方法一)用autoLink="none"设置普通文本  
  25.         TextView web_tv = (TextView) findViewById(R.id.mm_tv1_1);  
  26.           web_tv.setText("(1_1)百度:https://www.baidu.com/");  
  27.   
  28.         //(方法一)用autoLink="phone"设置电话  
  29.         TextView phone_tv = (TextView) findViewById(R.id.mm_tv1_2);  
  30.           phone_tv.setText("(1_2)电话:15800000000");  
  31.   
  32.         //(方法一)用autoLink="all"自动识别  
  33.         TextView all_tv = (TextView) findViewById(R.id.mm_tv1_3);  
  34.           all_tv.setText("(1_3)百度:https://www.baidu.com/");  
  35.   
  36.         //(方法二)将显示内容写到String.xml中  
  37.         TextView string_tv = (TextView) findViewById(R.id.mm_tv2);  
  38.           string_tv.setMovementMethod(LinkMovementMethod.getInstance());//激活链接  
  39.   
  40.         //(方法三)用Html类的fromHtml()方法  
  41.         TextView html_tv = (TextView) findViewById(R.id.mm_tv3);  
  42.           html_tv.setText(  
  43.                 Html.fromHtml(  
  44.                         "(3)百度:" + "<a href='http://www.baidu.com'>链接到百度</a> ")  
  45.           );  
  46.           html_tv.setMovementMethod(LinkMovementMethod.getInstance());//激活链接  
  47.   
  48.         //(方法四)用Spannable或实现它的类  
  49.         TextView spannable_tv = (TextView) findViewById(R.id.mm_tv4);  
  50.         SpannableString ss = new SpannableString("(4)百度: 点我就可以访问百度首页");  
  51.           ss.setSpan(new URLSpan("http://www.baidu.com"), 718,  
  52.                 Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);//设置4~18为网站链接  
  53.         spannable_tv.setText(ss);  
  54.         spannable_tv.setMovementMethod(LinkMovementMethod.getInstance());//激活链接  
  55.     }  
  56. }  

3.用到的String.xml资源,代码如下:

[html]  view plain  copy
  1. <string name="link_string">  
  2.     (2)百度:<a href="http://www.baidu.com">点我进入百度首页!</a>  
  3. </string>  

最终的执行结果,如下图:



四、我的项目:

//TextView中指定一段文字设置监听、颜色、去下划线
        SpannableString spanStr = new SpannableString(tvBalanceZero.getText().toString());
        //跳转到拨号界面
        spanStr.setSpan(new URLSpan("tel:133××××6666"), spanStr.length() - 18, spanStr.length() - 7, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
        //去除特殊文字下划线效果
        NoUnderlineSpan mNoUnderlineSpan = new NoUnderlineSpan();
        spanStr.setSpan(mNoUnderlineSpan, spanStr.length() - 18, spanStr.length() - 7, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
        //设置颜色
        spanStr.setSpan(new ForegroundColorSpan(Color.parseColor("#ff3b30")), spanStr.length() - 18, spanStr.length() - 7, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
        tvBalanceZero.setText(spanStr);
        tvBalanceZero.setMovementMethod(LinkMovementMethod.getInstance());


//实现清除文字下划线:
public class NoUnderlineSpan extends UnderlineSpan {

    @Override
    public void updateDrawState(TextPaint ds) {
        ds.setColor(ds.linkColor);
        ds.setUnderlineText(false);
    }
}

五、效果:

请给我打电话 133××××6666 哈哈哈哈哈



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值