How to align Radio button at the center of the screen

前端 未结 11 1326
误落风尘
误落风尘 2021-01-04 02:13

I am using Radio buttons as tab in my application.

I have loaded images for it, but they are aligning towards left side. how to make them align at center.

相关标签:
11条回答
  • 2021-01-04 03:03

    I had similar issue before, I figure it out, so I try to explain it for you.

    runtime screenshot

    above is my app screenshot, as you can see, I also did the same, I had a menu align screen bottom, they're a RadioGroup and three RadionButton inside it, I want each menu icon align center for RadionButton, the shadow image(9-patch) shown together when Button check event trigger.
    At first, I used android:button attribute refers to a drawable selector, the selector has two drawable state between check and uncheck, but I cannot align the menu icon center and make the shadow image fill up by RadionButton, they looks like it :

    enter image description here

    I tried included android:layout_gravity=center and android:gravity=center with the RadionButton, but it also didn't got effect. after that, my workmate told me the android:button attribute is refers to foreground rather than background, then I use android:background instead of android:button and it worked, below is my code :

    <RadioGroup android:layout_width="match_parent" android:layout_height="60dp"
            android:orientation="horizontal" android:background="@drawable/menu_bg">
    
        <RadioButton android:layout_width="0dp" android:layout_height="match_parent"
                     android:layout_weight="1" android:button="@null" android:checked="true"
                     android:background="@drawable/menu_item_selector" />
    
        <RadioButton android:layout_width="0dp" android:layout_height="match_parent"
                     android:layout_weight="1" android:button="@null"
                     android:background="@drawable/menu_item_selector" />
    
        <RadioButton android:layout_width="0dp" android:layout_height="match_parent"
                     android:layout_weight="1" android:button="@null"
                     android:background="@drawable/menu_item_selector" />
    
    </RadioGroup>
    

    the menu_item_selector is important thing because it had gravity setting :

    <selector xmlns:android="http://schemas.android.com/apk/res/android">
        <item android:drawable="@drawable/menu_item_layer_list" android:state_checked="true" />
        <item android:drawable="@drawable/menu_item_layer_list" android:state_pressed="true" />
        <item>
            <bitmap android:src="@drawable/menu_item_off" android:gravity="center" />
        </item>
    </selector>
    

    cause I had two images to draw when user turn Button state is checked, the shadow background image and icon active state image, so I used layer-list to implement it, the active icon also had gravity setting, below is menu_item_layer_list code :

    <layer-list xmlns:android="http://schemas.android.com/apk/res/android">
        <item android:drawable="@drawable/menu_bg_pressed" />
        <item>
            <bitmap android:src="@drawable/menu_item_on" android:gravity="center" />
        </item>
    </layer-list>
    

    I don't know that solution was perfect or not, because I always implement it as a view and draw myself. But I think Android SDK supplied more convenient component let's finish work with xml configuration, we should be learn and use it.

    0 讨论(0)
  • 2021-01-04 03:03
     <RadioGroup
        android:id="@+id/radioGroup1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:gravity="center_horizontal"
        android:orientation="horizontal" >
           <RadioButton
            android:id="@+id/rb1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="One"/>
    
            <RadioButton
            android:id="@+id/rb2"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Two"/>
     </RadioGroup>
    
    0 讨论(0)
  • 2021-01-04 03:03

    It was in the opposite side in my case and I just put android:paddingLeft="0dp" and it worked so you should try android:paddingRight="0dp" for radiobuttons

    0 讨论(0)
  • 2021-01-04 03:06

    You could put your RadioButton inside FrameLayout and center them:

    <RadioGroup
        android:id="@+id/radioGroup1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@color/gray_percent"
        android:orientation="horizontal" >
    
        <FrameLayout
            android:layout_width="0dip"
            android:layout_height="wrap_content" 
             android:layout_weight="1">
    
            <RadioButton
                android:id="@+id/radio0"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="center_horizontal"
    
                android:button="@drawable/rb_temp1"
                android:checked="true"
                android:gravity="center" />
        </FrameLayout>
    
        <FrameLayout
            android:layout_width="0dip"
            android:layout_height="wrap_content" 
             android:layout_weight="1">
    
            <RadioButton
                android:id="@+id/radio0"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="center_horizontal"
    
                android:button="@drawable/rb_temp1"
                android:gravity="center" />
        </FrameLayout>
    
    </RadioGroup>
    
    0 讨论(0)
  • 2021-01-04 03:06

    Put android:gravity="center" on RadioGroup Tag. This Works.

    0 讨论(0)
提交回复
热议问题