2010-03-19 17 views
8

Potrzebuję przykładu, jak wyświetlić ciągi, które zaznaczyłem prostym html w TextView. Znalazłem "Spanned fromHtml (String source)", ale nie wiem jak podłączyć go do mojego kodu java.Wyświetl sformatowany ciąg HTML

Oto moja Java:

package com.SorenWinslow.TriumphHistory; 

import android.app.ListActivity; 
import android.os.Bundle; 
import android.widget.ArrayAdapter; 

public class TriumphHistory extends ListActivity { 
    String[] HistoryList; 

    /** Called when the activity is first created. */ 
    @Override 
    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.main); 

     ArrayAdapter<String> adapter; 
     HistoryList = getResources().getStringArray(R.array.history); 
     adapter = new ArrayAdapter<String> (this,R.layout.historylistlayout,HistoryList); 
     setListAdapter(adapter); 

    } 
} 

Oto przykład z historii:

<?xml version="1.0" encoding="utf-8"?> 
<resources> 
<string-array name="history"> 
<item><b>1883</b><br/>Some stuff happened</item> 
<item><b>1884</b><br/>Some more stuff happened <i>before</i> the other stuff 
</item> 
<resources> 

Oto moja historylistlayout.xml:

<?xml version="1.0" encoding="utf-8"?> 
<TextView xmlns:android="http://schemas.android.com/apk/res/android" 
    android:id="@android:id/text1" 
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:textAppearance="?android:attr/textAppearanceLarge" 
    android:gravity="center_vertical" 
    android:textColor="#ffffff" 
    android:background="#000050" 
    android:layout_marginTop="5px" 
    android:minHeight="?android:attr/listPreferredItemHeight" 
    android:padding="3px" 
    android:textSize="8pt" android:layout_gravity="top|left"/> 

I tu jest moim głównym. xml

<?xml version="1.0" encoding="utf-8"?> 


<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:orientation="vertical" 
    android:textColor="#ffffff" 
    android:background="#000080" 
    android:isScrollContainer="true" 
    android:layout_height="fill_parent" 
    android:layout_width="fill_parent" android:scrollbarStyle="insideOverlay"> 

    <ListView xmlns:android="http://schemas.android.com/apk/res/android" 
    android:id="@android:id/list" 
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:clickable="true" 
    android:dividerHeight="1px"/> 

</LinearLayout> 

Odpowiedz

12

Użyj funkcji wspomniałeś powrót łączonego a następnie ustawić tekst swojego TextView użyciu toString zwróconego łączonego przedmiotu podobnego tak, aby osiągnąć sformatowany tekst:

Spanned marked_up = Html.fromHtml(yourTextWithHTML); 
((TextView) findViewById(R.id.text1)).setText(marked_up.toString()); 

To zadziała gdzie yourTextWithHTML jest jedną z ciągi znaków w wysłanych znacznikach przedmiotu. np "<b>1883</b><br/>Some stuff happened"

+1

To działa, jeśli jesteś pompowania zasób String, ale nie jeśli jesteś pompowania tablicę ciągów. Tablice ciągów usuwają formatowanie HTML. –

8
Spanned spannedContent = Html.fromHtml(htmlString); 
    textView.setText(spannedContent, BufferType.SPANNABLE); 
1

Wydaje najprostszy faktycznie (od HTML in string resource?):

mTextView.setText(getText(R.string.my_styled_text)); 

To działa dla ciągów, które mają HTML wewnątrz.

13

Starałem się zrobić coś z samej natury i okazało się, że mój html wraz z CSS nie był już sformatowana poprawnie więc wziąłem łańcuch i załadowaniu go do WebView jak ten:

WebView webview = (WebView) findViewById(R.id.MyWebview); 
String summary = "<html><body>You scored <b>192</b> points.</body></html>"; 
webview.loadData(summary, "text/html", "utf-8"); 

i rozpoznał wszystkie style i poprawnie sformatował HTML. Więcej z androidki odniesieniu HERE

+1

pracował jak urok ... dzięki! +1 – Hiral

0

I wobec tego samego problemu, i rozpuszcza je za pomocą

CharSequence[] HistoryList = getResources().getTextArray(R.array.history); 

Powyżej opisane zwraca kod stylu tablicy Tekst związany z zasobu. powróci CharSequence []

Następnie wystarczy użyć elemens w

setText(HistoryList[index]); 
Powiązane problemy