如何调整textview的大小以不超出屏幕

Posted

技术标签:

【中文标题】如何调整textview的大小以不超出屏幕【英文标题】:How to size textview to not go outside the screen 【发布时间】:2020-12-27 14:30:55 【问题描述】:

我必须实现一个聊天机器人,但我不知道如何为消息调整文本视图的大小。

我现在拥有的是这个

我希望气球完全适合文本,右边没有白色空白,不使用maxWidth

我的代码是

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

<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_
    android:layout_
    xmlns:app="http://schemas.android.com/apk/res-auto">

    <androidx.appcompat.widget.AppCompatImageView
        android:id="@+id/bot_icon"
        android:layout_
        android:layout_
        android:adjustViewBounds="true"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        android:src="@drawable/ic_botchat"
        android:layout_marginStart="8dp"
        android:layout_marginTop="16dp"
        />

    <androidx.constraintlayout.widget.ConstraintLayout
        android:layout_
        android:layout_
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.0"
        app:layout_constraintStart_toEndOf="@id/bot_icon"
        app:layout_constraintTop_toBottomOf="@id/bot_icon">

        <androidx.appcompat.widget.AppCompatTextView
            android:id="@+id/textMessage"
            android:layout_
            android:layout_
            android:layout_marginEnd="8dp"
            android:background="@drawable/bot_message"
            android:elevation="3dp"
            android:fontFamily="@font/roboto"
            android:paddingStart="16dp"
            android:paddingTop="10dp"
            android:paddingEnd="16dp"
            android:paddingBottom="10dp"
            android:textColor="@color/visia"
            android:textSize="18sp"
            app:layout_constraintTop_toTopOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintEnd_toEndOf="parent"/>

    </androidx.constraintlayout.widget.ConstraintLayout>
</androidx.constraintlayout.widget.ConstraintLayout>

我尝试用wrap_content修改AppCompatTextView中的android:layout_width,但是文本显示在一行中,超出了屏幕。

【问题讨论】:

您需要以这种方式设计您的 .9.png 图像(背景气泡)。 【参考方案1】:

根据this的回答,你不能通过使用默认的TextView来实现你想要的,你需要有一个自定义的文本视图,你可以覆盖onMeasure方法,这样最大宽度就会是你最大的线的宽度。

【讨论】:

【参考方案2】:

使用属性“maxLines”来指定你的文本视图应该有的行数。例如,

android:maxLines="2"

【讨论】:

这不是我问的【参考方案3】:

尝试为文本父级设置宽度并放置文本 wrap_content

【讨论】:

【参考方案4】:

如果您的问题是关于如何删除 textView 中的正确空格,只需删除 textview 属性中的这一行:

app:layout_constraintEnd_toEndOf="parent"

实际上,您将 textview 的末尾绑定到其父节点的末尾,这就是 wrap_content 无法正常运行的原因。所以结果是:

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

<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_
android:layout_
xmlns:app="http://schemas.android.com/apk/res-auto">

<androidx.appcompat.widget.AppCompatImageView
    android:id="@+id/bot_icon"
    android:layout_
    android:layout_
    android:adjustViewBounds="true"
    app:layout_constraintTop_toTopOf="parent"
    app:layout_constraintStart_toStartOf="parent"
    android:src="@drawable/boy_icon"
    android:layout_marginStart="8dp"
    android:layout_marginTop="16dp"
    />

<androidx.constraintlayout.widget.ConstraintLayout
    android:layout_
    android:layout_
    app:layout_constraintEnd_toEndOf="parent"
    app:layout_constraintHorizontal_bias="0.0"
    app:layout_constraintStart_toEndOf="@id/bot_icon"
    app:layout_constraintTop_toBottomOf="@id/bot_icon">

    <androidx.appcompat.widget.AppCompatTextView
        android:id="@+id/textMessage"
        android:layout_
        android:layout_
        android:layout_marginEnd="8dp"
        android:background="@drawable/round_gray_20"
        android:elevation="3dp"
        android:paddingStart="16dp"
        android:paddingTop="10dp"
        android:paddingEnd="16dp"
        android:paddingBottom="10dp"
        android:text="fsdfsdfsdfsdsfsd "
        android:textColor="@color/blackText"
        android:textSize="18sp"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

</androidx.constraintlayout.widget.ConstraintLayout>
</androidx.constraintlayout.widget.ConstraintLayout>

请注意,我可能更改了一些drawables 并使用我的来查看结果。所以相应地将它们还原为原始的。

【讨论】:

不管用 android:layout_ 和 android:layout_ 正如我在布局编辑器中测试的那样,它绝对有效。删除app:layout_constraintEnd_toEndOf="parent"后究竟是什么问题? 我从我发布的代码中删除了结束约束,并更改了气球右侧的边距现在消失了(气球附在屏幕的右侧)。我想要的是“per”右侧气球的白色部分消失,以便气球正好在行尾结束 我编辑了我的答案并添加了xml 代码,我得到了正确的结果表单。正是使用这个xml 并告诉结果。 好的,但请尝试使用此文本“您想要个性化哪个橱柜?”。你会看到在“to”的右边有一个空白区域【参考方案5】:

将您的布局编辑成这样

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_
    android:layout_
    android:background="#D7D7D7">

    <androidx.appcompat.widget.AppCompatImageView
        android:id="@+id/bot_icon"
        android:layout_
        android:layout_
        android:layout_marginStart="8dp"
        android:layout_marginTop="16dp"
        android:adjustViewBounds="true"
        android:src="@drawable/ic_botchat"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <androidx.appcompat.widget.AppCompatTextView
        android:id="@+id/textMessage"
        android:layout_
        android:layout_
        android:layout_marginEnd="8dp"
        android:layout_marginBottom="8dp"
        android:background="@drawable/bot_message"
        android:elevation="3dp"
        android:fontFamily="@font/roboto"
        android:maxLines="2"
        android:paddingStart="16dp"
        android:paddingTop="10dp"
        android:paddingEnd="16dp"
        android:paddingBottom="10dp"
        android:text="Lorem Ipsum."
        android:textColor="@color/visia"
        android:textSize="18sp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.0"
        app:layout_constraintStart_toEndOf="@id/bot_icon"
        app:layout_constraintTop_toBottomOf="@id/bot_icon" />

</androidx.constraintlayout.widget.ConstraintLayout>

然后创建 XML 文件“bot_message.xml”

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
    <corners
        android:bottomLeftRadius="20dp"
        android:bottomRightRadius="20dp"
        android:topLeftRadius="0dp"
        android:topRightRadius="20dp" />

    <solid android:color="#F5F5F5" />

</shape>

【讨论】:

以上是关于如何调整textview的大小以不超出屏幕的主要内容,如果未能解决你的问题,请参考以下文章

Android ConstraintLayout中TextView组件内容过长超出屏幕问题

如果文本字符串小于屏幕大小,则使 textview 选取框

调整视图大小时 textview 抖动

css 如何根据显示器屏幕大小自动调整显示区域

css 如何根据显示器屏幕大小自动调整显示区域

删除 ImageView 自动调整大小