• 【约束布局】ConstraintLayout配合Guideline解决两个子控件其中一个被挤出屏幕的问题


    一、需求

            屏幕横向显示文本框A和图标B,A在B的左侧,B紧贴在A的右边显示,文本框A的字数不确定,文本框A的字数足够多时,换行显示,并且保证图标B一直在文本框A的右侧,且不被挤出屏幕。

    二、问题

            本来以为是一个很简单的需求,直接用LinearLayout布局,horizontal横向,因为文本框的长度不确定,所以设置weight权重比例是不合适的。自适应横向排列的话,文本框字数太多就会把后面的图标挤出父布局看不到。还有一个想法,就是TextView设置drawableEnd属性,这种方法是可行的,不过也有弊端,那就是无法控制图标的大小,在不同分辨率的设备上,图标的大小会显示的很不适配。

    三、解决问题

    上面的问题解决的话,方法是比较多,不过需要嵌套布局或者多写一些代码,我觉得最合适的方案,还是使用约束布局ConstraintLayout及其相关的布局和属性来解决。涉及到的布局、属性如下:

    1. app:layout_constrainedWidth="true",让控件的宽度受到约束
    2. Guideline,利用参考线,让后面的ImageView保持在参考线左侧
    3. app:layout_constraintHorizontal_chainStyle,设置为packed,让图标紧贴着文本框
    4. app:layout_constraintHorizontal_bias,横向偏移设置为0,让整体从父布局左边开始

    四、代码

    1. <androidx.constraintlayout.widget.ConstraintLayout
    2. android:layout_width="@dimen/dp_120"
    3. android:layout_height="match_parent">
    4. <TextView
    5. android:id="@+id/tv_labelAndName"
    6. android:layout_width="wrap_content"
    7. android:layout_height="wrap_content"
    8. android:ellipsize="end"
    9. android:lineSpacingMultiplier="0.8"
    10. android:maxLines="2"
    11. android:textColor="@color/color_111111"
    12. android:textSize="@dimen/sp_14"
    13. app:layout_constrainedWidth="true"
    14. app:layout_constraintBottom_toBottomOf="parent"
    15. app:layout_constraintEnd_toStartOf="@id/img_sex"
    16. app:layout_constraintHorizontal_bias="0"
    17. app:layout_constraintHorizontal_chainStyle="packed"
    18. app:layout_constraintStart_toStartOf="parent"
    19. app:layout_constraintTop_toTopOf="parent"
    20. tools:text="0000000002床 特靠谱" />
    21. <ImageView
    22. android:id="@+id/img_sex"
    23. android:layout_width="@dimen/dp_12"
    24. android:layout_height="@dimen/dp_12"
    25. android:src="@mipmap/ic_sex_male"
    26. app:layout_constraintBottom_toBottomOf="parent"
    27. app:layout_constraintEnd_toStartOf="@id/guideline"
    28. app:layout_constraintStart_toEndOf="@id/tv_labelAndName"
    29. app:layout_constraintTop_toTopOf="parent" />
    30. <androidx.constraintlayout.widget.Guideline
    31. android:id="@+id/guideline"
    32. android:layout_width="wrap_content"
    33. android:layout_height="wrap_content"
    34. android:orientation="vertical"
    35. app:layout_constraintGuide_percent="1" />
    36. androidx.constraintlayout.widget.ConstraintLayout>

    关键代码:

    1,TextView

               //让TextView的宽度受到整体的约束,会给ImageView留位置,不把后者挤出去

                app:layout_constrainedWidth="true"

                //让TextView保持在ImageView的左边
                app:layout_constraintEnd_toStartOf="@id/img_sex"

                //TextView开头的链,横向偏移量为0,也就是从父控件的最左端开始
                app:layout_constraintHorizontal_bias="0"

                //将TextView、ImageView设为链,并且是紧贴在一起的
                app:layout_constraintHorizontal_chainStyle="packed"

    2,ImageView

                //让ImageView保持在参考线Guideline左侧,这样才能保证不被挤出父布局外面
                app:layout_constraintEnd_toStartOf="@id/guideline"

                //让ImageView保持在TextView右侧
                app:layout_constraintStart_toEndOf="@id/tv_labelAndName"

    3,Guideline

                //定义参考线的方向,是垂直方向的参考线

                android:orientation="vertical"

                //定义参考线相对父控件的位置,距离父控件起始位置的百分比。因为我们定义了垂直参考线,那么就是距离父控件左端的百分比。0.0表示在父控件最左端无偏移,1表示在父控件的最右端,完全偏移。
                app:layout_constraintGuide_percent="1" 

    调试效果:

  • 相关阅读:
    pom.xml
    高校宿舍系统
    基于Java+SpringBoot制作一个社区宠物登记小程序
    docker 部署tig监控服务
    连续仨月霸占牛客榜首,京东T8呕心巨作:700页JVM虚拟机实战手册
    Linux学习第20天:Linux按键输入驱动开发: 大道至简 量入为出
    命令解压aar、文件压缩成aar图文详解
    80. UE5 RPG 实现UI显示技能冷却进度功能
    独立站运营技巧:如何引流?如何提高转化率
    1.2-断言
  • 原文地址:https://blog.csdn.net/qq_29405933/article/details/133809528