【问题标题】:Android Constraint Layout chain with fixed height view and other to fill space具有固定高度视图和其他填充空间的 Android 约束布局链
【发布时间】:2020-03-13 02:24:38
【问题描述】:

我正在尝试创建一个聊天窗口,顶部有聊天消息(TextView),下面有一个聊天选择器/输入框(Spinner/EditText)。我的目标是微调器/editText 的高度为 30dp。我希望 TextView 填充剩余空间。

这是我得到的最接近的。当我尝试在 EditText 上硬编码 30dp 高度时,它会中断。任何帮助将不胜感激。

<?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"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <TextView
        android:id="@+id/textView"
        android:layout_width="0dp"
        android:layout_height="0dp"
        android:layout_marginStart="2dp"
        android:layout_marginTop="2dp"
        android:layout_marginEnd="2dp"
        android:text="This should fill height"
        app:layout_constraintBottom_toTopOf="@id/editText"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_chainStyle="spread" />

    <Spinner
        android:id="@+id/spinner"
        android:layout_width="wrap_content"
        android:layout_height="0dp"
        android:layout_marginStart="2dp"
        android:layout_marginTop="2dp"
        android:layout_marginBottom="2dp"
        app:layout_constraintBottom_toBottomOf="@id/editText"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="@id/editText" />

    <EditText
        android:id="@+id/editText"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginStart="2dp"
        android:layout_marginBottom="2dp"
        android:text="This should be 30dp tall"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toEndOf="@+id/spinner"
        app:layout_constraintTop_toBottomOf="@+id/textView" />
</android.support.constraint.ConstraintLayout>

【问题讨论】:

  • 你是什么意思“打破”?
  • 底部项目在高度方面缩小到没有
  • 如果用户想输入多行,它将如何工作?如果你给定高度,它就行不通了......
  • 我的游戏中的编辑文本限制为 80 个字符(单行)。
  • @KisnardOnline 他说的是高度而不是字符串的宽度/长度

标签: android android-layout android-constraintlayout constraint-layout-chains


【解决方案1】:

请不要再使用支持库,转用 AndroidX。

我建议不要为 EditTexts 使用预设高度,因为它可能会导致像这样剪切文本:
我建议使用Constraint Guidelines。 例如,像这样的东西:

<androidx.constraintlayout.widget.Guideline
    android:id="@+id/guideline1"
    android:layout_width="0dp"
    android:layout_height="0dp"
    android:orientation="horizontal"
    app:layout_constraintGuide_percent="0.7" />

这将占据屏幕顶部 70% 的位置,现在您可以根据需要限制该指南。

【讨论】:

    【解决方案2】:

    我想你可以用这个。
    首先在gradle中添加这个

     dependencies {
    
    implementation 'androidx.percentlayout:percentlayout:1.0.0'
    
    }
    

    你的布局变成了这个

        <?xml version="1.0" encoding="utf-8"?>
    <androidx.percentlayout.widget.PercentRelativeLayout  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"
        app:layout_behavior="@string/appbar_scrolling_view_behavior"
        android:paddingRight="10dp"
        android:paddingLeft="10dp"
        tools:context=".Cal"
        tools:showIn="@layout/cal">
    
        <TextView
            android:id="@+id/Q1"
            android:layout_width="0dp"
            android:layout_height="0dp"
    
            android:layout_marginTop="10dp"
            android:text="test"
            android:textSize="28sp"
            android:gravity="center"
            app:layout_heightPercent="80%"
            app:layout_widthPercent="100%" />
    
    
             <Spinner
            android:id="@+id/spinner"
            android:layout_width="0dp"
            android:layout_height="30dp"
             android:layout_below="@id/Q1"
    
            app:layout_widthPercent="30%" />
    
        <EditText
            android:id="@+id/editText"
            android:layout_width="0dp"
            android:layout_height="30dp"
             android:layout_below="@id/Q1"
             android:layout_toRightOf="@id/spinner"
    
            app:layout_widthPercent="70%"  />
    
    
    
    </androidx.percentlayout.widget.PercentRelativeLayout >
    

    试试看

    【讨论】:

    • 我可以用开箱即用的约束布局完成 90% 10%。但这也不能让我高 30dp
    • 你可以更改android:layout_height="30dp"并删除这一行app:layout_heightPercent="20%"
    猜你喜欢
    • 2014-06-25
    • 1970-01-01
    • 2018-04-17
    • 2018-08-03
    • 1970-01-01
    • 2017-09-27
    • 2023-01-11
    • 1970-01-01
    • 2020-07-25
    相关资源
    最近更新 更多