Значок рядом с текстовым полем - PullRequest
0 голосов
/ 10 февраля 2020

Мне нужно отобразить значок рядом с текстовым полем, например, значок человека и телефона на этом снимке экрана ( источник ) enter image description here

Есть ли какой-либо компонент на Android для этого или мне нужно выровнять и значок, и текстовое поле вручную, например, в макете ограничения? Обратите внимание, что мне нужен значок рядом с текстовым полем (как показано на снимке экрана), а не внутри него.

Ответы [ 8 ]

2 голосов
/ 10 февраля 2020

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

Вы можете создать макет выше, используя Relative Layout или Linear Layout.

. Вам нужно использовать ImageView и Editext для создания макета.

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">


    <ImageView
        android:id="@+id/imageView"
        android:layout_width="40dp"
        android:layout_height="40dp"
        android:layout_marginStart="20dp"
        android:layout_marginTop="25dp"
        android:contentDescription="Person Name"
        android:layout_alignParentStart="true"
        android:src="@drawable/ic_action_name" />

    <EditText
        android:id="@+id/editText"
        android:layout_width="match_parent"
        android:layout_height="60dp"
        android:layout_marginStart="20dp"
        android:layout_marginTop="16dp"
        android:layout_marginEnd="20dp"
        android:layout_toEndOf="@id/imageView"
        android:background="@drawable/border"
        android:ems="10"
        android:hint="Name"
        android:paddingStart="10dp"
        android:paddingEnd="10dp"
        android:inputType="textPersonName"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        android:layout_marginBottom="10dp"/>
</RelativeLayout>

Граница для рисования:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">

    <solid
        android:color="#ffffff"/>
    <stroke
        android:width="1dp"
        android:color="#222222"></stroke>

    <corners
        android:radius="10dp"></corners>

</shape>
1 голос
/ 10 февраля 2020

К сожалению, нет компонента с желаемой спецификой, единственный способ добиться этого - вручную настроить ImageView с TextInputLayout. На мой взгляд, лучший способ сделать это - использовать ConstraintLayout. Вы можете прочитать о ConstraintLayout здесь

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

Скопируйте и вставьте следующий код в ваш файл xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="match_parent">
    <LinearLayout
        android:id="@+id/linear1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        android:layout_margin="10dp">

        <ImageView
            android:id="@+id/imgPerson"
            android:layout_width="45dp"
            android:layout_height="45dp"
            android:src="@drawable/ic_person"
            android:layout_margin="5dp"
            android:padding="5dp"></ImageView>
        <EditText
            android:id="@+id/namePerson"
            android:layout_width="match_parent"
            android:layout_height="45dp"
            android:hint="Name"
            android:layout_margin="5dp"
            android:background="@drawable/box_style"
            android:padding="8dp"></EditText>
    </LinearLayout>

    <LinearLayout
        android:id="@+id/linear2"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        android:weightSum="3"
        android:layout_margin="10dp">

        <ImageView
            android:id="@+id/imgPhone"
            android:layout_width="0dp"
            android:layout_weight="0.5"
            android:layout_height="45dp"
            android:src="@drawable/ic_phone"
            android:layout_margin="5dp"
            android:padding="5dp"></ImageView>
        <EditText
            android:id="@+id/phoneNumber"
            android:layout_width="0dp"
            android:layout_weight="1.75"
            android:layout_height="45dp"
            android:hint="Phone"
            android:layout_margin="5dp"
            android:background="@drawable/box_style"
            android:padding="8dp"></EditText>
        <Spinner
            android:id="@+id/areaCode"
            android:layout_width="wrap_content"
            android:layout_height="45dp"
            android:layout_weight="0.75"
            android:layout_margin="5dp"
            android:background="@drawable/box_style"
            android:padding="8dp"></Spinner>
    </LinearLayout>

</LinearLayout>

Для стиля коробки скопируйте и вставьте следующий код в файл xml:

<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">

    <stroke
        android:width="1.5dp"
        android:color="@android:color/darker_gray" />

    <corners
        android:radius="4dp" />

</shape>

Приветствия. Счастливого кодирования

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

используйте это для EditText

android:drawableLeft="@drawable/card"
1 голос
/ 10 февраля 2020

Вы можете достичь этого, используя:

Ваша деятельность :

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:gravity="center_vertical">

<ImageButton
    android:layout_width="0dp"
    android:layout_height="match_parent"
    android:layout_weight="1"
    android:background="?attr/selectableItemBackgroundBorderless"
    android:src="@drawable/ic_phone" --> phone drawable
    android:tint="@color/gray"/>

<EditText
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    android:layout_margin="5dp"
    android:layout_weight="9"
    android:background="@drawable/et_style" --> this is custom drawable for EditText
    android:padding="20dp" />

et_style. xml

<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle">


<solid android:color="@color/white" />
<corners android:radius="10dp" />
<stroke
    android:width="1dp"
    android:color="@color/gray" />

enter image description here

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

Нет, по умолчанию нет компонента, кроме использования атрибута "drawable_left" в тексте редактирования. Который, как правило, никогда не выглядит так, как ожидалось.

В настоящее время рекомендуется в этой ситуации вручную добавлять ImageView к макету.

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

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="horizontal">
    <ImageView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/ic_person"
        android:layout_gravity="center_vertical"/>
    <EditText
        android:layout_width="match_parent"
        android:layout_height="wrap_content"/>
</LinearLayout>
1 голос
/ 10 февраля 2020

это не в текстовом поле редактирования, а в виде изображения, вы можете использовать imageview, чтобы установить эти значки перед textView, и если вы хотите показать изображение в textView, вы можете использовать drawableSart в xml

0 голосов
/ 10 февраля 2020

Нет компонента по умолчанию в Android, как вы упомянули в снимке, но для этого вы можете попробовать этот способ constraintLayoutTesting. xml

<?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"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent">


    <ImageView
        android:id="@+id/imgPerson"
        android:layout_width="wrap_content"
        android:layout_height="0dp"
        android:layout_marginStart="15dp"
        android:layout_marginLeft="15dp"
        android:layout_marginTop="15dp"
        android:layout_marginEnd="10dp"
        android:layout_marginRight="10dp"
        android:layout_marginBottom="30dp"
        android:padding="5dp"
        android:src="@drawable/icon_storage"
        android:tint="@color/colorAccent"
        app:layout_constraintBottom_toTopOf="@+id/imgPhone"
        app:layout_constraintEnd_toStartOf="@+id/edtNamePerson"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <EditText
        android:id="@+id/edtNamePerson"
        android:layout_width="0dp"
        android:layout_height="0dp"
        android:layout_marginTop="15dp"
        android:layout_marginEnd="14dp"
        android:layout_marginRight="14dp"
        android:layout_marginBottom="30dp"
        android:background="@drawable/round_corner_border"
        android:hint="Name"
        android:padding="8dp"
        app:layout_constraintBottom_toTopOf="@+id/spAreaCode"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toEndOf="@+id/imgPerson"
        app:layout_constraintTop_toTopOf="parent" />


    <ImageView
        android:id="@+id/imgPhone"
        android:layout_width="wrap_content"
        android:layout_height="0dp"
        android:layout_marginStart="15dp"
        android:layout_marginLeft="15dp"
        android:layout_marginEnd="10dp"
        android:layout_marginRight="10dp"
        android:layout_marginBottom="596dp"
        android:padding="5dp"
        android:src="@drawable/icon_authentication"
        android:tint="@color/colorAccent"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toStartOf="@+id/edtPhoneNumber"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/imgPerson" />

    <EditText
        android:id="@+id/edtPhoneNumber"
        android:layout_width="0dp"
        android:layout_height="0dp"
        android:layout_marginEnd="10dp"
        android:layout_marginRight="10dp"
        android:background="@drawable/round_corner_border"
        android:hint="Phone"
        android:padding="8dp"
        app:layout_constraintBottom_toBottomOf="@+id/imgPhone"
        app:layout_constraintEnd_toStartOf="@+id/spAreaCode"
        app:layout_constraintStart_toEndOf="@+id/imgPhone"
        app:layout_constraintTop_toTopOf="@+id/imgPhone" />

    <Spinner
        android:id="@+id/spAreaCode"
        android:layout_width="0dp"
        android:layout_height="0dp"
        android:layout_marginEnd="14dp"
        android:layout_marginRight="14dp"
        android:layout_marginBottom="596dp"
        android:background="@drawable/round_corner_border"
        android:padding="8dp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toEndOf="@+id/edtPhoneNumber"
        app:layout_constraintTop_toBottomOf="@+id/edtNamePerson" />


</androidx.constraintlayout.widget.ConstraintLayout>

round_corner_border. xml

<?xml version="1.0" encoding="utf-8"?>
<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">

    <stroke
        android:width="1dp"
        android:color="@android:color/darker_gray" />

    <corners
        android:radius="5dp" />

</shape>

Кроме того, я приложил скриншот моего тестового кода, чтобы вы могли получить лучшее представление.

enter image description here

...