форма представления текста отображается в виде овала, хотя форма является вихревой - PullRequest
0 голосов
/ 09 февраля 2020

Я создал круглую форму под названием круг. xml:

<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval">
    <solid
        android:color="#FFF" />
    <size
        android:width="5dp"
        android:height="5dp"/>

    <padding
        android:left="5dip"
        android:right="5dip"
        android:top="5dip"
        android:bottom="5dip" />
</shape>

В предварительном просмотре он выглядит круглым, а не овальным. Затем я реализовал это в моем текстовом виде:

<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintStart_toStartOf="parent">
    <Button
        android:id="@+id/addToCartBtn"
        android:layout_width="match_parent"
        android:text="@string/cart_button_text"
        android:textColor="#FFF"
        android:background="@color/colorPrimary"
        android:layout_height="65dp"/>
    <TextView
        android:id="@+id/cartItemsCountTV"
        android:elevation="20dp"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerVertical="true"
        android:layout_marginStart="16dp"
        android:layout_alignStart="@id/addToCartBtn"
        android:text="1"
        android:textSize="16sp"
        android:textStyle="bold"
        android:background="@drawable/circle"/>
</RelativeLayout>

Тогда результат по-прежнему имеет овальную форму:

enter image description here

Форма становится круглым только тогда, когда текст состоит из двух цифр, таких как «10». Почему он овальный, хотя должен быть круглым?

1 Ответ

1 голос
/ 09 февраля 2020

Используйте те же layout_width и layout_height, чтобы сохранить его в виде круга вместо wrap_content.

<TextView
    ....
    android:layout_width="40dp"
    android:layout_height="40dp"
    ..../>

Использование размера представления до wrap_content заставит его расширяться только далеко достаточно, чтобы содержать значения (или дочерние элементы управления), которые он содержит.

...