我有一个布局,它有一个像树一样的组件层次结构
主约束布局>;子图像查看子嵌套约束布局>;约束布局
图像被限制在20%的顶部和50%的底部,而嵌套布局被限制在30%。
我的逻辑是图像嵌套布局视图的底部约束的差异,即
50-30=20%
因此,如果我将TextView放在嵌套布局中,并带有20%的约束>;NestedScrollView的约束布局中的TextView应适合父约束布局的image view的正下方。
但是当我在Mobile中用4“,5”和6“测试这一逻辑时,约束准则百分比似乎不符合要求,TextView的顶部出现了空白。
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/gradient_bck"
android:clickable="true"
android:focusable="true">
<View
android:id="@+id/layout_show_all_gradient_bck"
android:layout_width="0dp"
android:layout_height="0dp"
android:background="@drawable/bck_primary_gradient"
android:visibility="gone"
app:layout_constraintBottom_toBottomOf="@+id/img_top"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<com.google.android.material.imageview.ShapeableImageView
android:id="@+id/img_top"
style="@style/CornerShape10"
android:layout_width="0dp"
android:layout_height="0dp"
android:elevation="1dp"
android:scaleType="centerCrop"
app:layout_constraintBottom_toTopOf="@+id/guideline22"
app:layout_constraintEnd_toStartOf="@+id/guideline26"
app:layout_constraintStart_toStartOf="@+id/guideline25"
app:layout_constraintTop_toTopOf="@+id/guideline9"
app:layout_constraintVertical_bias="1.0"
app:srcCompat="@drawable/test_img" />
<androidx.core.widget.NestedScrollView
android:id="@+id/layout_nested"
android:layout_width="match_parent"
android:layout_height="0dp"
android:background="@drawable/bck_cat_details_view"
android:fillViewport="true"
android:orientation="vertical"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.0"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="@+id/guideline24"
app:layout_constraintVertical_bias="0.0">
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<TextView
android:id="@+id/tv_details"
android:layout_width="0dp"
android:layout_height="wrap_content"
app:layout_constraintEnd_toStartOf="@+id/guideline30"
app:layout_constraintStart_toStartOf="@+id/guideline29"
app:layout_constraintTop_toTopOf="@+id/guideline28"
/>
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_facts"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/txt_facts"
app:layout_constraintStart_toStartOf="@+id/guideline29"
app:layout_constraintTop_toBottomOf="@+id/tv_test_details"
app:textAllCaps="true" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_msg_facts"
android:layout_width="0dp"
android:layout_height="wrap_content"
app:layout_constraintEnd_toStartOf="@+id/guideline30"
app:layout_constraintStart_toStartOf="@+id/guideline29"
app:layout_constraintTop_toBottomOf="@+id/tv_facts"
/>
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="TITLE"
app:layout_constraintStart_toStartOf="@+id/guideline29"
app:layout_constraintTop_toBottomOf="@+id/tv_msg_facts"
app:textAllCaps="true" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_msg_title"
android:layout_width="0dp"
android:layout_height="wrap_content"
app:layout_constraintEnd_toStartOf="@+id/guideline30"
app:layout_constraintStart_toStartOf="@+id/guideline29"
app:layout_constraintTop_toBottomOf="@+id/tv_title"
/>
<Space
android:id="@+id/space_bottom_extra"
android:layout_width="match_parent"
android:layout_height="80dp"
app:layout_constraintTop_toBottomOf="@+id/tv_msg_title" />
<androidx.constraintlayout.widget.Guideline
android:id="@+id/guideline29"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical"
app:layout_constraintGuide_percent="0.10" />
<androidx.constraintlayout.widget.Guideline
android:id="@+id/guideline30"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical"
app:layout_constraintGuide_percent="0.90" />
<androidx.constraintlayout.widget.Guideline
android:id="@+id/guideline31"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
app:layout_constraintGuide_percent="0.73" />
<androidx.constraintlayout.widget.Guideline
android:id="@+id/guideline28"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
app:layout_constraintGuide_percent="0.20" />
</androidx.constraintlayout.widget.ConstraintLayout>
</androidx.core.widget.NestedScrollView>
<androidx.constraintlayout.widget.Guideline
android:id="@+id/guideline9"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
app:layout_constraintGuide_percent="0.20"
app:layout_constraintTop_toTopOf="parent" />
<androidx.constraintlayout.widget.Guideline
android:id="@+id/guideline23"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
app:layout_constraintGuide_percent="0.05" />
<androidx.constraintlayout.widget.Guideline
android:id="@+id/guideline24"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
app:layout_constraintGuide_percent="0.35" />
<androidx.constraintlayout.widget.Guideline
android:id="@+id/guideline22"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
app:layout_constraintGuide_percent="0.5" />
<androidx.constraintlayout.widget.Guideline
android:id="@+id/guideline25"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical"
app:layout_constraintGuide_percent="0.1" />
<androidx.constraintlayout.widget.Guideline
android:id="@+id/guideline26"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical"
app:layout_constraintGuide_percent="0.9" />
<androidx.constraintlayout.widget.Guideline
android:id="@+id/guideline27"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
app:layout_constraintGuide_percent="0.10" />
<androidx.constraintlayout.widget.Guideline
android:id="@+id/guideline32"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
app:layout_constraintGuide_percent="0.92" />
</androidx.constraintlayout.widget.ConstraintLayout>
正如您可能已经想到的那样,尽管定义了layout_height=“match_patrent”
属性,NestedScrollView
中的布局会根据其内容扩展其高度。知道您应该找到替代senario来在NestedScrollView
内部构建布局,例如使用绝对维度值而不是百分比。