文字描边

Stroke with text

我想知道是否可以创建一个带有笔划作为边框的自定义可绘制对象,并且该笔划包含文本,对于我的问题,请参见我在 Paint 上创建的以下图像。

我创建了一个带笔划的线性布局,笔划上有文字 'Hello World',所以问题又是是否可以创建这种类型的笔划。

您的预期设计可以通过我刚刚编写并检查过的以下代码实现:

首先在drawable中使用自定义背景:bg_gray_rectangle_rounded_corners.xml

<?xml version="1.0" encoding="utf-8"?>
<shape android:shape="rectangle" 
     xmlns:android="http://schemas.android.com/apk/res/android">

    <stroke android:width="1.5dp"
        android:color="@color/colorPrimary"/>

    <corners android:radius="8dp"/>

    <solid android:color="#00B6625D"/>

</shape>

然后在您的主 xml 文件中复制并粘贴此 snippet:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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"
android:layout_gravity="center"
android:background="#FFF"
android:orientation="vertical">

<androidx.constraintlayout.widget.ConstraintLayout
    android:layout_width="match_parent"
    android:layout_height="100dp"
    android:layout_margin="15dp">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="80dp"
        android:background="@drawable/bg_gray_rectangle_rounded_corners"
        android:gravity="center"
        android:orientation="horizontal"
        android:paddingStart="15dp"
        android:paddingEnd="15dp"
        android:weightSum="2"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent">

        <TextView
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_margin="5dp"
            android:layout_weight="1"
            android:background="@drawable/bg_gray_rectangle_rounded_corners"
            android:gravity="center"
            android:padding="10dp"
            android:text="Log In"
            android:textColor="@color/colorPrimary" />

        <TextView
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_margin="5dp"
            android:layout_weight="1"
            android:background="@drawable/bg_gray_rectangle_rounded_corners"
            android:gravity="center"
            android:padding="10dp"
            android:text="Sign up"
            android:textColor="@color/colorPrimary" />
    </LinearLayout>

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginStart="32dp"
        android:layout_marginLeft="32dp"
        android:layout_marginTop="7dp"
        android:background="#FFF"
        android:padding="4dp"
        android:text="@string/app_name"
        android:textColor="#636262"
        android:textSize="16sp"
        android:textStyle="bold"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>

</LinearLayout>

这是输出

祝你有美好的一天。如果有帮助,请告诉我。