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