Android 剪辑到背景

Android clip to background

我有以下可绘制对象 squared_card_background.xml,我希望将其用作不同视图的背景,并让视图子项以及视图本身在之后被剪裁。

squared_card_background_left.xml

<?xml version="1.0" encoding="utf-8"?>
<vector xmlns:android="http://schemas.android.com/apk/res/android"
    android:height="16dp"
    android:width="16dp"
    android:viewportHeight="1"
    android:viewportWidth="1">
    <path
        android:name="left"
        android:fillColor="@color/colorSurface"
        android:pathData="M0,1 L1,0 L1,1z" />
    <clip-path android:name="leftClip"
        android:pathData="M0,1 L1,0 L1,1z"/>
</vector>

squared_card_background_right.xml

<?xml version="1.0" encoding="utf-8"?>
<vector xmlns:android="http://schemas.android.com/apk/res/android"
    android:height="16dp"
    android:width="16dp"
    android:viewportHeight="1"
    android:viewportWidth="1" >
    <path
        android:name="v"
        android:fillColor="@color/colorSurface"
        android:pathData="M1,1 L0,0 L0,1z" />
</vector>

squared_card_background.xml

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:gravity="fill|top|clip_horizontal|clip_vertical"
        android:start="16dp"
        android:end="16dp"
        android:height="16dp">
        <shape android:shape="rectangle"
            android:useLevel="false">
            <solid android:color="@color/colorSurface"/>
        </shape>
    </item>
    <item android:drawable="@drawable/squared_card_background_left"
        android:gravity="start|top|clip_horizontal|clip_vertical"
        android:height="16dp"
        android:width="16dp">
    </item>
    <item android:drawable="@drawable/squared_card_background_right"
        android:gravity="end|top|clip_horizontal|clip_vertical"
        android:height="16dp"
        android:width="16dp">
    </item>
    <item android:top="16dp">
        <color android:color="@color/colorSurface"/>
        <scale android:scaleGravity="fill"/>
    </item>
</layer-list>

我试过将视图设置为剪裁儿童和轮廓背景,但它似乎无法识别正确的剪裁路径,有什么想法吗?

我当前尝试设置视图背景的布局。

<?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"
    android:background="@color/colorBackground"
    android:orientation="vertical">

    <com.mobile.indico.indicomobile.views.Toolbar
        android:id="@+id/sync_toolbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:toolbarTitle="@string/title_sync"
        app:showNavigationIcon="false"
        app:layout_constraintTop_toTopOf="parent">
        <ImageButton
            android:id="@+id/sync_start"
            android:layout_width="56dp"
            android:layout_height="56dp"
            android:layout_alignParentStart="true"
            android:layout_alignParentTop="true"
            android:background="@drawable/preview_button_background"
            android:tint="@color/colorOnPrimary"
            android:src="@drawable/ic_refresh_white"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintTop_toTopOf="parent"
            app:layout_constraintBottom_toBottomOf="parent"/>
    </com.mobile.indico.indicomobile.views.Toolbar>

    <android.support.v7.widget.RecyclerView
        android:id="@+id/sync_recycler"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        app:layout_constraintTop_toBottomOf="@id/sync_toolbar"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintBottom_toBottomOf="parent"
        android:background="@drawable/squared_card_background"
        android:clipChildren="true"/>
</android.support.constraint.ConstraintLayout>

最后,我尝试创建一个父 FrameLayout 将单个子项剪裁到背景,但结果相同,我不知道如何从可绘制对象创建剪裁路径并插入到 onDraw 方法中.

最终使用了这个...我猜感谢您的反对意见

override fun onDraw(canvas: Canvas?) = super.onDraw(canvas?.also {
        it.clipPath(Path().apply{
            moveTo(0f, height.toFloat())
            lineTo(0f, _cornerRadius)
            lineTo(_cornerRadius, 0f)
            lineTo(width - _cornerRadius, 0f)
            lineTo(width.toFloat(), _cornerRadius)
            lineTo(width.toFloat(), height.toFloat())
            lineTo(0f, height.toFloat())
            close()
        })
    })