Android:Radio Group的自定义布局

时间:2014-06-13 13:51:22

标签: android xml eclipse radio-button android-radiogroup

我正在尝试创建一个2x2的单选按钮阵列,但我不知道如何自定义除水平或垂直之外的布局。有什么想法吗?

我只是得到了

A B C D

A
B
C
D

但我想要

A B
C D

编辑: 我解决了这个问题。对于任何想知道的人,我设置了两个单独的无线电组(即一个用AB,一个用CD)。我为每个RadioButton设置onClickListener(),并在点击第一个RadioGroup中的按钮时在第二个RadioGroup上使用clearCheck(),反之亦然。

3 个答案:

答案 0 :(得分:3)

您可以通过在LinearLayout RadioGroup中添加两个orientation="horizontal"来轻松完成此操作。

<RadioGroup
    android:layout_width="wrap_content"
    android:layout_height="wrap_content">

            <LinearLayout
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:orientation="horizontal">

                <RadioButton
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:textAllCaps="true"
                    android:text="18-24"
                    />

                <RadioButton
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:textAllCaps="true"
                    android:text="36-45"
                    />
            </LinearLayout>

            <LinearLayout
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:orientation="horizontal">

                <RadioButton
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:textAllCaps="true"
                    android:text="25-35"
                    />

                <RadioButton
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:textAllCaps="true"
                    android:text=">45"
                    />
            </LinearLayout>

答案 1 :(得分:2)

更好地解决上述示例。当我们必须使用没有放射组的无线电按钮时,这应该是有用的。

    ///////////////////////////  for call setting rb ////////////////////////////////////////////////////

    grbtn = (RadioButton) findViewById(R.id.grbtn);
    vrbtn = (RadioButton) findViewById(R.id.vrbtn);
    srbtn = (RadioButton) findViewById(R.id.srbtn);
    arbtn = (RadioButton) findViewById(R.id.arbtn);

    grbtn.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {
            vrbtn.setChecked(false);
            srbtn.setChecked(false);
            arbtn.setChecked(false);
            ///////////////////////////////////////////////

        }
    });

    vrbtn.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {
            grbtn.setChecked(false);
            srbtn.setChecked(false);
            arbtn.setChecked(false);
            ///////////////////////////////////////////////

        }
    });

    srbtn.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {
            vrbtn.setChecked(false);
            grbtn.setChecked(false);
            arbtn.setChecked(false);
            ///////////////////////////////////////////////

        }
    });

    arbtn.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {
            vrbtn.setChecked(false);
            srbtn.setChecked(false);
            grbtn.setChecked(false);
            ///////////////////////////////////////////////

        }
    });

    /////////////////////////////////////////////////////////////////////////////////////////////////////


`

答案 2 :(得分:0)

如果这是你要问的,这就是我要做的。可能有更好的方法,但这对我来说效果很好。

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/radioGroup"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    android:layout_gravity="top|left">
    <RadioButton
        android:id="@+id/radio1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/radioOneText" />
    <RadioButton
        android:id="@+id/radio2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/radioTwoText"
        android:layout_toRightOf="@id/radio1"
        android:layout_alignBaseline="@id/radio1"
        android:layout_marginLeft="10dp" />
    <RadioButton
        android:id="@+id/radio3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/radioThreeText"
        android:layout_below="@id/radio1"
        android:layout_alignLeft="@id/radio1" />
    <RadioButton
        android:id="@+id/radio4"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/radioFourText"
        android:layout_below="@id/radio2"
        android:layout_toRightOf="@id/radio3"
        android:layout_alignBaseline="@id/radio3"
        android:layout_alignLeft="@id/radio2" />
</RelativeLayout>

以下是使用&#39; setOnClickListener&#39;的示例。处理变化......

package com.example.breakable;

import android.os.*;
import android.app.*;
import android.view.View;
import android.widget.*;

public class MainActivity extends Activity
{   
    RadioButton radioOne;
    RadioButton radioTwo;
    RadioButton radioThree;
    RadioButton radioFour;
    @Override
    public void onCreate(Bundle icicle)
    {       
        super.onCreate(icicle);
        setContentView(R.layout.main);

        radioOne = (RadioButton)findViewById(R.id.radio1);
        radioTwo = (RadioButton)findViewById(R.id.radio2);
        radioThree = (RadioButton)findViewById(R.id.radio3);
        radioFour = (RadioButton)findViewById(R.id.radio4);

        radioOne.setOnClickListener(new View.OnClickListener() {

            @Override
            public void onClick(View v) {
                if (radioTwo.isChecked()){
                    radioTwo.setChecked(false);
                    radioOne.setChecked(true);
                } else if (radioThree.isChecked()) {
                    radioThree.setChecked(false);
                    radioOne.setChecked(true);
                } else if (radioFour.isChecked()) {
                    radioFour.setChecked(false);
                    radioOne.setChecked(true);
                } else {
                    radioOne.setChecked(true);
                }
            }
        });
        radioTwo.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                if (radioOne.isChecked()){
                    radioOne.setChecked(false);
                    radioTwo.setChecked(true);
                } else if (radioThree.isChecked()) {
                    radioThree.setChecked(false);
                    radioTwo.setChecked(true);
                } else if (radioFour.isChecked()) {
                    radioFour.setChecked(false);
                    radioTwo.setChecked(true);
                } else {
                    radioTwo.setChecked(true);
                }
            }
        });
        radioThree.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                if (radioOne.isChecked()){
                    radioOne.setChecked(false);
                    radioThree.setChecked(true);
                } else if (radioTwo.isChecked()) {
                    radioTwo.setChecked(false);
                    radioThree.setChecked(true);
                } else if (radioFour.isChecked()) {
                    radioFour.setChecked(false);
                    radioThree.setChecked(true);
                } else {
                    radioThree.setChecked(true);
                }
            }
        });
        radioFour.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                if (radioOne.isChecked()){
                    radioOne.setChecked(false);
                    radioFour.setChecked(true);
                } else if (radioTwo.isChecked()) {
                    radioTwo.setChecked(false);
                    radioFour.setChecked(true);
                } else if (radioThree.isChecked()) {
                    radioThree.setChecked(false);
                    radioFour.setChecked(true);
                } else {
                    radioFour.setChecked(true);
                }
            }
        });
    }
}