【发布时间】:2020-03-17 11:44:45
【问题描述】:
我想重叠(将图像的一半放在外面)卡片视图。 ShapeableImageView 是卡片视图的子项。
我尝试在卡片视图和子约束布局上添加clipChilder="false",但没有成功。我在运行时也尝试了同样的方法,但没有运气。
布局
<?xml version="1.0" encoding="utf-8"?>
<ScrollView 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"
tools:context=".fragments.ProfileFragment">
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="wrap_content">
<com.codepaints.velvet.views.HeaderView
android:id="@+id/v_profile_header"
android:layout_width="match_parent"
android:layout_height="235dp"
android:src="@drawable/img_profile_bg"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:overlay_color="@color/colorNavHeaderOverlay" />
<com.google.android.material.card.MaterialCardView
android:id="@+id/v_profile_card"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/app_space"
android:layout_marginEnd="@dimen/app_space"
android:clickable="false"
android:focusable="false"
android:translationY="-24dp"
app:cardCornerRadius="@dimen/app_space_h"
app:cardElevation="@dimen/app_shadow_two"
app:layout_constraintTop_toBottomOf="@+id/v_profile_header"
app:layout_constraintBottom_toBottomOf="@id/v_profile_header"
app:layout_constraintEnd_toEndOf="@+id/v_profile_header"
app:layout_constraintStart_toStartOf="@id/v_profile_header"
app:rippleColor="@android:color/transparent">
<androidx.constraintlayout.widget.ConstraintLayout
android:id="@+id/v_profile_card_layout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:clipChildren="false">
<com.google.android.material.imageview.ShapeableImageView
android:id="@+id/v_profile_avatar"
android:layout_width="@dimen/profile_avatar_size"
android:layout_height="@dimen/profile_avatar_size"
android:background="@drawable/shape_circle_border"
android:src="@drawable/img_profile_avatar"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintBottom_toTopOf="parent"/>
<View
android:id="@+id/v_profile_online_status_holder"
android:layout_width="@dimen/app_space"
android:layout_height="@dimen/app_space"
app:layout_constraintEnd_toEndOf="@id/v_profile_avatar"
app:layout_constraintStart_toStartOf="@id/v_profile_avatar"
app:layout_constraintTop_toBottomOf="@+id/v_profile_avatar" />
<View
android:id="@+id/v_profile_online_status"
android:layout_width="@dimen/app_space"
android:layout_height="@dimen/app_space"
android:layout_marginBottom="@dimen/app_space_h"
android:background="@drawable/shape_circle"
android:backgroundTint="@color/colorOnline"
app:layout_constraintBottom_toBottomOf="@id/v_profile_online_status_holder"
app:layout_constraintEnd_toEndOf="@id/v_profile_avatar"
app:layout_constraintStart_toStartOf="@id/v_profile_avatar" />
<TextView
android:id="@+id/v_profile_username"
style="@style/TextAppearance.MaterialComponents.Headline6"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/profile_username"
android:textAlignment="center"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@id/v_profile_avatar" />
<TextView
android:id="@+id/v_profile_qualification"
style="@style/TextAppearance.MaterialComponents.Body2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:drawableStart="@drawable/ic_university"
android:drawablePadding="@dimen/app_space_q"
android:text="@string/profile_qualification"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@id/v_profile_username" />
</androidx.constraintlayout.widget.ConstraintLayout>
</com.google.android.material.card.MaterialCardView>
</androidx.constraintlayout.widget.ConstraintLayout>
</ScrollView>
截图
另一个测试
我试过不使用 MaterialCardView 但结果是一样的。 我不知道为什么它不起作用。
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.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"
tools:context=".fragments.ProfileFragment">
<androidx.constraintlayout.widget.ConstraintLayout
android:id="@+id/v_profile_card"
android:layout_width="match_parent"
android:layout_height="200dp"
android:background="@color/colorAccent"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
android:clipChildren="false"
app:elevation="1dp"
android:clipToPadding="false">
<ImageView
app:elevation="16dp"
android:id="@+id/v_image"
android:layout_width="128dp"
android:layout_height="128dp"
android:src="@drawable/img_profile_avatar"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintBottom_toTopOf="parent"/>
<TextView
android:id="@+id/v_user"
style="@style/TextAppearance.MaterialComponents.Headline4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/profile_username"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/v_image"
android:background="@color/colorNutritionKcal"
android:translationY="60dp"
android:elevation="100dp"/>
</androidx.constraintlayout.widget.ConstraintLayout>
</androidx.constraintlayout.widget.ConstraintLayout>
截图
测试 3
它也不适用于 LinearLayout :(
<LinearLayout
android:orientation="vertical"
android:id="@+id/v_profile_card"
android:layout_width="match_parent"
android:layout_height="200dp"
android:background="@color/colorAccent"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
android:clipChildren="false"
android:elevation="1dp"
android:clipToPadding="false">
<ImageView
android:elevation="@dimen/app_space"
android:id="@+id/v_image"
android:layout_width="128dp"
android:layout_height="128dp"
android:translationY="-60dp"
android:src="@drawable/img_profile_avatar"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintBottom_toTopOf="parent"/>
<TextView
android:id="@+id/v_user"
style="@style/TextAppearance.MaterialComponents.Headline4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/profile_username"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/v_image"
android:background="@color/colorNutritionKcal"
android:translationY="60dp"
android:elevation="100dp"/>
</LinearLayout>
【问题讨论】:
-
将
android:clipChildren="false"添加到您的顶级 ConstraintLayout 并将其删除到其他位置。内部布局太高兴了,无法在框外绘制。剪裁其子级的是顶级组。 -
该选项也不起作用。我想知道这是一个错误,还是它是这样的?
-
我尝试使用
constraintlayout作为根布局而不是ScrollView,如果我有类似ConstraintLayout > ConstraintLayout > ImageView的东西,这似乎可以工作,但在我分享的第一个结构中,没有如果我将clipChildren添加到父约束布局甚至滚动视图中,会有什么不同
标签: android android-constraintlayout android-cardview materialcardview