android - 如何让按钮看起来像一个列表

标签 android android-layout

在我的应用程序中,我有如下所示的按钮:enter image description here

我想让它们看起来像这样: enter image description here

我的background.xml如下:

<?xml version="1.0" encoding="utf-8"?>
<layer-list
    xmlns:android="http://schemas.android.com/apk/res/android" >
    <item android:drawable="@drawable/solid" />        
    <item android:drawable="@drawable/shape" />
</layer-list>

solid.xml如下:

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

shape.xml如下:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
    <solid android:color="#ffffff" /> 
    <stroke android:width="3dp" color="#ff000000" /> 
    <corners android:radius="15dp" /> 
    <padding 
        android:left="10dp" 
        android:top="10dp" 
        android:right="10dp" 
        android:bottom="10dp" /> 
</shape>

如何获得所需的按钮外观?

最佳答案

顶部形状:

<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <corners
        android:topLeftRadius="5dp"
        android:topRightRadius="5dp" />
    <padding
        android:left="3dp"
        android:top="3dp"
        android:right="3dp"
        android:bottom="3dp" />
    <solid
        android:color="#ffffffff" />
    <stroke
        android:width="2dp"
        android:color="#ff000000" />
</shape>

中间形状:

<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <padding
        android:left="3dp"
        android:top="3dp"
        android:right="3dp"
        android:bottom="3dp" />
    <solid
        android:color="#ffffffff" />
    <stroke
        android:width="2dp"
        android:color="#ff000000" />
</shape>

底部形状:

<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <corners
        android:bottomLeftRadius="5dp"
        android:bottomRightRadius="5dp" />
    <padding
        android:left="3dp"
        android:top="3dp"
        android:right="3dp"
        android:bottom="3dp" />
    <solid
        android:color="#ffffffff" />
    <stroke
        android:width="2dp"
        android:color="#ff000000" />
</shape>

例子:

<Button
    android:background="@drawable/top"
    android:layout_width="150dp"
    android:layout_height="wrap_content"
    android:text="Top" />
<Button
    android:background="@drawable/middle"
    android:layout_width="150dp"
    android:layout_height="wrap_content"
    android:layout_marginTop="-2dp"
    android:text="Middle" />
<Button
    android:background="@drawable/bottom"
    android:layout_width="150dp"
    android:layout_height="wrap_content"
    android:layout_marginTop="-2dp"
    android:text="Bottom" />

看看 android:layout_marginTop="-2dp" - 你需要它让顶部按钮的边框与底部按钮的边框重叠

结果(图形不太好,sry): enter image description here

经过一些调整后,您将获得预期的形状。

我的调整:enter image description here

关于android - 如何让按钮看起来像一个列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6736303/

相关文章:

android - 在安卓工作室 : How to change packages file path

android - 如何避免音频流在 5 分钟后停止?

适用于 API 14 的安卓 setTextViewCompoundDrawables

java - 如何将 Canvas 作为参数发送给处理程序?

android - 尝试安装 Android Studio 时出错

android - 从普通 Activity 启动 FragmentActivity.. java.lang.NoClassDefFoundError

android - PinnedHeaderListView 示例

android - Eclipse Android 图形布局编辑器坏了

android - 如何在任何 Jetpack Compose View 上禁用涟漪效应?

Android同心圆缩放动画