Android 部分文字颜色大小点击事件的处理

Android开发中,经常会有这样一个需求,在一段文字中,为突出显示其中几个文字,会采用不同的颜色,大小来显示,并且有可能需要点击处理。先将自己平常用到的几种方法总结如下。

1. 直接利用布局实现

2. 利用富文本标签实现

3. webview嵌套html实现

4. SpannableString实现

现在我有一个需求是显示:“简单点说话的方式简单点”这句话,要求“说话的”三个字为红色,字号比其他的字大,并且可以点击。下面分别采用以上四种方式实现。

首先看下效果图:

Android 部分文字颜色大小点击事件的处理_第1张图片

1. 直接利用布局实现

xml代码:

            "match_parent"
                android:layout_height="wrap_content"
                android:gravity="center_horizontal"
                android:orientation="horizontal">

                id="@+id/tv_1"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="简单点" />

                id="@+id/tv_2"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="说话的"
                    android:textColor="@android:color/holo_red_light" />

                id="@+id/tv_3"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="方式简单点" />
            

MainActivity代码:

  findViewById(R.id.tv_2).setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Toast.makeText(MainActivity.this, "说话的", Toast.LENGTH_SHORT).show();
            }
        });

注意:

  1. 直接采用布局实现是最简单的方式, 改变字体大小和颜色只需要设置android:textSize=”“和android:textColor=”“就可以了。
  2. 但是当这一行文字的长度超过一行时,会发现,用这种方式就不好控制了。eg:

Android 部分文字颜色大小点击事件的处理_第2张图片

2.利用富文本标签实现

xml代码:

 <TextView
                android:id="@+id/tv_html"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_marginTop="15dp"
                android:gravity="center_horizontal" />

MainActivity代码:

   TextView tv_html = (TextView) findViewById(R.id.tv_html);
        String s = "简单点" + "" + "说话的" + "" + "方式简单点";
        tv_html.setText(Html.fromHtml(s));

注意:
1. size用不了。
2. 不支持 style 样式设置。

3.webview嵌套html

xml代码:

   <WebView
                android:id="@+id/wv"
                android:layout_width="wrap_content"
                android:layout_marginTop="15dp"
                android:layout_gravity="center"
                android:layout_height="wrap_content">WebView>

MainActivity代码:

 WebView webView = (WebView) findViewById(R.id.wv);
        webView.loadUrl("file:///android_asset/redFont.html");
        webView.getSettings().setJavaScriptEnabled(true);
        webView.addJavascriptInterface(new ClickMethod(), "Zyc");

redFont.html:


<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档title>
head>
<body>
<p align="center">简单点<span onclick="zyc()"><font color="#FF0000">说话的font>span>方式简单点p>
body>
<script type="text/javascript">
    function zyc(){
        Zyc.show("说话的");
        }
script>
html>

注意:

1.这种方式是比较强大的,利用HTML CSS JS等可以实现你所想要几乎所有的效果。

4.SpannableString实现

xml代码:

  <TextView
                android:id="@+id/tv_yanyuan"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_marginTop="15dp"
                android:gravity="center_horizontal" />

MainActivity代码:

  final String geci = getResources().getString(R.string.yanyuan);
        SpannableString ss = new SpannableString(geci);
        ss.setSpan(new ClickableSpan() {

            @Override
            public void onClick(View widget) {
                Toast.makeText(MainActivity.this, geci.substring(geci.length() - 6 - 3, geci.length() - 6), Toast.LENGTH_SHORT).show();
            }
        }, geci.length() - 6 - 3, geci.length() - 6, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
        tv_yanyuan.setText(ss);
        tv_yanyuan.setMovementMethod(LinkMovementMethod
                .getInstance());

注意:

  1. 这种方式,个人感觉不就是HTML的变形么,所以我推荐使用第三种方式。
  2. 设置颜色ss.setSpan(new ForegroundColorSpan(Color.RED), geci.length() - 4, geci.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);

最后总结下,每种方式都有各自的优缺点,最简单的就是直接用布局的方式。在没有超过一行的情况下,是一种很容易的实现方式;采用富文本可以很简单的改变部分文字的颜色,但是改变字体的大小和添加监听事件就不容易了;至于第三种和第四种方式,我就直接推荐WebView了,用HTML,CSS,JS是现在APP开发比较流行的一种方式。

OK,就到这了~

你可能感兴趣的:(Android,文字颜色)