Вопрос по android – Android, как ограничить ширину TextView (и добавить три точки в конце текста)?

255

у меня естьTextView что я хочу ограничить символы этого. На самом деле, я могу сделать это, но то, что я ищу, - это как добавить три точки (...) в конце строки. Этот показывает, что текст продолжается. Это мой XML, но нет точек, хотя он ограничивает мой текст.

<TextView 
        android:id                      = "@+id/tvFixture"
        android:layout_width            = "wrap_content"
        android:layout_height           = "wrap_content"
        android:layout_toLeftOf         = "@id/ivFixture_Guest"
        android:text                    = "@string/test_06"
        android:lines                   = "1"
        android:ems                     = "3"
        android:gravity                 = "right"
        style                           = "@style/simpletopic.black" 
        android:ellipsize="end"/>

Ваш Ответ

18   ответов
10

например. ты можешь использовать

android:maxLength="13"

это ограничит длину texview до 13, но проблема в том, что если вы попытаетесь добавить 3 точки (...), он не будет отображаться, так как это будет частью длины textview.

     String userName;
     if (data.length() >= 13) {
            userName = data.substring(0, 13)+ "...";

     } else {

            userName = data;

    }
        textView.setText(userName);

кроме этого вы должны использовать

 android:maxLines="1"
Error: User Rate Limit Exceeded
Error: User Rate Limit Exceeded
Error: User Rate Limit Exceeded
1

Подход @AzharShaikh работает отлично.

android:ellipsize="end"
android:maxLines="1"

Но я понимаю беду, что TextView будет усечен по слову (по умолчанию). Показать, если у нас есть текст, как:

test long_line_without_any_space_abcdefgh

TextView отобразит:

test...

И я нашел решение, чтобы справиться с этой проблемой, заменив пробелы символом пробела Unicode без пробелов, это делает TextView переносом на символы вместо слов:

yourString.replace(" ", "\u00A0");

Результат:

test long_line_without_any_space_abc...

2

Я думаю, что вы даете фиксировать высоту и ширину просмотра текста. Тогда ваше решение будет работать.

30

Я так понимаю, вы хотите ограничить ширину одной строкой, а не ограничить ее символом? посколькуsingleLine устарела, вы можете попробовать использовать следующее вместе:

android:maxLines="1"
android:scrollHorizontally="true"
android:ellipsize="end"
2

Вы можете написать эту строку в XML, где вы беретеtextview :

android:singleLine="true"
4

Вы можете ограничить количество символов в вашем текстовом просмотре и добавить (...) после текста. Предположим, вам нужно показать только 5 букв, а затем вам нужно показать (...), просто сделайте следующее:

String YourString = "abcdefghijk";

if(YourString.length()>5){

YourString  =  YourString.substring(0,4)+"...";

your_text_view.setText(YourString);
}else{

 your_text_view.setText(YourString); //Dont do any change

}

немного взломать ^ _ ^. Хотя это не очень хорошее решение. Но работа вокруг которой работала для меня: D

EDIT: Я добавил проверку на меньшее количество персонажей согласно вашему ограниченному номеру. персонажей.

It's already explained here
Error: User Rate Limit Exceeded
0

использование

  • android:singleLine="true"
  • android:maxLines="1"
  • app:layout_constrainedWidth="true"

Это как мой полныйTextView выглядит:

    <TextView
    android:id="@+id/message_title"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginStart="5dp"
    android:maxLines="1"
    android:singleLine="true"
    android:text="NAME PLACEHOLDER MORE Text"
    android:textColor="@android:color/black"
    android:textSize="16sp"

    android:textStyle="bold"
    app:layout_constrainedWidth="true"
    app:layout_constraintEnd_toStartOf="@id/message_check_sign"
    app:layout_constraintHorizontal_bias="0"
    app:layout_constraintStart_toEndOf="@id/img_chat_contact"
    app:layout_constraintTop_toTopOf="@id/img_chat_contact" />

Picture of <code>TextView</code>

1

Добавьте эти две строки в свой текст

android:ellipsize="end"
android:singleLine="true"
78

Попробуйте это свойство TextView в вашем файле макета.

android:ellipsize="end"
android:maxLines="1"
4

код:

TextView your_text_view = (TextView) findViewById(R.id.your_id_textview);
your_text_view.setEllipsize(TextUtils.TruncateAt.END);

XML:

android:maxLines = "5"

например

В Евангелии от Матфея 13 ученики спросили Иисуса, почему Он говорил с толпами притчами. Он ответил: «Тебе дано знать тайны Царства Небесного, но им не дано.

Выход: В Евангелии от Матфея 13 ученики спросили Иисуса, почему Он говорил с толпами притчами. Он ответил: «Вам дано знать ...

138

Вот что я узнал, поиграв с различными вариантами форсированияTextView в одну строку (с тремя точками и без них).

enter image description here

android:maxLines="1"

<TextView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:maxLines="1"
    android:text="one two three four five six seven eight nine ten" />

Это просто заставляет текст в одну строку. Любой дополнительный текст скрыт.

Связанные с:

ellipsize="end"

<TextView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:maxLines="1"
    android:ellipsize="end"
    android:text="one two three four five six seven eight nine ten" />

Это обрезает текст, который не помещается, но позволяет пользователям узнать, что текст был усечен путем добавления многоточия (трех точек).

Связанные с:

ellipsize="marquee"

<TextView
    android:id="@+id/MarqueeText"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:maxLines="1"
    android:singleLine="true"
    android:ellipsize="marquee"
    android:focusable="true"
    android:focusableInTouchMode="true"
    android:text="one two three four five six seven eight nine ten" />

Это заставляет текст прокручиваться автоматически через TextView. Обратите внимание, чтоиногда это должно быть установлено в коде:

textView.setSelected(true);

предположительноandroid:maxLines="1" а такжеandroid:singleLine="true" должен делать в основном то же самое, и так как SingleLine являетсяочевидно, устарела Я предпочел бы не использовать его, но когда я вынимаю его, выделение больше не прокручивается. принятиеmaxLines однако, это не влияет на это.

Связанные с:

HorizontalScrollView with scrollHorizontally

<HorizontalScrollView
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:id="@+id/horizontalScrollView">

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:maxLines="1"
        android:scrollHorizontally="true"
        android:text="one two three four five six seven eight nine ten" />
</HorizontalScrollView>

Это позволяет пользователю прокручивать вручную, чтобы увидеть всю строку текста.

Error: User Rate Limit Exceeded
Error: User Rate Limit ExceededPaint.measureText.
Error: User Rate Limit Exceeded
0

Вы можете сделать это путемxml:

<TextView 
    android:id="@+id/textview"
    android:maxLines="1" // or any number of lines you want
    android:ellipsize="end"
    />
Error: User Rate Limit ExceededDotsError: User Rate Limit ExceededmaxLength="35"Error: User Rate Limit Exceeded
548

Deprecated:

Добавить еще одно свойствоandroid:singleLine="true" в вашем Textview

Updated:

android:ellipsize="end" 
android:maxLines="1"
Error: User Rate Limit Exceeded
Error: User Rate Limit Exceeded
Error: User Rate Limit Exceeded
Error: User Rate Limit ExceededsingleLineError: User Rate Limit ExceededIs the xml attribute singleLine deprecated or not in Android?
Error: User Rate Limit Exceeded
5

Я получил желаемый результат с помощью

android:maxLines="2"
android:minLines="2"
android:ellipsize="end"

Для трюка установлено одинаковое значение для maxLines и minLines ... и не только для android: lines = & quot; 2 & quot ;, не делайте этого трюка. Также вы избегаете любых устаревших атрибутов.

3

Вам нужно добавить следующие строки в ваш макет для просмотра текста

android:maxLines="1"
android:ellipsize="end"
android:singleLine="true"

Надеюсь, что это работает для вас.

0

Вы просто измените

Android: layout_width = & Quot; wrap_content & Quot;

используйте эту строку ниже

Android: layout_width = & Quot; match_parent & Quot;

<LinearLayout
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerVertical="true"
            android:layout_marginLeft="10dp"
            android:layout_marginTop="10dp"
            android:layout_toRightOf="@+id/visitBox"
            android:orientation="vertical" >

            <TextView
                android:id="@+id/txvrequestTitle"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:singleLine="true"
                android:text="Abcdefghighiklmnon"
                android:textAppearance="?android:attr/textAppearanceLarge"
                android:textColor="@color/orange_color" />


        </LinearLayout>
3

Для того, чтобы работать сandroid:ellipsize атрибут, вы должны ограничитьlayout width изTextViewтак, чтоtext выходит за пределы видимости TextView.

Так,android:layout_width Атрибут играет ключевую роль здесь, установите его соответствующим образом.

Одинexample может быть:

<TextView        
    android:layout_width="120dp"
    android:layout_height="wrap_content"
    android:ellipsize="end"
    android:text="This is a very long text to be displayed"
    android:textSize="12sp"
    android:maxLines="1"            
     />

Теперь здесь, еслиtext вandroid:text="This is a very long text to be displayed" выходит из поля зрения из TextView сandroid:layout_width="120dp", android:ellipsize="end" будет усекатьtext и место...(3 dots) после этого. то естьThis is very long... будет отображаться в TextView.

4

Я использую Horizonal Recyclerview.
1) Здесь, в CardView, TextView искажается по вертикали при использовании

android:ellipsize="end"
android:maxLines="1"

Проверьте смелый TextViews Wyman Group, Jaskolski ... enter image description here

2) Но когда я использовал SingleLine вместе с Ellipsize -

android:ellipsize="end"
android:singleLine="true"

Проверьте смелый TextViews Wyman Group, Jaskolski ... enter image description here

2-е решение сработало у меня правильно (с помощью singleLine). Также я протестировал в версии ОС: 4.1 и выше (до 8.0), она работает нормально, без сбоев.

Похожие вопросы