按钮的中间未放置在另一个视图的底部
Middle of the button isn't placed to the bottom of another view
我遇到以下情况:我想将我的按钮放在 ImageView 的底部(情况与您在 问题中看到的相同)。我有以下 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>
在问题中,哪个更高,我添加了Coordinator Layout,但它只允许我将FAB放置在头像两侧的角落和中间,而我需要将其放置在底部|端角背景 iv,我在 attribute.But 中指定了它,不幸的是 FAB 没有按需要放置(抱歉这样的背景颜色):
那么,我该如何解决这个问题呢?
在这种情况下,我想将视图放在彼此的顶部,我使用 FrameLayout,并将顶部视图放在 FrameLayout 底部的视图之后
如果你不需要协调器布局,你可以这样做:
<?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>
我有这样的东西
您可以使用 ConstraintLayout 实现此 "view over view" 外观。
下面是一个使用 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>
它看起来像这样:
现在,如果您想水平更改按钮的位置,只需更改一个约束即可。
例如 - 如果您希望按钮与右侧对齐,您可以这样做:
<?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>
它看起来像这样:
请注意:
Different phones got different screen size, in your layout you are using fixed-size on your views and the result is that what may look good on one screen will not look good on another screen.
在我的示例中,我使用的是 wrap_content
而不是固定大小。
我知道使用 wrap_content
也不是响应式布局的理想选择,如果您希望布局响应所有屏幕尺寸,我可以推荐使用 Guidelines
我遇到以下情况:我想将我的按钮放在 ImageView 的底部(情况与您在
<?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>
在问题中,哪个更高,我添加了Coordinator Layout,但它只允许我将FAB放置在头像两侧的角落和中间,而我需要将其放置在底部|端角背景 iv,我在 attribute.But 中指定了它,不幸的是 FAB 没有按需要放置(抱歉这样的背景颜色):
那么,我该如何解决这个问题呢?
在这种情况下,我想将视图放在彼此的顶部,我使用 FrameLayout,并将顶部视图放在 FrameLayout 底部的视图之后
如果你不需要协调器布局,你可以这样做:
<?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>
我有这样的东西
您可以使用 ConstraintLayout 实现此 "view over view" 外观。
下面是一个使用 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>
它看起来像这样:
现在,如果您想水平更改按钮的位置,只需更改一个约束即可。
例如 - 如果您希望按钮与右侧对齐,您可以这样做:
<?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>
它看起来像这样:
请注意:
Different phones got different screen size, in your layout you are using fixed-size on your views and the result is that what may look good on one screen will not look good on another screen.
在我的示例中,我使用的是 wrap_content
而不是固定大小。
我知道使用 wrap_content
也不是响应式布局的理想选择,如果您希望布局响应所有屏幕尺寸,我可以推荐使用 Guidelines