繁体   English   中英

在Android中的Button drawable中添加文本

[英]Add text inside Button drawable in Android

我在Xamarin有Android项目。 我需要做的是在Button中放置图像(绿点)内部添加文本。

如你所见,我正在添加绿点作为drawable。 那么也许我应该制作自定义drawable,将TextView和Image结合起来?

这就是它现在看起来/我想要实现的目标:

在此输入图像描述

按钮XML

<RelativeLayout
    android:layout_width="fill_parent"
    android:layout_height="fill_parent">
    <Button
        android:id="@+id/button_synchronize"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:background="@drawable/button_action"
        android:minHeight="60dp"
        android:maxHeight="60dp"
        android:layout_marginTop="15dp"
        android:layout_marginBottom="15dp"
        android:layout_marginLeft="15dp"
        android:layout_marginRight="15dp"
        android:paddingLeft="20dp"
        android:paddingRight="60dp"
        android:layout_alignParentBottom="true"
        android:text="Synkronisering"
        android:drawableRight="@drawable/ic_green_dot"
        android:drawablePadding="3dp"
        android:gravity="center" />
</RelativeLayout>

选择器XML

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<layer-list>
<item>
<shape>
<solid android:color="@color/main_orange_color" />
<stroke android:width="1dp" android:color="@color/main_grey_color" />
<corners android:radius="4dp" />
<padding android:left="3dp" android:top="3dp" android:right="3dp" android:bottom="3dp" />
</shape>
</item>
</layer-list>
</item>
</selector>

您可以从FrameLayout开始,其宽度和高度都设置为wrap_content 然后,将Button添加为底部的视图。 添加应用了适当样式的TextView 适当地改变它的layout_gravity

有关更多信息,请查看: http//blog.neteril.org/blog/2013/10/10/framelayout-your-best-ui-friend/

FrameLayout的秘诀在于它如何布置其子项。 虽然通常设计为包含一个项目,但它会很乐意将其他元素叠加在一起。 因此,FrameLayout本质上是一种操纵屏幕上视图的Z顺序的方法。

您不必使用Button 您可以使用RelativeLayoutLinearLayoutFrameLayout等中的任何一个及其组合。 为它们分配OnClickListener时,它们将充当按钮。 所以,让Button成为一个Layout

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM