使用Barrier对齐ConstraintLayout几个控件的最高的一个

前提就是想让一个控件X,对齐A,B,C等控件最高的位置,直接看图。

看,由于name的一行,或者2行,会导致email行的高度,可能比image块高,也可能比image快矮。

那么,往下的控件我该如何实现呢?

xml 复制代码
           <ImageView
            android:id="@+id/image"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toTopOf="parent"
            android:layout_width="65dp"
            android:layout_height="65dp"/>

        <TextView
            android:id="@+id/name"
            app:layout_constraintStart_toEndOf="@id/image"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintTop_toTopOf="@id/image"
            android:layout_marginStart="16dp"
            android:layout_width="0dp"
            android:maxLines="2"
            android:ellipsize="end"
            android:layout_height="wrap_content"
            tools:text="This is a looog name here for this name"/>

        <TextView
            android:id="@+id/email"
            app:layout_constraintStart_toEndOf="@id/image"
            app:layout_constraintEnd_toEndOf="parent"
            android:layout_marginStart="16dp"
            android:textSize="16dp"
            android:layout_width="0dp"
            android:maxLines="1"
            android:ellipsize="end"
            android:layout_height="wrap_content"
            app:layout_constraintTop_toBottomOf="@id/name"
            android:layout_marginTop="4dp"
            tools:text="[email protected]" />

        <androidx.constraintlayout.widget.Barrier
            android:id="@+id/lowestBarrier"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            app:barrierDirection="bottom"
            app:constraint_referenced_ids="image,email" />

		<View
            android:layout_marginTop="12dp"
            app:layout_constraintTop_toBottomOf="@id/lowestBarrier"
			...>

使用Barrier对齐ConstraintLayout几个控件的最高的一个。如上图虚线处,就是Barrier的位置。下面的控件就可以根据Barrier位置来做对齐了。

相关推荐
恋猫de小郭1 小时前
React Native 0.80 开始支持 iOS 预构建
android·前端·flutter
移动开发者1号1 小时前
Kotlin实现文件下载断点续传(RandomAccessFile全解析)
android·kotlin
张风捷特烈1 小时前
每日一题 Flutter#11 | StatelessWidget 从诞生到 build 的流程
android·flutter·面试
移动开发者1号1 小时前
Gson TypeAdapter处理复杂JSON结构
android·kotlin
积跬步DEV9 小时前
Android 获取签名 keystore 的 SHA1和MD5值
android
陈旭金-小金子11 小时前
发现 Kotlin MultiPlatform 的一点小变化
android·开发语言·kotlin
二流小码农13 小时前
鸿蒙开发:DevEcoStudio中的代码提取
android·ios·harmonyos
江湖有缘13 小时前
使用obsutil工具在OBS上完成基本的数据存取【玩转华为云】
android·java·华为云
移动开发者1号15 小时前
Android 多 BaseUrl 动态切换策略(结合 ServiceManager 实现)
android·kotlin
移动开发者1号15 小时前
Kotlin实现文件上传进度监听:RequestBody封装详解
android·kotlin