文字描边
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>
这是输出
祝你有美好的一天。如果有帮助,请告诉我。
我想知道是否可以创建一个带有笔划作为边框的自定义可绘制对象,并且该笔划包含文本,对于我的问题,请参见我在 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>
这是输出
祝你有美好的一天。如果有帮助,请告诉我。