Using radio buttons in tabbed fragment

2.4k views Asked by At

I have a tabbed activity and in one of the fragments I have a radio group with 3 radio buttons. I am trying to figure out how to determine which radio buttons is selected. I suspect I needed to make a java file for the fragment. I am not sure if that is correct, though. I followed an example for the java file. I modified it and it is not working. Nothing happens when I click on a radio button.

fragment_calories_want.xml (omitted code not relevant to the question)

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="layout.CaloriesWant">

    <RadioGroup
        android:layout_width="match_parent"
        android:layout_height="100px"
        android:id="@+id/radioGroup"
        android:orientation="horizontal"
        android:layout_marginTop="82dp"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true">

        <RadioButton
            android:text="Grams"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/radioButtonGrams"
            android:layout_weight="1"
            tools:text="Grams" />

        <RadioButton
            android:text="Ounces"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/radioButtonOunces"
            android:layout_weight="1" />

        <RadioButton
            android:text="Pounds"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/radioButtonPounds" />
    </RadioGroup>
</RelativeLayout>

CaloriesWantFragment.java

package com.example.crims.caloriecalculator;
import android.app.Activity;
import android.app.Fragment;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.RadioButton;
import android.widget.RadioGroup;
import android.widget.Toast;

public class CaloriesWantFragment extends Fragment {

    private RadioButton radioButton1;
    private RadioButton radioButton2;
    private RadioButton radioButton3;
    private RadioGroup radioGroupOne;
    String buttonSelected;
    Activity activity;


    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {


        final View view = inflater.inflate(R.layout.fragment_calories_want,  container, false);
        radioButton1 = (RadioButton)  view.findViewById(R.id.radioButtonGrams);
        radioButton2 = (RadioButton) view.findViewById(R.id.radioButtonOunces);
        radioButton3 = (RadioButton) view.findViewById(R.id.radioButtonPounds);
        radioGroupOne = (RadioGroup) view.findViewById(R.id.radioGroup);

        radioGroupOne.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {
            @Override
            public void onCheckedChanged(RadioGroup radioGroup, int i) {
                switch(i){
                    case R.id.radioButtonGrams:
                        buttonSelected = "button one selected";

                        break;
                    case R.id.radioButtonOunces:
                        buttonSelected = "button two selected";

                        break;
                    case R.id.radioButtonPounds:
                        buttonSelected = "button three selected";

                        break;
                    default:

                }
                Toast.makeText(activity, "radio button selected " + buttonSelected, Toast.LENGTH_SHORT).show();
            }
        });

        return view;
    }

}
1

There are 1 answers

3
Rishabh Mahatha On

Initialize Radio Group

 radioGroupOne = (RadioGroup) view.findViewById(R.id.radioGroup);

java file

public class CaloriesWantFragment extends AppCompatActivity {

    private RadioButton radioButton1;
    private RadioButton radioButton2;
    private RadioButton radioButton3;
    private RadioGroup radioGroupOne;
    String buttonSelected;
    Activity activity;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.test);

        radioButton1 = (RadioButton) findViewById(R.id.radioButtonGrams);
        radioButton2 = (RadioButton) findViewById(R.id.radioButtonOunces);
        radioButton3 = (RadioButton) findViewById(R.id.radioButtonPounds);
        radioGroupOne = (RadioGroup) findViewById(R.id.radioGroup);

        radioGroupOne.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {
            @Override
            public void onCheckedChanged(RadioGroup radioGroup, int i) {
                switch (i) {
                    case R.id.radioButtonGrams:
                        buttonSelected = "button one selected";

                        break;
                    case R.id.radioButtonOunces:
                        buttonSelected = "button two selected";

                        break;
                    case R.id.radioButtonPounds:
                        buttonSelected = "button three selected";

                        break;
                    default:

                }
                Toast.makeText(CaloriesWantFragment.this, "radio button selected " + buttonSelected, Toast.LENGTH_SHORT).show();
            }
        });
    }

Xml file

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <RadioGroup
        android:layout_width="match_parent"
        android:layout_height="100px"
        android:id="@+id/radioGroup"
        android:orientation="horizontal"
        android:layout_marginTop="82dp"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true">

        <RadioButton
            android:text="Grams"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/radioButtonGrams"
            android:layout_weight="1"
            tools:text="Grams" />

        <RadioButton
            android:text="Ounces"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/radioButtonOunces"
            android:layout_weight="1" />

        <RadioButton
            android:text="Pounds"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/radioButtonPounds" />
    </RadioGroup>
</RelativeLayout>