come creare un testo specifico su TextView BOLD


252

Non so come rendere grassetto un testo specifico su TextView.

è così

txtResult.setText(id+" "+name);

Voglio che l'output sia così:

1111 neil

ide namesono variabili in cui ho recuperato il valore dal database e voglio renderlo idgrassetto, ma solo idcosì la namevolontà non sarà influenzata, non ho idea di come farlo.



Risposte:


379

Crea la tua stringa in HTML e impostala:

String sourceString = "<b>" + id + "</b> " + name; 
mytextview.setText(Html.fromHtml(sourceString));

5
Poiché fromHtml (sourceString) è obsoleto in API 24, è necessario utilizzare il codice successivo: Durata spanningSpanning; if (android.os.Build.VERSION.SDK_INT> = android.os.Build.VERSION_CODES.N) {durationSpanned = Html.fromHtml (durationFormatted, Html.FROM_HTML_MODE_LEGACY); } else {durationSpanned = Html.fromHtml (durationFormatted); }
Mladen Rakonjac,

2
Questa è l'unica opzione che funzionerà se stai localizzando la tua app.
howettl

È una buona soluzione ma ho scoperto che non funziona per <e> la soluzione @ wtsang02 è più ottimale
Omar Boshra,

Non funziona con <SE usi String.format, A MENO CHE non esca anche dalla parentesi, come descritto qui .
Yusuf X

5
Html.fromHtml()è ora deprecato
Someone Somewhere

384

Mentre puoi usare Html.fromHtml () puoi usare un approccio più nativo che è SpannableStringBuilder , questo post può essere utile.

SpannableStringBuilder str = new SpannableStringBuilder("Your awesome text");
str.setSpan(new android.text.style.StyleSpan(android.graphics.Typeface.BOLD), INT_START, INT_END, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
TextView tv=new TextView(context);
tv.setText(str);

Se questa risposta non funziona, prova ad aggiungere il tuo testo con una stringa spannabile qualcosa come: mSpannable.append (yourremainingtext);
Gowtham Kumar,

10
Per le persone che provengono da Google senza conoscenza preliminare: INT_START / INT_END sono la posizione in cui il grassetto dovrebbe iniziare e finire.
Spotlight

2
se hai solo bisogno di applicare un po 'di markup alla stringa sorgente senza cambiarla, allora è meglio usare la classe
SpannableString

26
Questo si interromperà completamente se è necessario localizzare la copia. INT_START e INT_END saranno posizioni diverse in diverse localizzazioni.
howettl

4
Cerca di capire cosa sta facendo il codice in caso di dubbio. Int start è un numero definito dall'utente, ovvero l'indice iniziale dell'intervallo. Prova 0 per inizio, stringa. (). Size () per fine.
wtsang02,

85

Primo: non devi preoccuparti di usare il codice delle prestazioni lente dalla risposta di Raghav Sood .

Secondo: non è necessario scrivere una funzione di estensione fornita dalla risposta di w3bshark quando si utilizza Kotlin.

Finnaly: tutto ciò che devi fare è utilizzare la libreria Android-ktx di Kotlin di Google ( fai riferimento qui per trovare ulteriori informazioni e come includerle nel tuo progetto):

// Suppose id = 1111 and name = neil (just what you want). 
val s = SpannableStringBuilder()
          .bold { append(id) } 
          .append(name)
txtResult.setText(s) 

Produce: 1111 neil


AGGIORNARE:

Perché penso che possa aiutare qualcun altro oltre a dimostrare fino a che punto puoi andare qui ci sono più casi d'uso.

  • Quando è necessario visualizzare un testo con alcune parti in blu e in corsivo:

    val myCustomizedString = SpannableStringBuilder()
        .color(blueColor, { append("A blue text ") })
        .append("showing that ")
        .italic{ append("it is painless") }
  • Quando è necessario visualizzare un testo in grassetto e corsivo:

        bold { italic { append("Bold and italic") } }

In breve, bold, append, colore italicsono funzioni di estensione a SpannableStringBuilder. Puoi vedere un'altra funzione di estensione nella documentazione ufficiale , da cui puoi pensare per altre possibilità.


Questo è fantastico e tutto, ma penso che ogni risposta relativa alle stringhe dovrebbe prendere in considerazione le traduzioni. Le parole nelle frasi possono essere ordinate e strutturate in modo completamente diverso in alcune lingue, quindi aggiungere in questo modo non è sempre applicabile in determinate situazioni. Inoltre, non è l'ideale per elementi come stringhe di quantità in XML.
Edward van Raak,

1
@CoolMind Non ti rende incapace di utilizzare Android KTX. Puoi trovare informazioni su github.com/android/android-ktx su come segnalare un bug, dare un suggerimento sulle funzionalità o contribuire a quella libreria. Quindi, è ancora un riferimento valido. Ho aggiornato la mia risposta per includere ulteriori informazioni sulla biblioteca e su come usarla nel tuo progetto.
Filipe Brito,

1
dai a questo ragazzo una medaglia per questa soluzione e risorsa moderne !! Grazie!!!
Sjd

37

Ho pensato che la risposta scelta non avesse fornito un risultato soddisfacente. Ho scritto la mia funzione che richiede 2 stringhe; Il testo completo e la parte del testo che vuoi mettere in grassetto.

Restituisce SpannableStringBuilder con 'textToBold' da 'text' in grassetto.

Trovo utile la capacità di rendere audace una sottostringa senza racchiuderla in tag.

    /**
     * Makes a substring of a string bold.
     * @param text          Full text
     * @param textToBold    Text you want to make bold
     * @return              String with bold substring
     */

    public static SpannableStringBuilder makeSectionOfTextBold(String text, String textToBold){

        SpannableStringBuilder builder=new SpannableStringBuilder();

        if(textToBold.length() > 0 && !textToBold.trim().equals("")){

            //for counting start/end indexes
            String testText = text.toLowerCase(Locale.US);
            String testTextToBold = textToBold.toLowerCase(Locale.US);
            int startingIndex = testText.indexOf(testTextToBold);
            int endingIndex = startingIndex + testTextToBold.length();
            //for counting start/end indexes

            if(startingIndex < 0 || endingIndex <0){
                return builder.append(text);
            }
            else if(startingIndex >= 0 && endingIndex >=0){

                builder.append(text);
                builder.setSpan(new StyleSpan(Typeface.BOLD), startingIndex, endingIndex, 0);
            }
        }else{
            return builder.append(text);
        }

        return builder;
  }

Potete fornire un esempio di come utilizzare questo nel codice?
Micro

2
@MicroR Devi passare due stringhe, la seconda stringa deve essere una sezione di testo contenuta nella prima. es. makeSectionOfTextBold ("Questo è un ottimo testo.", "fantastico").
Leon,

1
dovresti cambiare la tua istruzione if con if (textToBold! = null &&! textToBold.isEmpty ())
Arda Kara

2
Questa funzione non prevede che la sottostringa possa verificarsi più volte nel testo completo. Ad esempio in "Il mio nome utente è nome" non può rendere grassetto il secondo "nome".
Jadamec,

1
Quindi questo metodo dovrebbe effettivamente essere chiamato makeAllBold (text, textToBold).
wtsang02,

30

Come diceva wtsang02, l'utilizzo dell'HTML è un costoso dispendio di risorse. Usa la soluzione nativa. Se non è necessario modificare la stringa, utilizzare solo SpannableString, non SpannableStringBuilder.

String boldText = "id";
String normalText = "name";
SpannableString str = new SpannableString(boldText + normalText);
str.setSpan(new StyleSpan(Typeface.BOLD), 0, boldText.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
textView.setText(str);

23

Nel caso in cui desideri utilizzare la stringa da XML, puoi fare qualcosa del genere:

strings.xml (la parte "CDATA" è importante, altrimenti non funzionerà)

<string name="test">
     <![CDATA[
 <b>bold!</b> normal
    ]]>
</string>

file di layout

<FrameLayout
    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" tools:context=".MainActivity">

    <TextView
        android:id="@+id/textView" android:layout_width="wrap_content" android:layout_height="wrap_content"
        android:layout_gravity="center" />

</FrameLayout>

codice

textView.text = HtmlCompat.fromHtml(getString(R.string.test), HtmlCompat.FROM_HTML_MODE_LEGACY)

Questo funziona per me <string name="test"><b>text bold</b> other text</string>. Non funziona se scrivo<![CDATA[
sara,

@sara Provato di nuovo ora, su Pixel 2 con Q. Funziona bene. Qui, ho aggiornato su come funziona con Kotlin. Per favore riprova.
sviluppatore Android

Questa è la risposta accettabile se si utilizzano caratteri personalizzati. Kudus al creatore.
Raghul Sugathan,

13

È semplice, ad esempio, chiudere il testo specificato come questo <b>"your text here:"</b>

<string name="headquarters">"<b>"Headquarters:"</b>" Mooresville, North Carolina, U.S.</string>

risultato: sede centrale: Mooresville, Carolina del Nord, Stati Uniti


Funziona solo se la stringa viene utilizzata da XML. Se questa stringa viene chiamata a livello di codice, la codifica HTML viene eliminata.
Starwave,

11

Se stai usando Kotlin, diventa ancora più facile da fare usando core-ktx, in quanto fornisce un dominio specifico del linguaggio (DSL) per fare questo:

val string: SpannedString = buildSpannedString {
    bold {
        append("foo")
    }
    append("bar")     
}

Altre opzioni fornite sono:

append("Hello There")
bold {
    append("bold")
    italic {
        append("bold and italic")
        underline {
            append("then some text with underline")
        }
    }
}

Finalmente puoi semplicemente:

textView.text = string

10

Ecco la soluzione migliore se si desidera rendere più testo in grassetto. Ho migliorato il codice di Eitan. grazie Eitan.

public static SpannableStringBuilder makeSectionOfTextBold(String text, String... textToBold) {
    SpannableStringBuilder builder = new SpannableStringBuilder(text);

    for (String textItem :
            textToBold) {
        if (textItem.length() > 0 && !textItem.trim().equals("")) {
            //for counting start/end indexes
            String testText = text.toLowerCase(Locale.US);
            String testTextToBold = textItem.toLowerCase(Locale.US);
            int startingIndex = testText.indexOf(testTextToBold);
            int endingIndex = startingIndex + testTextToBold.length();

            if (startingIndex >= 0 && endingIndex >= 0) {
                builder.setSpan(new StyleSpan(Typeface.BOLD), startingIndex, endingIndex, 0);
            }
        }
    }

    return builder;
}

8

Sulla base della risposta di @ mladj0ni, ho ottenuto il codice seguente per funzionare. Il problema era che se usi String.format , elimina il markup html, quindi devi sfuggire ai simboli parentesi quadre in strings.xml:

strings.xml:

<string name="welcome_messages">Hello, %1$s! You have &lt;b>%2$d new messages&lt;/b>.</string>

code.java:

String unspanned = String.format(Locale.US, "%s%s", getResources().getString(R.string. welcome_messages), 99);

Spanned spanned;
if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.N) {
    spanned = Html.fromHtml(unspanned, Html.FROM_HTML_MODE_LEGACY);
} else {
    spanned = Html.fromHtml(unspanned);
}

textView.setText(spanned);

È più semplice di SpannableStringBuilder. Per quanto riguarda le prestazioni, se stai visualizzando solo una stringa, l'utente non noterà il millisecondo in più per analizzarlo.

Vedi la documentazione qui .


Grazie per & lt; b> ... & lt; / b>
oxied

4

Puoi utilizzare questo codice per impostare in grassetto parte del testo. Per qualunque cosa si trovi tra i tag HTML in grassetto, lo renderà grassetto.

String myText = "make this <b>bold</b> and <b>this</b> too";
textView.setText(makeSpannable(myText, "<b>(.+?)</b>", "<b>", "</b>"));

public SpannableStringBuilder makeSpannable(String text, String regex, String startTag, String endTag) {

            StringBuffer sb = new StringBuffer();
            SpannableStringBuilder spannable = new SpannableStringBuilder();

            Pattern pattern = Pattern.compile(regex);
            Matcher matcher = pattern.matcher(text);
            while (matcher.find()) {
                sb.setLength(0);
                String group = matcher.group();
                String spanText = group.substring(startTag.length(), group.length() - endTag.length());
                matcher.appendReplacement(sb, spanText);

                spannable.append(sb.toString());
                int start = spannable.length() - spanText.length();

                spannable.setSpan(new android.text.style.StyleSpan(android.graphics.Typeface.BOLD), start, spannable.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
            }
            sb.setLength(0);
            matcher.appendTail(sb);
            spannable.append(sb.toString());
            return spannable;
        }

3
public static Spanned getBoldString(String textNotBoldFirst, String textToBold, String textNotBoldLast) {
    String resultant = null;

    resultant = textNotBoldFirst + " " + "<b>" + textToBold + "</b>" + " " + textNotBoldLast;

    return Html.fromHtml(resultant);

}

Prova questo. Può aiutare sicuramente


3

Rendi spannabile il primo carattere di stringa durante la ricerca di caratteri nell'elenco come / riciclatore

r a vi e ajay

evidenziando in precedenza come questo, ma volevo essere come di seguito

ravi un ajay nd OR ravi e un jay

per questo ho cercato la lunghezza della parola se è uguale a 1, ho separato la stringa principale in parole e calcolato la posizione iniziale della parola quindi ho cercato la parola che inizia con char.

 public static SpannableString colorString(int color, String text, String... wordsToColor) {
    SpannableString coloredString = new SpannableString(text);

    for (String word : wordsToColor) {

        Log.e("tokentoken", "-wrd len-" + word.length());
        if (word.length() !=1) {
            int startColorIndex = text.toLowerCase().indexOf(word.toLowerCase());
            int endColorIndex = startColorIndex + word.length();
            try {
                coloredString.setSpan(new ForegroundColorSpan(color), startColorIndex, endColorIndex,
                        Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);

            } catch (Exception e) {
                e.getMessage();
            }
        } else {
            int start = 0;

            for (String token : text.split("[\u00A0 \n]")) {
                if (token.length() > 0) {
                    start = text.indexOf(token, start);
                   // Log.e("tokentoken", "-token-" + token + "   --start--" + start);
                    char x = token.toLowerCase().charAt(0);
                    char w = word.toLowerCase().charAt(0);
                   // Log.e("tokentoken", "-w-" + w + "   --x--" + x);

                    if (x == w) {
                        // int startColorIndex = text.toLowerCase().indexOf(word.toLowerCase());
                        int endColorIndex = start + word.length();
                        try {
                            coloredString.setSpan(new ForegroundColorSpan(color), start, endColorIndex,
                                    Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);

                        } catch (Exception e) {
                            e.getMessage();
                        }
                    }
                }
            }

        }

    }

    return coloredString;
}

3

Sono venuto qui per fornire una soluzione più aggiornata, perché non ero soddisfatto delle risposte esistenti. Avevo bisogno di qualcosa che avrebbe funzionato per i testi tradotti e che non avesse il successo prestazionale dell'uso Html.fromHtml(). Se stai usando Kotlin, ecco una funzione di estensione che imposta facilmente in grassetto più parti del testo . Funziona proprio come Markdown e, se necessario, potrebbe essere esteso per supportare altri tag Markdown.

val yourString = "**This** is your **string**.".makePartialTextsBold()
val anotherString = getString(R.string.something).makePartialTextsBold()

/**
 * This function requires that the parts of the string that need
 * to be bolded are wrapped in ** and ** tags
 */
fun String.makePartialTextsBold(): SpannableStringBuilder {
    var copy = this
    return SpannableStringBuilder().apply {
        var setSpan = true
        var next: String
        do {
            setSpan = !setSpan
            next = if (length == 0) copy.substringBefore("**", "") else copy.substringBefore("**")
            val start = length
            append(next)
            if (setSpan) {
                setSpan(StyleSpan(Typeface.BOLD), start, length,
                        Spannable.SPAN_EXCLUSIVE_EXCLUSIVE)
            }
            copy = copy.removePrefix(next).removePrefix("**")
        } while (copy.isNotEmpty())
    }
}

3

La risposta di wtsang02 è il modo migliore per farlo, poiché Html.fromHtml ("") è ora deprecato. Qui ho intenzione di migliorarlo un po 'per chiunque abbia problemi a rendere dinamicamente in grassetto la prima parola, non importa quale sia la dimensione della frase.

Per prima cosa creiamo un metodo per ottenere la prima parola:

 private String getFirstWord(String input){

    for(int i = 0; i < input.length(); i++){

        if(input.charAt(i) == ' '){

            return input.substring(0, i);
        }
    }

    return input;
}

Ora supponiamo che tu abbia una lunga stringa come questa:

String sentence = "friendsAwesomeName@gmail.com want's to be your friend!"

E vuoi che la tua frase sia come yourAwesomeName@gmail.com vuoi che sia tuo amico! Tutto quello che devi fare è prendere la prima Parola e prenderne la lunghezza per rendere audace la prima Parola, qualcosa del genere:

String myFirstWord = getFirstWord(sentence);
int start = 0; // bold will start at index 0
int end = myFirstWord.length(); // and will finish at whatever the length of your first word

Ora segui i passaggi di wtsang02 , in questo modo:

SpannableStringBuilder fancySentence = new SpannableStringBuilder(sentence);
fancySentence.setSpan(new android.text.style.StyleSpan(Typeface.BOLD), start, end, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
textView.setText(fancySentence);

E questo è tutto! Ora dovresti essere in grado di mettere in grassetto una parola con qualsiasi dimensione dalla frase lunga / corta. Spero che possa aiutare qualcuno, felice coding :)


3

Questa è la funzione di estensione di Kotlin che uso per questo

/**
 * Sets the specified Typeface Style on the first instance of the specified substring(s)
 * @param one or more [Pair] of [String] and [Typeface] style (e.g. BOLD, ITALIC, etc.)
 */
fun TextView.setSubstringTypeface(vararg textsToStyle: Pair<String, Int>) {
    val spannableString = SpannableString(this.text)
    for (textToStyle in textsToStyle) {
        val startIndex = this.text.toString().indexOf(textToStyle.first)
        val endIndex = startIndex + textToStyle.first.length

        if (startIndex >= 0) {
            spannableString.setSpan(
                StyleSpan(textToStyle.second),
                startIndex,
                endIndex,
                Spannable.SPAN_EXCLUSIVE_EXCLUSIVE
            )
        }
    }
    this.setText(spannableString, TextView.BufferType.SPANNABLE)
}

Uso:

text_view.text="something bold"
text_view.setSubstringTypeface(
    Pair(
        "something bold",
        Typeface.BOLD
    )
)

.

text_view.text="something bold something italic"
text_view.setSubstringTypeface(
    Pair(
        "something bold ",
        Typeface.BOLD
    ),
    Pair(
        "something italic",
        Typeface.ITALIC
    )
)

2

Puoi aggiungere le due stringhe separatamente nel builder, una delle quali è spanningString, l'altra è normale. In questo modo non devi calcolare gli indici.

val instructionPress = resources?.getString(R.string.settings_press)

val okText = resources?.getString(R.string.ok)
val spannableString = SpannableString(okText)

val spannableBuilder = SpannableStringBuilder()
spannableBuilder.append(instructionPress)
spannableBuilder.append(spannableString, StyleSpan(Typeface.BOLD), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE)

instructionText.setText(spannableBuilder,TextView.BufferType.SPANNABLE)

2

se la posizione del testo in grassetto è fissa (es: se è all'inizio di textView), utilizzare due textView diversi con lo stesso sfondo. Quindi puoi rendere textStyle dell'altro textView in grassetto.

Ciò richiederà il doppio della memoria rispetto a un singolo textView ma la velocità aumenterà.


1

Ho creato un metodo statico per impostare parte del testo Grassetto per TextView e EditText

public static void boldPartOfText(View mView, String contentData, int startIndex, int endIndex){
        if(!contentData.isEmpty() && contentData.length() > endIndex) {
            final SpannableStringBuilder sb = new SpannableStringBuilder(contentData);

            final StyleSpan bss = new StyleSpan(Typeface.BOLD); // Span to make text bold
            final StyleSpan iss = new StyleSpan(Typeface.NORMAL); //Span to make text normal
            sb.setSpan(iss, 0, startIndex, Spanned.SPAN_INCLUSIVE_INCLUSIVE);
            sb.setSpan(bss, startIndex, endIndex, Spannable.SPAN_INCLUSIVE_INCLUSIVE); // make first 4 characters Bold
            sb.setSpan(iss,endIndex, contentData.length()-1, Spanned.SPAN_INCLUSIVE_INCLUSIVE);

            if(mView instanceof TextView)
               ((TextView) mView).setText(sb);
            else if(mView instanceof EditText)
               ((EditText) mView).setText(sb);

        }
    }

Un altro codice più personalizzato

  /*typeFaceStyle can be passed as 

    Typeface.NORMAL = 0;
    Typeface.BOLD = 1;
    Typeface.ITALIC = 2;
    Typeface.BOLD_ITALIC = 3;*/

    public static void boldPartOfText(View mView, String contentData, int startIndex, int endIndex,int typeFaceStyle){
        if(!contentData.isEmpty() && contentData.length() > endIndex) {
            final SpannableStringBuilder sb = new SpannableStringBuilder(contentData);

            final StyleSpan bss = new StyleSpan(typeFaceStyle); // Span to make text bold
            final StyleSpan iss = new StyleSpan(Typeface.NORMAL); //Span to make text italic
            sb.setSpan(iss, 0, startIndex, Spanned.SPAN_INCLUSIVE_INCLUSIVE);
            sb.setSpan(bss, startIndex, endIndex, Spannable.SPAN_INCLUSIVE_INCLUSIVE); // make first 4 characters Bold
            sb.setSpan(iss,endIndex,contentData.length()-1,Spanned.SPAN_INCLUSIVE_INCLUSIVE);

            if(mView instanceof TextView)
                ((TextView) mView).setText(sb);
            else if(mView instanceof EditText)
                ((EditText) mView).setText(sb);
        }
    }

1

Nel caso in cui qualcuno stia utilizzando Data Binding. Possiamo definire un adattatore di rilegatura in questo modo

@BindingAdapter("html")
fun setHtml(view: TextView, html: String) {
    view.setText(HtmlCompat.fromHtml(html, HtmlCompat.FROM_HTML_MODE_LEGACY))
}

Quindi possiamo usarlo su un TextView

app:html="@{@string/bold_text}"

dove bold_text è

<string name="bold_text"><![CDATA[Part of text is <b>bold</b>]]></string>

Dove scrivi la funzione "setHtml"?
sviluppatore Android il

developer.android.com/topic/libraries/data-binding/… È praticamente una classe, a condizione che tu abbia un'annotazione
logcat

Oh, è così strano per me. Grazie. Conosci forse un bel tutorial / campione per i nuovi arrivati ​​di questo argomento?
sviluppatore Android

Non conosco tutorial. Basta google "android BindingAdapter"
logcat

1

Ho trovato un modo nel caso in cui desideri gestire la localizzazione in più lingue, è noioso da fare ma funziona, supponiamo di volerlo:

In inglese:

Non ci sono pagamenti registrati

In spagnolo:

Nessun registro pagos di fieno

Devi creare 3 stringhe

Inglese:

<string name="start_string">There are no</string>
<string name="middle_string">payments</string>
<string name="end_string">registered.</string>
<string name="string_format" translatable="false">%1$s %2$s %3$s</string>

Spagnolo:

<string name="start_string">No hay</string>
<string name="middle_string">pagos</string>
<string name="end_string">registrados</string>

Ora puoi farlo:

val startSpanPosition = getString(R.string.start_string).length
val endSpanPosition = startSpanPosition + getString(R.string.middle_string).length
val mySpannableString = SpannableStringBuilder(String.format(getString(R.string.string_format),
        getString(R.string.start_string), getString(R.string.middle_string))), getString(R.string.end_string)))

mySpannableString.setSpan(StyleSpan(Typeface.BOLD), spanStartPosition, endSpanPosition, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE)

1

La tua risorsa String

<resources>
   <string name="your_string_resource_name">This is normal text<![CDATA[<b> but this is bold </b>]]> and <![CDATA[<u> but this is underline text</u>]]></string>
</resources> 

la tua lezione di java

yourtextView.setText(getString(R.string.your_string_resource_name));

0

Ecco la mia soluzione completa per valori String dinamici con case check.

/**
 * Makes a portion of String formatted in BOLD.
 *
 * @param completeString       String from which a portion needs to be extracted and formatted.<br> eg. I am BOLD.
 * @param targetStringToFormat Target String value to format. <br>eg. BOLD
 * @param matchCase Match by target character case or not. If true, BOLD != bold
 * @return A string with a portion formatted in BOLD. <br> I am <b>BOLD</b>.
 */
public static SpannableStringBuilder formatAStringPortionInBold(String completeString, String targetStringToFormat, boolean matchCase) {
    //Null complete string return empty
    if (TextUtils.isEmpty(completeString)) {
        return new SpannableStringBuilder("");
    }

    SpannableStringBuilder str = new SpannableStringBuilder(completeString);
    int start_index = 0;

    //if matchCase is true, match exact string
    if (matchCase) {
        if (TextUtils.isEmpty(targetStringToFormat) || !completeString.contains(targetStringToFormat)) {
            return str;
        }

        start_index = str.toString().indexOf(targetStringToFormat);
    } else {
        //else find in lower cases
        if (TextUtils.isEmpty(targetStringToFormat) || !completeString.toLowerCase().contains(targetStringToFormat.toLowerCase())) {
            return str;
        }

        start_index = str.toString().toLowerCase().indexOf(targetStringToFormat.toLowerCase());
    }

    int end_index = start_index + targetStringToFormat.length();
    str.setSpan(new StyleSpan(BOLD), start_index, end_index, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
    return str;
}

Per esempio. completeString = "I am BOLD"

CASO I se *targetStringToFormat* = "bold"e*matchCase* = true

restituisce "I am BOLD" (poiché grassetto! = BOLD)

CASO II se *targetStringToFormat* = "bold"e*matchCase* = false

restituisce "I am BOLD "

Applicare:

myTextView.setText(formatAStringPortionInBold("I am BOLD", "bold", false))

Spero che aiuti!

Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.