天天看點

Android項目實戰(十四):TextView顯示html樣式的文字

項目需求:

TextView顯示一段文字,格式為:白雪公主(姓名,字數不确定)向您發來了2(消息個數,不确定)條消息

這段文字中名字和數字的長度是不确定的,還要求名字和數字各自有各自的顔色。

一開始我想的是用

(轉) SpannableString與SpannableStringBuilder

來實作,因為它可以實作一段文字顯示不同的顔色

但是貌似它隻能固定哪些位置的文字顯示什麼樣式,于是乎放棄。

然後就想到了用 

Html.fromHtml(String str)      

來實作。

看方法名很簡單,就是可以顯示字元串str對應的html格式的文本

比如:

Html.fromHtml(<font color='red' size='24'>你好</font>" )      

就将你好以html格式顯示了,紅色字型 大小24 

那麼通過一個小Demo看下這個方法的簡單使用:

我有三個字元串,字元串中姓名、數字長度都是不同的,實作讓姓名顯示紅色,數字顯示藍色,其他文字顯示預設灰色的效果

先寫布局檔案,三個TextView

<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:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:gravity="center"
    android:orientation="vertical"
    tools:context=".MainActivity">

    <TextView
        android:id="@+id/html_text"
        android:gravity="center"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />

    <TextView
        android:id="@+id/html_text2"
        android:gravity="center"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />

    <TextView
        android:id="@+id/html_text3"
        android:gravity="center"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />

</LinearLayout>      

然後Activity 的onCreate()方法

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

        textView = (TextView) findViewById(R.id.html_text);
        textView2 = (TextView) findViewById(R.id.html_text2);
        textView3 = (TextView) findViewById(R.id.html_text3);
        names = new ArrayList<>();
        counts = new ArrayList<>();
        message = new ArrayList<>();

        names.add("奧特曼");
        names.add("白雪公主與七個小矮人");
        names.add("沃德天·沃納陌帥·帥德·布耀布耀德 ");

        counts.add(1);
        counts.add(123);
        counts.add(9090909);

        for (int i = 0; i < 3; i++) {
            message.add("<font color='red' size='20'>"+names.get(i)+"</font>"+"向您發來"+
                        "<font color='blue' size='30'>"+counts.get(i)+"</font>"+"條資訊");
        }

        textView.setText(Html.fromHtml(message.get(0)));
        textView2.setText(Html.fromHtml(message.get(1)));
        textView3.setText(Html.fromHtml(message.get(2)));

    }      

看下效果圖,是不是很簡單,隻要簡單的會html 就可實作這種效果

Android項目實戰(十四):TextView顯示html樣式的文字

繼續閱讀