Computer >> Computer tutorials >  >> Programming >> Android

Example on ToggleButton?


Before getting into example, we should know what is togglebutton in android, Toggle button is extended view of Button view. It going to represent of state of button as checked and unchecked. Here is the simple solution about toggle button in android.

Step 1 − Create a new project in Android Studio, go to File ⇒ New Project and fill all required details to create a new project.

Step 2 − Add the following code to res/layout/activity_main.xml.

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
   xmlns:android="https://schemas.android.com/apk/res/android"
   xmlns:app="https://schemas.android.com/apk/res-auto"
   xmlns:tools="https://schemas.android.com/tools"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   tools:context=".MainActivity">
   <ToggleButton
      android:id="@+id/result"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="Result Data"
      android:textColor="#FFF"
      android:background="@color/colorPrimary"
      android:textOff="Off"
      android:textOn="On"
      android:textSize="20sp"
      app:layout_constraintBottom_toBottomOf="parent"
      app:layout_constraintLeft_toLeftOf="parent"
      app:layout_constraintRight_toRightOf="parent"
      app:layout_constraintTop_toTopOf="parent" />
</android.support.constraint.ConstraintLayout>

In the above code we have added toggle button, when user click on toggle button it going to change the state.

Step 3 − Add the following code to src/MainActivity.java

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.ToggleButton;

public class MainActivity extends AppCompatActivity {
   @Override
   protected void onCreate(Bundle savedInstanceState) {
   super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);
      final ToggleButton toggleButton = findViewById(R.id.result);
      toggleButton.setOnClickListener(new View.OnClickListener() {
         @Override
         public void onClick(View v) {
            if (toggleButton.isChecked()) {
               toggleButton.setTextOn("You have Checked");
               toggleButton.setChecked(true);
            } else if (!toggleButton.isChecked()) {
               toggleButton.setTextOff("You have not Checked");
               toggleButton.setChecked(false);
            }
         }
      });
   }
}

In the above code, when user click on toggle button, it going to check the state as toggleButton.isChecked(). if it is checked state then it going to change the toggle button text using setTexton() and change the state as setChecked(true). In else case. if it is not checked then it going to change the toggle button text using setTextOff() and change the state as setChecked(false).

Step 4 − No need to change manifest.xml

Let's try to run your application. I assume you have connected your actual Android Mobile device with your computer. To run the app from android studio, open one of your project's activity files and click Run icon from the toolbar. Select your mobile device as an option and then check your mobile device which will display your default screen −

Example on ToggleButton?

In the above output represent about idle state. When user click on the button it going show the result as follows-

Example on ToggleButton?

In the above result, it going to change the text as YOU HAVE CHECKED and internally it going to change the state as setChecked(true). When you click on the above button, it going to show the output as shown below -

Example on ToggleButton?

In the above result, it going change the text as "YOU HAVE NOT CHECKED" and internally it going to change the state as setChecked(false).