web-dev-qa-db-fra.com

Pour dessiner un soulignement sous TextView dans Android

Je veux dessiner le soulignement sous mon TextView. J'ai cherché quelques contenus mais je n'ai rien trouvé de fructueux.

Quelqu'un peut-il m'aider s'il vous plaît ici?

104
David Brown

Il y a trois façons de souligner le texte dans TextView.

  1. SpannableString

  2. setPaintFlags (); de TextView

  3. Html.fromHtml ();

Laissez-moi vous expliquer toutes les approches:

1ère approche

Pour souligner le texte dans TextView, vous devez utiliser SpannableString

String udata="Underlined Text";
SpannableString content = new SpannableString(udata);
content.setSpan(new UnderlineSpan(), 0, udata.length(), 0);
mTextView.setText(content);

2ème approche

Vous pouvez utiliser la méthode setPaintFlags de TextView pour souligner le texte de TextView.

Pour par exemple.

mTextView.setPaintFlags(mTextView.getPaintFlags() | Paint.UNDERLINE_TEXT_FLAG);
mTextView.setText("This text will be underlined");

Vous pouvez faire référence aux constantes de Paint class si vous souhaitez insérer des caractères dans le texte.

3ème approche

Utiliser Html.fromHtml(htmlString);

String htmlString="<u>This text will be underlined</u>";
mTextView.setText(Html.fromHtml(htmlString));

[~ # ~] ou [~ # ~]

txtView.setText(Html.fromHtml("<u>underlined</u> text"));
300
Kartik Domadiya

entourez simplement votre texte avec la balise <u> dans votre fichier de ressources string.xml

<string name="your_string"><u>Underlined text</u></string>

et dans votre activité/fragment

mTextView.setText(R.string.your_string);
38
Sarpe

Cela fonctionne pour moi.

tv.setPaintFlags(Paint.UNDERLINE_TEXT_FLAG);
15
mani

Pour ceux qui regardent encore cette querstion. Ceci est pour un lien hypertexte mais vous pouvez le modifier pour un simple soulignement:

Créez un dessin (hyperlink_underline.xml):

<layer-list xmlns:Android="http://schemas.Android.com/apk/res/Android">
  <item Android:top="-10dp"
        Android:left="-10dp"
        Android:right="-10dp">
    <shape Android:shape="rectangle">
      <solid Android:color="@Android:color/transparent"/>

      <stroke Android:width="2dp"
              Android:color="#3498db"/>
    </shape>
  </item>
</layer-list>

Créer un nouveau style:

<style name="Hyperlink">
    <item name="Android:textColor">#3498db</item>
    <item name="Android:background">@drawable/hyperlink_underline</item>
  </style>

Ensuite, utilisez ce style sur votre TextView:

<TextView
    Android:layout_height="wrap_content"
    Android:layout_width="wrap_content"
    local:MvxBind="Text Id; Click ShowJobInfoCommand"
    style="@style/HyperLink"/>
9
Daniel Fowler

underline a textview in Android

5 façons étonnantes de souligner un TextView dans Android - Kotlin/Java & XML

  1. String html = "<u>Underline using Html.fromHtml()</u>"; textview.setText(Html.fromHtml(html));

Mais Html.fromHtml (ressource String) était obsolète dans l'API 24.

Ainsi, vous pouvez utiliser la dernière Android bibliothèque de support androidx.core.text.HtmlCompat . Avant cela, vous devez inclure la dépendance dans votre projet.

`implementation 'androidx.core:core:1.0.1'`
  1. String html = "<u> 1.1 Underline using HtmlCompat.fromHtml()</u>"; //underline textview using HtmlCompat.fromHtml() method textview11.setText(HtmlCompat.fromHtml(html, HtmlCompat.FROM_HTML_MODE_LEGACY));

Utilisation de strings.xml ,

  1. <string name="underline_text">1.3 &lt;u>Underline using HtmlCompat.fromHtml() and string resource&lt;/u></string>

textview13.setText(HtmlCompat.fromHtml(getString(R.string.underline_text), HtmlCompat.FROM_HTML_MODE_LEGACY));

à l'aide de PaintFlags

  1. textview2.setPaintFlags(textview2.getPaintFlags() | Paint.UNDERLINE_TEXT_FLAG); textview2.setText("2. Underline using setPaintFlags()");

en utilisant SpannableString

`String content1 = "3.1 Underline using SpannableString";
        SpannableString spannableString1 = new SpannableString(content1);
        spannableString1.setSpan(new UnderlineSpan(), 0, content1.length(), 0);
        textview31.setText(spannableString1);`
4
Vijay Ram

Une solution simple et durable consiste à créer une liste de calques et à en faire l’arrière-plan de votre TextView:

<layer-list xmlns:Android="http://schemas.Android.com/apk/res/Android">
    <item
        Android:left="-5dp"
        Android:right="-5dp"
        Android:top="-5dp">
        <shape>
            <stroke
                Android:width="1.5dp"
                Android:color="@color/colorAccent" />
        </shape>
    </item>
</layer-list>
2
Darush

Si votre TextView a une largeur fixe, une autre solution peut être de créer une vue qui ressemblera à un soulignement et de la positionner juste en dessous de votre TextView.

<RelativeLayout
   Android:layout_width="match_parent"
   Android:layout_height="match_parent">

        <TextView
            Android:id="@+id/myTextView"
            Android:layout_width="20dp"
            Android:layout_height="wrap_content"/>

        <View
            Android:layout_width="20dp"
            Android:layout_height="1dp"
            Android:layout_below="@+id/myTextView"
            Android:background="#CCCCCC"/>
</RelativeLayout>
1
Lera