使用约束布局将图像放在另一个图像的左上角
Placing an image on the top left of another image using Constraint Layout
我正在尝试使用约束布局将图标放置在图像的左上方,但它需要从其两侧的中心偏移。喜欢图片:
这是我目前得到的:
这是最终目标:
这是我的 xml 文件:
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:background="@color/grey_500">
<ImageView
android:id="@+id/iv_landscape_art"
android:layout_width="240dp"
android:layout_height="150dp"
android:layout_marginTop="48dp"
android:elevation="2dp"
android:adjustViewBounds="true"
android:scaleType="centerCrop"
android:background="@android:color/white"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintEnd_toEndOf="parent"/>
<ImageView
android:id="@+id/iv_sold_icon"
android:layout_width="32dp"
android:layout_height="32dp"
android:adjustViewBounds="true"
android:background="@color/colorPrimary"
android:elevation="4dp"
android:scaleType="fitXY"
app:layout_constraintTop_toTopOf="@+id/iv_landscape_art"
app:layout_constraintStart_toStartOf="@id/iv_landscape_art"
app:layout_constraintEnd_toStartOf="@+id/iv_landscape_art"
app:layout_constraintBottom_toTopOf="@+id/iv_landscape_art"/>
我该如何完成?
从较大正方形的左上角偏移较小正方形的最简单方法是应用 X 和 Y 平移。将以下内容添加到较小正方形的 XML 中,看看我的意思。
android:translationX="10dp"
android:translationY="10dp"
另一种偏移较小正方形的方法是在较大正方形的左上角放置一个 Space
小部件,并使 Space
的边长为 48dp
。现在将较小正方形的右侧和底部约束到 Space
小部件的右侧和底部。
我正在尝试使用约束布局将图标放置在图像的左上方,但它需要从其两侧的中心偏移。喜欢图片:
这是我目前得到的:
这是最终目标:
这是我的 xml 文件:
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:background="@color/grey_500">
<ImageView
android:id="@+id/iv_landscape_art"
android:layout_width="240dp"
android:layout_height="150dp"
android:layout_marginTop="48dp"
android:elevation="2dp"
android:adjustViewBounds="true"
android:scaleType="centerCrop"
android:background="@android:color/white"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintEnd_toEndOf="parent"/>
<ImageView
android:id="@+id/iv_sold_icon"
android:layout_width="32dp"
android:layout_height="32dp"
android:adjustViewBounds="true"
android:background="@color/colorPrimary"
android:elevation="4dp"
android:scaleType="fitXY"
app:layout_constraintTop_toTopOf="@+id/iv_landscape_art"
app:layout_constraintStart_toStartOf="@id/iv_landscape_art"
app:layout_constraintEnd_toStartOf="@+id/iv_landscape_art"
app:layout_constraintBottom_toTopOf="@+id/iv_landscape_art"/>
我该如何完成?
从较大正方形的左上角偏移较小正方形的最简单方法是应用 X 和 Y 平移。将以下内容添加到较小正方形的 XML 中,看看我的意思。
android:translationX="10dp"
android:translationY="10dp"
另一种偏移较小正方形的方法是在较大正方形的左上角放置一个 Space
小部件,并使 Space
的边长为 48dp
。现在将较小正方形的右侧和底部约束到 Space
小部件的右侧和底部。