Android圆形按钮带有图标

Sim*_*ius 1 android android-layout android-fragments android-button

我想制作一个像这个 按钮图像的按钮,但我不能把图标放在文本前面.我现在制作的按钮现在看起来像这个按钮图像.所以,主要的问题是如何让图标靠近文本前面?

这是我的按钮形状代码:

    <?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle" >
    <corners
        android:radius="50dp"
        />
    <solid
        android:color="#00A651"
        />
    <padding
        android:left="0dp"
        android:top="0dp"
        android:right="0dp"
        android:bottom="0dp"
        />
    <size
        android:width="300dp"
        android:height="20dp"
        />
</shape>
Run Code Online (Sandbox Code Playgroud)

这是我用来将按钮实现为活动的代码:

<Button
        android:id="@+id/problem"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:background="@drawable/buttonshape"
        android:drawableStart="@drawable/ic_rate_review_black_24dp"
        android:textColor="#FFFFFF"
        android:textSize="15sp"
        android:text="@string/button_problem" />
Run Code Online (Sandbox Code Playgroud)

小智 6

从buttonXml中删除大小和填充减少半径

并将paddingTop和paddinBottom添加到您或您也可以使用TextView作为按钮已经分配了一些填充.

 <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle" >
<corners
    android:radius="10dp"
    />
<solid
    android:color="#00A651"
    />


</shape>
Run Code Online (Sandbox Code Playgroud)


Sim*_*ius 6

一切都按Muhib Pirani的建议进行。多亏了他

Button的代码现在如下所示:

<Button
    android:id="@+id/problem"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="center"
    android:background="@drawable/buttonshape"
    android:drawableStart="@drawable/ic_rate_review_black_24dp" 
    android:drawablePadding="5dp"
    android:paddingLeft="40dp"
    android:paddingRight="40dp"
    android:text="@string/button_problem"
    android:textColor="#FFFFFF"
    android:textSize="15sp" />
Run Code Online (Sandbox Code Playgroud)

ButtonShape.xml看起来是这样的:

    <?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle" >
    <corners
        android:radius="50dp"/>
    <solid
        android:color="#00A651"
        /> </shape>
Run Code Online (Sandbox Code Playgroud)

  • 如果他的解决方案正确,则应将其标记为 (9认同)

Gab*_*tti 5

您可以使用MaterialButton

 <MaterialButton
     style="@style/Widget.MaterialComponents.Button.IconOnly"
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     .../>
Run Code Online (Sandbox Code Playgroud)

和:

<style name="Widget.MaterialComponents.Button.IconOnly">
    <item name="iconPadding">0dp</item>
    <item name="android:insetTop">0dp</item>
    <item name="android:insetBottom">0dp</item>
    <item name="android:paddingLeft">12dp</item>
    <item name="android:paddingRight">12dp</item>
    <item name="android:minWidth">12dp</item>
    <item name="android:minHeight">12dp</item>
    <item name="iconGravity">textStart</item>
</style>
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述