带图标的 Android 圆形按钮

Android round button with icon

提问人:Simonas Petkevičius 提问时间:4/15/2017 最后编辑:PhantômaxxSimonas Petkevičius 更新时间:11/20/2020 访问量:18407

问:

我正在尝试制作一个像这个按钮图像这样的按钮,但我不能将图标放在文本前面。我现在制作的按钮现在看起来像这个按钮图像。所以,主要问题是我怎样才能让图标靠近文本的前面?

这是我的按钮形状代码:

    <?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>

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

<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" />
android-layout android-fragments android-button

评论


答:

8赞 Muhib Pirani 4/15/2017 #1

从按钮中删除大小和填充Xml 减小半径

并将 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>

评论

0赞 Muhib Pirani 4/15/2017
按钮和 textview 都是可行的,我想你必须在你设置 startDrawable 的按钮中给出 drawablePadding
11赞 Simonas Petkevičius 4/15/2017 #2

一切都按照穆希布·皮拉尼(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" />

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>
-1赞 Ashish Chaugule 9/28/2020 #3

带圆角 + 图标 + 文本的按钮

style="@style/Base.Widget.AppCompat.Button.Borderless"

这对我来说不需要太多的定制

5赞 Gabriele Mariotti 9/30/2020 #4

您可以使用:MaterialButton

 <MaterialButton
     style="@style/Widget.MaterialComponents.Button.IconOnly"
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     .../>

跟:

<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>

enter image description here