按钮的中间位置没有放在另一个视图的底部

时间:2019-07-18 20:16:51

标签: android xml android-layout android-coordinatorlayout

我有以下情况:我想将按钮放在ImageView的底部(情况与您在this问题中看到的情况相同)。我有以下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"
    tools:context=".ui.profile.ProfileFragment">

    <androidx.coordinatorlayout.widget.CoordinatorLayout
        android:id="@+id/coordinator_layout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent">

        <ImageView
            android:id="@+id/iv_background_avatar"
            android:layout_width="match_parent"
            android:layout_height="350dp"
            android:scaleType="centerCrop"
            android:src="@drawable/profile_background"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toTopOf="parent"
            tools:ignore="ContentDescription" />


        <com.google.android.material.floatingactionbutton.FloatingActionButton
            android:id="@+id/btn_log_out"
            android:layout_width="48dp"
            android:layout_height="48dp"
            android:layout_marginEnd="@dimen/base_margin"
            android:src="@drawable/logout"
            app:layout_anchor="@+id/iv_background_avatar"
            app:layout_anchorGravity="end|bottom" />

    </androidx.coordinatorlayout.widget.CoordinatorLayout>

    <de.hdodenhof.circleimageview.CircleImageView
        android:id="@+id/iv_avatar"
        android:layout_width="300dp"
        android:layout_height="300dp"
        android:layout_marginTop="@dimen/base_margin"
        app:civ_border_color="#000000"
        app:civ_border_width="2dp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        tools:src="@tools:sample/avatars" />

    <TextView
        android:id="@+id/tv_login"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginStart="@dimen/base_margin"
        android:layout_marginTop="@dimen/base_margin"
        android:layout_marginEnd="@dimen/base_margin"
        android:text="@string/login"
        android:textAlignment="center"
        app:layout_constraintTop_toBottomOf="@id/coordinator_layout" />

    <TextView
        android:id="@+id/tv_id"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginStart="@dimen/base_margin"
        android:layout_marginTop="@dimen/base_margin"
        android:layout_marginEnd="@dimen/base_margin"
        android:text="@string/id"
        android:textAlignment="center"
        app:layout_constraintTop_toBottomOf="@id/tv_login" />

    <TextView
        android:id="@+id/tv_email"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginStart="@dimen/base_margin"
        android:layout_marginTop="@dimen/base_margin"
        android:layout_marginEnd="@dimen/base_margin"
        android:autoLink="email"
        android:clickable="true"
        android:focusable="true"
        android:text="@string/email"
        android:textAlignment="center"
        app:layout_constraintTop_toBottomOf="@id/tv_id" />


</androidx.constraintlayout.widget.ConstraintLayout>

就像在更高的问题中一样,我添加了协调器布局,但是它只允许我将FAB放置在头像侧面的角和中间,而我需要将其放置到背景iv的底角。并且我在attribute中指定了它。但是不幸的是,FAB并未按需要放置(很抱歉这样的背景色):

enter image description here

那么,我该如何解决这个问题?

3 个答案:

答案 0 :(得分:1)

如果您不需要协调器布局,可以这样做:

<?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/iv_background_avatar"
        android:layout_width="match_parent"
        android:layout_height="350dp"
        android:scaleType="centerCrop"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        tools:ignore="ContentDescription"/>


<com.google.android.material.floatingactionbutton.FloatingActionButton
        android:id="@+id/btn_log_out"
        android:layout_width="48dp"
        android:layout_height="48dp"
        android:layout_marginEnd="@dimen/base_margin"
        android:src="@drawable/logout"
        app:layout_constraintBottom_toBottomOf="@+id/iv_background_avatar"
        app:layout_constraintTop_toBottomOf="@+id/iv_background_avatar"
        app:layout_constraintEnd_toEndOf="parent"
/>
//There is remaining partof your layout

</androidx.constraintlayout.widget.ConstraintLayout>

我有这样的东西

enter image description here

答案 1 :(得分:1)

您可以使用ConstraintLayout来实现这种“从视图到视图”的外观。

以下是使用ConstraintLayout而不使用固定大小的示例:

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


<android.support.constraint.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"
  android:orientation="vertical">

<Button
    android:id="@+id/button"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginBottom="8dp"
    android:text="FAB"
    app:layout_constraintBottom_toBottomOf="@+id/imageView"
    app:layout_constraintEnd_toEndOf="@+id/imageView"
    app:layout_constraintStart_toStartOf="@+id/imageView"
    app:layout_constraintTop_toBottomOf="@+id/imageView" />

<ImageView
    android:id="@+id/imageView"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginTop="8dp"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintEnd_toEndOf="parent"
    app:layout_constraintHorizontal_bias="0.5"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintTop_toTopOf="parent"
    tools:srcCompat="@tools:sample/avatars[7]" />

</android.support.constraint.ConstraintLayout>

它看起来像这样:

enter image description here

现在,如果要水平更改按钮的位置,只需更改一个约束即可。


例如-,如果您希望按钮与右侧对齐,则可以执行以下操作:

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


<android.support.constraint.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"
  android:orientation="vertical"
 >

<Button
    android:id="@+id/button"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="FAB"
    app:layout_constraintBottom_toBottomOf="@+id/imageView"
    app:layout_constraintEnd_toEndOf="@+id/imageView"
    app:layout_constraintTop_toBottomOf="@+id/imageView" />

<ImageView
    android:id="@+id/imageView"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginTop="8dp"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintEnd_toEndOf="parent"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintTop_toTopOf="parent"
    tools:srcCompat="@tools:sample/avatars[7]" />

</android.support.constraint.ConstraintLayout>

它看起来像这样:

enter image description here


请注意:

  

不同的手机具有不同的屏幕尺寸,在您的布局中,您使用的是固定尺寸的视图,结果是在一个屏幕上看起来不错的东西在另一个屏幕上看起来不好。

在我的示例中,我使用的是wrap_content而不是固定大小。

我知道使用wrap_content也不适合响应式布局,如果您希望您的布局对所有屏幕尺寸都响应,我建议您使用Guidelines

答案 2 :(得分:0)

在这种情况下,我想将视图放置在彼此的顶部,我使用FrameLayout,然后将顶部视图放置在FrameLayout内部底部视图的后面