Friday, 3 May 2013

Work with RadioButton , CheckBox, Spinner , EditText, TextView and Button in Android

In this tutorial, I show you how to use XML to create 

  1. RadioButton in XML file, and grouped in a RadioGroup. When Button is clicked, display which RadioButton is selected.
  2. CheckBox in XML file, and demonstrates the use of listener to check the CheckBox state – checked or unchecked.
  3. EditText in XML file, and how to get value from EditText when we select the Button.
  4. Spinner in XML file, how to select one particular from many given values and display which value is selected.
  5. TextView in XML file, it is used to show the value or result .
  6. Button in XML file, which help us to get values from several widget on a single click.
Now I write here the XML code 

activity_layout_interface.xml

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

    <EditText
        android:id="@+id/editTextName"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="20dp"
        android:ems="10"
        android:hint="Enter Your Name Here"
        android:inputType="textPersonName" >

        <requestFocus />
    </EditText>

    <LinearLayout
        android:id="@+id/linearLayout1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@+id/editTextName"
        android:layout_centerHorizontal="true"
        android1:layout_marginTop="17dp" >

        <TextView
            android:id="@+id/textView1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Gender:: "
            android:textAppearance="?android:attr/textAppearanceMedium" />

        <RadioGroup
            android:id="@+id/radioGroup1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" >

            <RadioButton
                android:id="@+id/radio0"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"               
                android:text="Male" />
        

        <RadioButton
            android:id="@+id/radio1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Female" />
        </RadioGroup>
    </LinearLayout>

    <LinearLayout
        android:id="@+id/linearLayout2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@+id/linearLayout1"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="30dp" >

        <TextView
            android:id="@+id/textView2"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:layout_marginLeft="55dp"
            android:text="Age:: "
            android:textAppearance="?android:attr/textAppearanceMedium" />

        <Spinner
            android:id="@+id/spinner1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:entries="@array/ageGroup" />
    </LinearLayout>

    <LinearLayout
        android:id="@+id/linearLayout3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@+id/linearLayout2"
        android:layout_centerHorizontal="true" >

        <TextView
            android:id="@+id/textView3"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Hobby:: "
            android:textAppearance="?android:attr/textAppearanceMedium" />

        <CheckBox
            android:id="@+id/checkBox1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Cricket" />

        <CheckBox
            android:id="@+id/checkBox2"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Football" />
    </LinearLayout>

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@+id/linearLayout3"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="48dp"
        android:text="SUBMIT" />

    <TextView
        android:id="@+id/result"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_below="@+id/button1"
        android:layout_marginTop="22dp"
        android:textColor="#CC0000"        
        android:textAppearance="?android:attr/textAppearanceSmall" />

</RelativeLayout>

The result screen looking like this:

For Spinner I have to create an array in string.XML file.

string.XML

<?xml version="1.0" encoding="utf-8"?>
<resources>

    <string name="app_name">Introduce Layout</string>
    <string name="action_settings">Settings</string>
    <string name="hello_world">Hello world!</string>

    
    <string-array name="ageGroup">
<item>0 to 10</item>
<item>11 to 18</item>
<item>19 to 25</item>
<item>26 to 40</item>
<item>40 to 60</item>
<item>Above 60</item>
</string-array>
</resources>

The yellow portion I have created .

java source code LayoutInterface.java

LayoutInterface.java


package com.blogspot.mukherjee.satyaki.introducelayout;

import android.os.Bundle;
import android.app.Activity;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.*;
import android.widget.CompoundButton.OnCheckedChangeListener;

public class LayoutInterface extends Activity {

EditText fullName;
RadioGroup genderGroup;
RadioButton genderButton;
Spinner ageScroll;
CheckBox chkCricket,chkFootball;
Button submit;
TextView result;
String gender="";
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_layout_interface);
        
        fullName   =(EditText) findViewById(R.id.editTextName) ;
        genderGroup=(RadioGroup) findViewById(R.id.radioGroup1);
        ageScroll  =(Spinner) findViewById(R.id.spinner1)      ;
        chkCricket =(CheckBox) findViewById(R.id.checkBox1)    ;
        chkFootball=(CheckBox) findViewById(R.id.checkBox2)    ;
        result     =(TextView) findViewById(R.id.result)       ;
        submit   =(Button) findViewById(R.id.button1)   ;
        
        /* Work with RadioButton */
        genderGroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {
        /**
             * Called when the RadioButton is selected
             */
@Override
public void onCheckedChanged(RadioGroup group, int checkedId) {
// TODO Auto-generated method stub
genderButton=(RadioButton) findViewById(checkedId);
// This puts the value (true/false) into the variable
       boolean isChecked = genderButton.isChecked();
       
if(isChecked)
{
gender=genderButton.getText().toString().trim();
Toast.makeText(getApplicationContext(), ""+genderButton.getText().toString().trim(), Toast.LENGTH_SHORT).show();
}
}
});
        
        /* Work with CheckBox*/
        chkCricket.setOnCheckedChangeListener(new OnCheckedChangeListener()
        {
        /**
             * Called when the checkbox is selected 
             */
@Override
public void onCheckedChanged(CompoundButton arg0, boolean isChecked) {
// TODO Auto-generated method stub
if(isChecked)
{
Toast.makeText(getApplicationContext(), ""+chkCricket.getText().toString().trim(), Toast.LENGTH_SHORT).show();
}
}
       
        });
        
        /* Work with CheckBox*/
        chkFootball.setOnCheckedChangeListener(new OnCheckedChangeListener()
        {
        /**
             * Called when the checkbox is selected 
             */
@Override
public void onCheckedChanged(CompoundButton arg0, boolean isChecked) {
// TODO Auto-generated method stub
if(isChecked)
{
Toast.makeText(getApplicationContext(), ""+chkFootball.getText().toString().trim(), Toast.LENGTH_SHORT).show();
}
}
       
        });
        
        /* Work with Spinner*/
        ageScroll.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
            /**
             * Called when a new item is selected (in the Spinner)
             */
             public void onItemSelected(AdapterView<?> parent, View view, 
                        int pos, long id) {
                    // An spinnerItem was selected. You can retrieve the selected item using
                    // parent.getItemAtPosition(pos)

                    Toast.makeText(getApplicationContext(), ""+ageScroll.getSelectedItem().toString().trim(),Toast.LENGTH_SHORT).show();

                }

                public void onNothingSelected(AdapterView<?> parent) {
                    // Do nothing, just another required interface callback
                Toast.makeText(getApplicationContext(), "You are not selected any value",Toast.LENGTH_SHORT).show();

                }

        }); 
        
        submit.setOnClickListener(new OnClickListener()
        {

@Override
public void onClick(View v) {
// TODO Auto-generated method stub
String name=fullName.getText().toString().trim();
/*int genderID=genderGroup.getCheckedRadioButtonId();
genderButton=(RadioButton) findViewById(genderID);
String gender=genderButton.getText().toString().trim();*/
String age=ageScroll.getSelectedItem().toString().trim();
String hobby="";
if(chkCricket.isChecked() && chkFootball.isChecked())
{
hobby="Cricket and Football";
}
else if(chkCricket.isChecked())
{
if(!chkFootball.isChecked())
hobby="Cricket";
}
else if(chkFootball.isChecked())
{
if(!chkCricket.isChecked())
hobby="Football";
}
else{
hobby="Please select your hobby..";;
}
result.setText("Name:: "+name+" ; Gender:: "+gender+" ; Age:: "+age+" ; Hobby:: "+hobby);
Toast.makeText(getApplicationContext(), "Name:: "+name+" ; Gender:: "+gender+" ; Age:: "+age+" ; Hobby:: "+hobby, Toast.LENGTH_LONG).show();
}
       
        });
    }
    
}

Output screen::




If you have any query and face any problem, then you can also contact with me .

Thanks,
 

13 comments:

  1. how to show an alert if the gender is not selected using try statement?

    ReplyDelete
  2. Inside Button write
    if(genderButton.isChecked()){
    // Give some message here
    }
    else {
    // Alert Dialog
    AlertDialog.Builder alertDialogBuilder = new AlertDialog.Builder(
    context);

    // set title
    alertDialogBuilder.setTitle("Your Title");

    // set dialog message
    alertDialogBuilder
    .setMessage("Click yes to exit!")
    .setCancelable(false)
    .setPositiveButton("Yes",new DialogInterface.OnClickListener() {
    public void onClick(DialogInterface dialog,int id) {
    // if this button is clicked, close
    // current activity
    MainActivity.this.finish();
    }
    })
    .setNegativeButton("No",new DialogInterface.OnClickListener() {
    public void onClick(DialogInterface dialog,int id) {
    // if this button is clicked, just close
    // the dialog box and do nothing
    dialog.cancel();
    }
    });

    // create alert dialog
    AlertDialog alertDialog = alertDialogBuilder.create();

    // show it
    alertDialog.show();
    }

    ReplyDelete
  3. hi. i am doing one mail application. if i type message in "compose message text box" it will contain some key words like"insert" " join"...... based on this keyword, mail has to send to particualr person.
    if i am expert in insert statement in db, that mail should come to me. how to do that.

    ReplyDelete
    Replies
    1. @senthil send your requirement in my email id in details, because this a tutorial blog for this particular topics.

      Delete
  4. why u have used linear layout for all input types that u have used?

    ReplyDelete
    Replies
    1. @senthil you can also use RelativeLayout , It's a quick tutorial without complexity , so, for this reason I have used this for better understanding.

      Delete
  5. i have to save these information to mysql database..can u send the query to my mail id.. 91vanaja@gmail.com

    ReplyDelete
  6. hi
    i want to store spinner value in my database on register page plz help

    ReplyDelete
  7. hi
    i want to store spinner value in my database on register page plz help

    ReplyDelete
  8. Thanks you soooooooo much.

    ReplyDelete
  9. Visit Woodley Titanium Sunglasses
    Sunglasses titanium symbol at Titha, Oakley Titanium Sunglasses apple watch titanium vs aluminum & Accessories. black titanium rings Find ford focus titanium a new shop with our Sunglasses titanium dab tool store or find a new shop with our store listing.

    ReplyDelete