android поместил кнопку на краю поля зрения

#android #xml #android-constraintlayout #floating-action-button

Вопрос:

Примерный вид

Я пытаюсь добавить floating action button » а «в углу image view » а » как таковое. Я просмотрел все текущие решения в stackoverflow, но ответы, с которыми я столкнулся, не были подробными и содержали только широкую информацию, такую как «использовать привязку макета» или «использовать макет фрейма». Как бы я это сделал? Кстати, корневой макет, который я использую, — это constraint layout .

Ответ №1:

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

В XML для вашего представления убедитесь, что кнопка находится после вашего серого представления в XML-файле, и установите атрибуты компоновки ограничений кнопки (я дал произвольные значения для layout_width и layout_height:

 ...

<View
    android:layout_width="100dp"
    android:layout_height="100dp"
    android:id="@ id/backrgoundGreyView"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintEnd_toEndOf="parent"
    app:layout_constraintTop_toTopOf="parent"
    app:layout_constraintBottom_toBottomOf="@id/headerMenuButton"/>

<com.google.android.material.floatingactionbutton.FloatingActionButton
    android:layout_width="20dp"
    android:layout_height="20dp"
    app:layout_constraintStart_toEndOf="@id/backgroundGreyView"
    app:layout_constraintEnd_toEndOf="@id/backgroundGreyView"
    app:layout_constraintTop_toBottomOf="@id/backgroundGreyView"
    app:layout_constraintBottom_toBottomOf="@id/backgroundGreyView"/>

...

 

Ответ №2:

Вы можете использовать атрибуты: layout_anchor и layout_anchorGravity , но это работает только внутри CoordinatorLayout

Образец:

   <?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.widget.CoordinatorLayout 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"
    android:orientation="vertical">


<ImageView
    android:id="@ id/imageView"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    tools:srcCompat="@tools:sample/avatars" />

<com.google.android.material.floatingactionbutton.FloatingActionButton
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    app:layout_anchor="@id/imageView"
    app:layout_anchorGravity="end|bottom" />

</androidx.coordinatorlayout.widget.CoordinatorLayout>
 

Это будет выглядеть так:

введите описание изображения здесь

Комментарии:

1. Как бы я добился такого же эффекта при использовании wrap content coordinator layout атрибутов? В настоящее время при использовании wrap content кнопка переходит внутрь imagview . Я хочу сохранить свою базовую компоновку как a constraint layout и вложить a coordinator layout только для этого imageview и button .

2. В качестве обходного пути вы можете добавить margin атрибут в ImageView : <ImageView android:id="@ id/imageView" android:layout_width="wrap_content" android:layout_height="wrap_content" tools:srcCompat="@tools:sample/avatars" android:layout_marginEnd="32dp" android:layout_marginBottom="32dp"/>

Ответ №3:

Вывод: Вывод кода

файл макета:

 <?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_width="match_parent"
    android:layout_height="match_parent"
    android:background="#255177">

<!--Image code-->
<androidx.constraintlayout.widget.ConstraintLayout
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintEnd_toEndOf="parent"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintTop_toTopOf="parent">

    <ImageView
        android:id="@ id/imageView"
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:background="@drawable/round_box"
        android:src="@drawable/demo"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <androidx.cardview.widget.CardView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        app:cardCornerRadius="20dp"
        app:layout_constraintBottom_toBottomOf="@id/imageView"
        app:layout_constraintEnd_toEndOf="@id/imageView"
        app:layout_constraintStart_toEndOf="@id/imageView"
        app:layout_constraintTop_toBottomOf="@id/imageView">

        <ImageView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentRight="true"
            android:layout_alignParentBottom="true"
            android:layout_margin="10dp"
            android:background="@mipmap/edit_pro" />
    </androidx.cardview.widget.CardView>

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

Ответ №4:

Вы можете обернуть как в a ConstraintLayout , так и манипулировать ограничениями в верхней и нижней части таблицы.

Но этого недостаточно для того, чтобы кнопка была включена в изображение, поэтому вы можете добавить эту функцию, масштабируя изображение и/или изображение с android:scaleX помощью amp; android:scaleY и установив размер изображения как мини с помощью app:fabSize="mini"

 <?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_width="wrap_content"
    android:layout_height="wrap_content"
    android:background="#0E153A">

    <ImageView
        android:id="@ id/image"
        android:layout_width="130dp"
        android:layout_height="130dp"
        android:background="@drawable/rect_frame"
        android:scaleX="1.1"
        android:scaleY="1.1"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <com.google.android.material.floatingactionbutton.FloatingActionButton
        android:layout_width="40dp"
        android:layout_height="wrap_content"
        android:backgroundTint="#3D5AF1"
        app:fabSize="mini"
        app:borderWidth="0dp"
        app:layout_constraintBottom_toBottomOf="@id/image"
        app:layout_constraintEnd_toEndOf="@id/image"
        app:layout_constraintStart_toEndOf="@id/image"
        app:layout_constraintTop_toBottomOf="@ id/msimageg"
        app:srcCompat="@drawable/ic_baseline_edit_24"
        app:tint="#FFF" />

</androidx.constraintlayout.widget.ConstraintLayout>
 

введите описание изображения здесь