Android TextView顯示html樣式的文字_Android

來源:互聯網
上載者:User

先給大家說下項目需求:

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

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

就想到了用

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"><TextViewandroid:id="@+id/html_text"android:gravity="center"android:layout_width="wrap_content"android:layout_height="wrap_content" /><TextViewandroid:id="@+id/html_text2"android:gravity="center"android:layout_width="wrap_content"android:layout_height="wrap_content" /><TextViewandroid:id="@+id/html_text3"android:gravity="center"android:layout_width="wrap_content"android:layout_height="wrap_content" /></LinearLayout>

然後Activity 的onCreate()方法

@Overrideprotected 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樣式的文字,希望本文分享能夠協助到大家。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.