¿Cómo configurar el estilo de fuente en negrita, cursiva y subrayado en un Android TextView?

6 minutos de lectura

avatar de usuario
d-hombre

quiero hacer un TextViewEl contenido de negrita, cursiva y subrayado. Probé el siguiente código y funciona, pero no subraya.

<Textview android:textStyle="bold|italic" ..

¿Cómo lo hago? ¿Alguna idea rápida?

  • ¿Funciona configurar solo uno de ellos?

    – falstro

    7 de enero de 2011 a las 7:47

  • sí, funciona bien, también quiero que quede subrayado.

    – d-hombre

    7 de enero de 2011 a las 7:48

  • textView.setPaintFlags(Paint.UNDERLINE_TEXT_FLAG);

    – bCliks

    11 de septiembre de 2013 a las 5:50

  • tv.setTypeface(null, Typeface.BOLD_ITALIC);

    usuario2742371

    30 de octubre de 2013 a las 13:54

  • Subrayar TextView – 5 formas asombrosas

    – Vijay Ram

    19 de mayo de 2020 a las 7:10

Esto debería hacer que su TextView audaz, subrayada y itálico al mismo tiempo.

cadenas.xml

<resources>
    <string name="register"><u><b><i>Copyright</i></b></u></string>
</resources>

Para establecer esta cadena en su TextView, haga esto en su principal.xml

<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/textview"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:text="@string/register" />

o en JAVA,

TextView textView = new TextView(this);
textView.setText(R.string.register);

A veces, el enfoque anterior no será útil cuando tenga que usar texto dinámico. Entonces en ese caso Cadena expandible entra en acción.

String tempString="Copyright";
TextView text=(TextView)findViewById(R.id.text);
SpannableString spanString = new SpannableString(tempString);
spanString.setSpan(new UnderlineSpan(), 0, spanString.length(), 0);
spanString.setSpan(new StyleSpan(Typeface.BOLD), 0, spanString.length(), 0);
spanString.setSpan(new StyleSpan(Typeface.ITALIC), 0, spanString.length(), 0);
text.setText(spanString);

PRODUCCIÓN

ingrese la descripción de la imagen aquí

  • Lo comprobé en 2.1. Entonces, al menos debería funcionar desde 2.1 y superior

    –Andro Selva

    14 de octubre de 2012 a las 2:03

  • Puede considerar usar new StyleSpan(Typeface.BOLD_ITALIC)

    –Cheok Yan Cheng

    2 de julio de 2016 a las 16:11

  • ¿Por qué no funciona en cadenas concatenadas dinámicas? Está cableado que aparecieron algunos números….

    – AuBee

    14/10/2016 a las 22:54

avatar de usuario
nana

No sé sobre subrayado, pero para negrita y cursiva hay "bolditalic". No hay mención de subrayado aquí: http://developer.android.com/reference/android/widget/TextView.html#attr_android:textStyle

Tenga en cuenta que para usar el mencionado bolditalic es necesario, y cito de esa página

Debe ser uno o más (separados por ‘|’) de los siguientes valores constantes.

entonces usarías bold|italic

Puede verificar esta pregunta para subrayar: ¿Puedo subrayar el texto en un diseño de Android?

  • para subrayar.. textView.setPaintFlags(Paint.UNDERLINE_TEXT_FLAG);

    – bCliks

    11 de septiembre de 2013 a las 5:51


  • @bala tenga en cuenta que su solución siempre subraya todo el texto, por lo que no es factible en los casos en que uno quiere subrayar solo una parte.

    – Giulio Piancastelli

    02/04/2014 a las 18:14

  • Se prefiere usar xml en lugar de hacerlo por código cuando sea posible. Vea la respuesta de Andro Selva a continuación

    – El Sushiboi

    23 oct 2020 a las 16:05

O simplemente así en Kotlin:

val tv = findViewById(R.id.textViewOne) as TextView
tv.setTypeface(null, Typeface.BOLD_ITALIC)
// OR
tv.setTypeface(null, Typeface.BOLD or Typeface.ITALIC)
// OR
tv.setTypeface(null, Typeface.BOLD)
// OR
tv.setTypeface(null, Typeface.ITALIC)
// AND
tv.paintFlags = tv.paintFlags or Paint.UNDERLINE_TEXT_FLAG

O en Java:

TextView tv = (TextView)findViewById(R.id.textViewOne);
tv.setTypeface(null, Typeface.BOLD_ITALIC);
// OR
tv.setTypeface(null, Typeface.BOLD|Typeface.ITALIC);
// OR
tv.setTypeface(null, Typeface.BOLD);
// OR
tv.setTypeface(null, Typeface.ITALIC);
// AND
tv.setPaintFlags(tv.getPaintFlags()|Paint.UNDERLINE_TEXT_FLAG);

Mantenlo simple y en una línea 🙂

  • Al insertar el paquete kotlinx.android.synthetic para la vista con la que está trabajando, findViewByID no es necesario en Kotlin, haciendo que cada una de las líneas setTypeface: textViewOne.setTypeface(…)

    – cren90

    11/12/2017 a las 22:50


  • es paintFlags necesario ? Funciona sin eso

    – Prabs

    13 de febrero de 2019 a las 6:27


avatar de usuario
Vivek

Para negrita y cursiva, lo que sea que esté haciendo es correcto para subrayar, use el siguiente código

HolaAndroid.java

 package com.example.helloandroid;

 import android.app.Activity;
 import android.os.Bundle;
 import android.text.SpannableString;
 import android.text.style.UnderlineSpan;
import android.widget.TextView;

public class HelloAndroid extends Activity {
TextView textview;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    textview = (TextView)findViewById(R.id.textview);
    SpannableString content = new SpannableString(getText(R.string.hello));
    content.setSpan(new UnderlineSpan(), 0, content.length(), 0);
    textview.setText(content);
}
}

principal.xml

<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/textview"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:text="@string/hello"
android:textStyle="bold|italic"/>

cadena.xml

<?xml version="1.0" encoding="utf-8"?>
 <resources>
  <string name="hello">Hello World, HelloAndroid!</string>
  <string name="app_name">Hello, Android</string>
</resources>

avatar de usuario
sonida

Esta es una manera fácil de agregar un subrayado, manteniendo otras configuraciones:

textView.setPaintFlags(textView.getPaintFlags() | Paint.UNDERLINE_TEXT_FLAG);

  • Tenga en cuenta que esta solución siempre subraya todo el texto, por lo que no es factible en los casos en que se desea subrayar solo una parte del mismo.

    – Giulio Piancastelli

    02/04/2014 a las 18:15

avatar de usuario
rey de las masas

Programáticamente:

Puedes hacerlo programáticamente usando el método setTypeface():

A continuación se muestra el código para el tipo de letra predeterminado

textView.setTypeface(null, Typeface.NORMAL);      // for Normal Text
textView.setTypeface(null, Typeface.BOLD);        // for Bold only
textView.setTypeface(null, Typeface.ITALIC);      // for Italic
textView.setTypeface(null, Typeface.BOLD_ITALIC); // for Bold and Italic

y si desea configurar un tipo de letra personalizado:

textView.setTypeface(textView.getTypeface(), Typeface.NORMAL);      // for Normal Text
textView.setTypeface(textView.getTypeface(), Typeface.BOLD);        // for Bold only
textView.setTypeface(textView.getTypeface(), Typeface.ITALIC);      // for Italic
textView.setTypeface(textView.getTypeface(), Typeface.BOLD_ITALIC); // for Bold and Italic

XML:

Puede configurar directamente en un archivo XML como:

android:textStyle="normal"
android:textStyle="normal|bold"
android:textStyle="normal|italic"
android:textStyle="bold"
android:textStyle="bold|italic"

  • Tenga en cuenta que esta solución siempre subraya todo el texto, por lo que no es factible en los casos en que se desea subrayar solo una parte del mismo.

    – Giulio Piancastelli

    02/04/2014 a las 18:15

Si estás leyendo ese texto desde un archivo o desde la red.

Puede lograrlo agregando etiquetas HTML a su texto como se mencionó

This text is <i>italic</i> and <b>bold</b>
and <u>underlined</u> <b><i><u>bolditalicunderlined</u></b></i>

y luego puedes usar el HTML clase que procesa cadenas HTML en texto con estilo visualizable.

// textString is the String after you retrieve it from the file
textView.setText(Html.fromHtml(textString));

  • El método fromHtml(String) quedó en desuso en el nivel de API 24. Más discusión aquí: stackoverflow.com/questions/37904739/…

    – Pavel Biryukov

    23 de octubre de 2017 a las 9:34

¿Ha sido útil esta solución?

Esta web utiliza cookies propias y de terceros para su correcto funcionamiento y para fines analíticos y para mostrarte publicidad relacionada con sus preferencias en base a un perfil elaborado a partir de tus hábitos de navegación. Al hacer clic en el botón Aceptar, acepta el uso de estas tecnologías y el procesamiento de tus datos para estos propósitos. Configurar y más información
Privacidad