Android_TextView中部分文字响应事件

tips:本博客Github上的Demo链接:https://github.com/chengbiao1314/android_ViewAttribute.git


之前写过一篇关于Spannable实现同一个TextView显示多风格效果的博客:http://blog.csdn.net/u013035016/article/details/51096646,关于一个Textview分段效果介绍的比较全面,但是内容可能不够精炼,这里单独介绍一下如何实现TextView的部分文字响应事件,以及实现之后如何消除下划线的操作

记得之前介绍过Spannable实现效果一般都是三步:
1、创建Spannable字符串

2、setSpan设置字符串特性

3、setText即可

这里基本是一样的思路,但是添加局部点击事件的时候,setText之后 一定不能忘了加上一行初始化超链接的代码:tv_clickPart.setMovementMethod(LinkMovementMethod.getInstance());

        tv_clickPart = (TextView) findViewById(R.id.tv_clickPart);
        tv_clickPart.setClickable(true);
        tv_clickPart.setText(getClickableSpan());//第一、二步包含在这里
        tv_clickPart.setMovementMethod(LinkMovementMethod.getInstance());//这行代码一定不能忘了
完整代码如下:

布局文件:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:padding="15dp"
    tools:context=".MainActivity"
    android:orientation="vertical">

    <TextView
        android:id="@+id/tv_clickPart"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center_horizontal"/>

</LinearLayout>
代码:
package com.chengbiao.viewattribute;

import android.app.Activity;
import android.graphics.Color;
import android.os.Bundle;
import android.text.Spannable;
import android.text.SpannableString;
import android.text.Spanned;
import android.text.TextPaint;
import android.text.method.LinkMovementMethod;
import android.text.style.ClickableSpan;
import android.text.style.ForegroundColorSpan;
import android.text.style.UnderlineSpan;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.TextView;
import android.widget.Toast;


public class MainActivity extends Activity {
    TextView tv_clickPart;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        testClickPartView();
    }

    private void testClickPartView(){
        tv_clickPart = (TextView) findViewById(R.id.tv_clickPart);
        tv_clickPart.setClickable(true);
        tv_clickPart.setText(getClickableSpan());
        tv_clickPart.setMovementMethod(LinkMovementMethod.getInstance());//不可少
    }

    private SpannableString getClickableSpan() {
//        OnClickListener l = new OnClickListener() {
//            @Override
//            public void onClick(View v) {
//                Toast.makeText(MainActivity.this, "Click Success", Toast.LENGTH_SHORT).show();
//            }
//        };

        SpannableString spanableInfo = new SpannableString("This is a test, Click Me");
        int start = 16;
        int end = spanableInfo.length();

        //这一行是实现局部点击效果,实现Clickable(自定义的继承ClickableSpan implements OnClickListener)
        spanableInfo.setSpan(new Clickable(), start, end, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);

          //这一行是设置文字颜色的
//        spanableInfo.setSpan(new ForegroundColorSpan(Color.RED), start, end, Spannable.SPAN_INCLUSIVE_INCLUSIVE);

        //这一行主要是用来消除点击文字下划线的
        spanableInfo.setSpan(new NoUnderlineSpan(),start, end, Spanned.SPAN_MARK_MARK);

        return spanableInfo;
    }

    class Clickable extends ClickableSpan implements OnClickListener{
//        private final View.OnClickListener mListener;

//        public Clickable(OnClickListener l){
//            mListener = l;
//        }

        @Override
        public void onClick(View v){
//            mListener.onClick(v);
            tv_clickPart.setText(getClickableSpan());
            Toast.makeText(MainActivity.this, "Click Success", Toast.LENGTH_SHORT).show();
        }
    }

    public class NoUnderlineSpan extends UnderlineSpan {

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

}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值