Android中TextView富文本

android中textview利用富文本标签,类似于html标签,如strong标签,font标签,img标签等,可以实现富文本效果.

先展示效果图:
这里写图片描述

代码:

package com.eg.lyx.shiqu;


import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.text.Html;
import android.text.Spanned;
import android.view.View;
import android.widget.TextView;


public class MainActivity extends AppCompatActivity {


    private TextView tv1;
    private TextView tv2;
    private TextView tv3;
    private TextView tv4;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        tv1 = (TextView) findViewById(R.id.tv1);
        tv2 = (TextView) findViewById(R.id.tv2);
        tv3 = (TextView) findViewById(R.id.tv3);
        tv4 = (TextView) findViewById(R.id.tv4);


        String html1="<font color=\"#ED494B\">红色不加粗</font>   <strong><font color=\"#000000\">黑色加粗</font></strong>";
        tv1.setText( Html.fromHtml(html1));

        String html2 = "<strong><font color=\"#ED494B\">红色加粗</font></strong>  <font color=\"#000000\">黑色不加粗</font>";
        tv2.setText( Html.fromHtml(html2));


        StringBuffer str3 = new StringBuffer();
        str3.append("<font color=\"#ED494B\">").append("红色不加粗").append("</font>")
                .append("<strong><font color=\"#000000\">").append("黑色加粗").append("</font></strong>");
        Spanned spanned3 = Html.fromHtml(str3.toString());
        tv3.setText(spanned3);

        StringBuffer str4 = new StringBuffer();
        str4.append("<strong><font color=\"#ED494B\">").append("红色加粗").append("</font></strong>")
                .append("<font color=\"#000000\">").append("黑色不加粗").append("</font>");
        Spanned spanned4 = Html.fromHtml(str4.toString());
        tv4.setText(spanned4);

    }


在TextView类中预定义了一些类似HTML的标签,通过这些标签,可以使TextView控件显示不同的颜色、大小、字体的文字。

<font>:设置颜色和字体                  

<big>:设置大号字                 

<small>:设置小号字

<i>:斜体                 

<b>:粗体                     

<tt>:等宽字体(Monospace)

<br>:换行(行与行之间没有空行)                

<p>:换行(行与行之间的空行)

<a>:链接地址                          

<img>:插入图像

}

安卓TextView控件默认是不支持富文本的,即无法直接实现文字可点击的效果。不过我们可以通过一些方法来实现这个需求。 一种常用的方法是使用SpannableString类来实现富文本文字可点击的效果。SpannableString是一个可以调整文字的样式和属性的类。我们可以使用它的setSpan()方法来设置文字的点击事件。 首先,我们需要创建一个ClickableSpan对象,它是一个可以实现文字可点击的类。在ClickableSpan的onClick()方法,我们可以编写点击文字后的逻辑代码。 ``` ClickableSpan clickableSpan = new ClickableSpan() { @Override public void onClick(View widget) { // 在这里编写点击文字后的逻辑代码 } }; ``` 然后,我们创建一个SpannableString对象,并使用setSpan()方法将ClickableSpan对象应用于需要点击的文字范围。 ``` SpannableString spannableString = new SpannableString("需要设置点击事件的文字"); spannableString.setSpan(clickableSpan, startIndex, endIndex, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); ``` 其,startIndex和endIndex分别表示需要设置点击事件的文字的起始和结束位置。 接下来,我们将SpannableString对象设置给TextView控件,并为TextView控件设置setMovementMethod()方法,使其具有点击效果。 ``` textView.setText(spannableString); textView.setMovementMethod(LinkMovementMethod.getInstance()); ``` 最后,我们就可以在TextView实现文字可点击的效果了。 需要注意的是,在使用这种方法时,TextView的同时三个属性要设置为true:android:focusable="true"、android:focusableInTouchMode="true"和android:clickable="true",以确保TextView本身可以获得焦点和点击事件。 以上就是使用SpannableString实现安卓TextView富文本文字可点击的方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值