如何解决约束布局准则百分比屏幕尺寸不起作用
我的布局具有类似组件树的层次结构
主要约束布局> 子 ImageView 子嵌套约束布局>约束 布局
图片的顶部限制为20%,底部限制为50%,而嵌套布局的限制为30%。
我的逻辑是图像底部约束的差异-嵌套布局视图的约束是
50-30 = 20%
因此,如果我将我的 TextView 放在嵌套布局中且约束20%,则> nestedScrollView 的约束布局中的 TextView 应该适合 位于父约束布局的图像视图下方。
但是,当我在4“,5”和6“的Mobile中测试此逻辑时,约束准则百分比似乎消失了,并且在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>
解决方法
您可能已经知道,尽管定义了NestedScrollView
属性,但layout_height="match_patrent"
中的布局会根据其内容扩展其高度。知道您应该找到一个替代方案来在NestedScrollView
中建立布局,例如使用绝对尺寸值而不是百分比。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。