Android 如何使视图填充ConstraintsLayout中的剩余空间
如何使Android 如何使视图填充ConstraintsLayout中的剩余空间,android,android-constraintlayout,Android,Android Constraintlayout,如何使ViewFrameLayout填充ConstraintLayout 我有如下xml: <ImageView android:background="#FF0000" android:id="@+id/header" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/ic_header" andro
View
FrameLayout填充ConstraintLayout
我有如下xml:
<ImageView
android:background="#FF0000"
android:id="@+id/header"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ic_header"
android:scaleType="fitXY"
android:adjustViewBounds="true"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHeight_default="wrap"
app:layout_constraintWidth_default="spread"/>
<FrameLayout
android:background="#00FF00"
app:layout_constraintHeight_default="spread"
app:layout_constraintWidth_default="wrap"
app:layout_constraintTop_toBottomOf="@id/header"
app:layout_constrainedHeight="true"
app:layout_constraintBottom_toTopOf="@id/footer"
android:id="@+id/task_fragment"
android:layout_width="match_parent"
android:layout_height="wrap_content"/>
<LinearLayout
android:background="#FFFF00"
android:orientation="vertical"
android:id="@+id/footer"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHeight_default="spread"
app:layout_constraintWidth_default="spread"
app:layout_constraintBottom_toBottomOf="parent">
<ImageButton
style="?borderlessButtonStyle"
android:id="@+id/btn_ar"
android:layout_height="wrap_content"
android:layout_width="match_parent"
android:padding="0dp"
android:scaleType="fitXY"
android:adjustViewBounds="true"
android:src="@drawable/ic_ar"/>
</LinearLayout>
有页眉、页脚和<代码> FrAMLayayOut[中间,我想使<代码> FrAMLayayOut填充所有剩余空间。 我不明白,我必须使用哪些属性来展开
FrameLayout
。请帮帮我
编辑:或具有不同布局的任何解决方案。此项工作,请使用
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">
<ImageView
android:background="#FF0000"
android:id="@+id/header"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ic_header"
android:minHeight="30dp"
android:scaleType="fitXY"
android:adjustViewBounds="true"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHeight_default="wrap"
app:layout_constraintWidth_default="spread"/>
<FrameLayout
android:id="@+id/task_fragment"
android:layout_width="match_parent"
android:layout_height="0dp"
android:background="#00FF00"
android:orientation="vertical"
app:layout_constrainedHeight="true"
app:layout_constraintBottom_toTopOf="@+id/btn_ar"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHeight_default="spread"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@id/header"
app:layout_constraintWidth_default="wrap">
</FrameLayout>
<ImageButton
android:id="@+id/btn_ar"
style="?borderlessButtonStyle"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:adjustViewBounds="true"
android:padding="0dp"
android:scaleType="fitXY"
android:src="@drawable/ic_ar"
app:layout_constraintBottom_toBottomOf="parent" />
</android.support.constraint.ConstraintLayout>
这应该行得通
说明:
您只需将此FrameLayout约束的顶部设置为页眉的底部,将此FrameLayout约束的底部设置为页脚的顶部
设置所有约束后,仍然需要设置FrameLayout的布局参数以匹配约束。为此,您可以尝试将layout\u height
设置为0dp
。这将使FrameLayout的高度具有匹配约束的效果
有关更多详细信息,您可以查看此文档:(只需搜索关键字
匹配约束
,您就会找到该块),或者只需查看类似的答案:这非常简单。要使任何视图水平或垂直地填满可用空间,只需根据需要将布局宽度
/布局高度
设置为0dp
。要澄清一点,设置0dp后,将顶部设置为父视图的顶部或顶部视图的底部,并将底部设置为父视图的底部或底部视图的顶部。回答很好
<FrameLayout
android:id="@+id/task_fragment"
android:layout_width="match_parent"
android:layout_height="0dp"
android:background="#00FF00"
android:orientation="vertical"
app:layout_constrainedHeight="true"
app:layout_constraintBottom_toTopOf="@+id/btn_ar"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHeight_default="spread"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@id/header"
app:layout_constraintWidth_default="wrap">
</FrameLayout>