Skip to content
geeksforgeeks
  • Tutorials
    • Python
    • Java
    • Data Structures & Algorithms
    • ML & Data Science
    • Interview Corner
    • Programming Languages
    • Web Development
    • CS Subjects
    • DevOps And Linux
    • School Learning
    • Practice Coding Problems
  • Courses
    • DSA to Development
    • Get IBM Certification
    • Newly Launched!
      • Master Django Framework
      • Become AWS Certified
    • For Working Professionals
      • Interview 101: DSA & System Design
      • Data Science Training Program
      • JAVA Backend Development (Live)
      • DevOps Engineering (LIVE)
      • Data Structures & Algorithms in Python
    • For Students
      • Placement Preparation Course
      • Data Science (Live)
      • Data Structure & Algorithm-Self Paced (C++/JAVA)
      • Master Competitive Programming (Live)
      • Full Stack Development with React & Node JS (Live)
    • Full Stack Development
    • Data Science Program
    • All Courses
  • Data Science
  • Data Science Projects
  • Data Analysis
  • Data Visualization
  • Machine Learning
  • ML Projects
  • Deep Learning
  • NLP
  • Computer Vision
  • Artificial Intelligence
Open In App
Next Article:
How to create a Face Detection Android App using Machine Learning KIT on Firebase
Next article icon

How to create a Face Detection Android App using Machine Learning KIT on Firebase

Last Updated : 16 Jul, 2024
Comments
Improve
Suggest changes
Like Article
Like
Report

Pre-requisites:

  • Firebase Machine Learning kit
  • Adding Firebase to Android App

Firebase ML KIT aims to make machine learning more accessible, by providing a range of pre-trained models that can use in the iOS and Android apps. Let's use ML Kit’s Face Detection API which will identify faces in photos. By the end of this article, we’ll have an app that can identify faces in an image, and then display information about these faces, such as whether the person is smiling, or has their eyes closed with wonderful GUI.

Approach

Step 1: Create a New Project

  1. Open a new project in android studio with whatever name you want.
  2. We are gonna work with empty activity for the particular project.
  3. The minimum SDK required for this particular project is 23, so choose any API of 23 or above.
  4. The language used for this project would be JAVA.
  5. Leave all the options other than those mentioned above, untouched.
  6. Click on FINISH.


Step 2: Connect with ML KIT on Firebase.

  1. Login or signup on Firebase.
  2. In Firebase console, create a new project or if you wanna work with an existing project then open that.
  3. Name the project as per your choice.
  4. Go to Docs.
  5. Click on Firebase ML, and in the left space, choose 'recognize text' under Vision.
  6. Go through the steps mentioned for better understanding.
  7. Come back to Android Studio.
  8. Go to Tools -> Firebase -> Analytics -> Connect with Firebase -> Choose your project from the dialog box appeared -> Click Connect. (This step connects your android app to the Firebase)


Step 3: Custom Assets and Gradle

  • For enhancing the GUI either choose an image of .png format and add it in the res folder and set it as the background of main .xml file, or  set a background color by going to the design view of the layout and customizing background under Declared Attributes as shown below:

  • To, include the ML KIT dependencies, in the app, go to Gradle Script -> build.gradle(Module:app) and add an implementation mentioned below:

implementation 'com.google.firebase:firebase-ml-vision:17.0.0'

  • Now copy the below-mentioned text, and paste it at the very end of the app level Gradle, outside all the brackets as shown in the image below.

apply plugin: 'com.google.gms.google-services'

  • Next, go to build.gradle (project) and copy the below-mentioned text, and paste it in 'dependencies' classpath as shown in the image below.

classpath 'com.google.gms:google-services:4.2.0'

  • Click on sync now.


Step 4: Designing the UI

  • Below is the code for the basic XML file. Add a Button to open the camera option.
XML
<?xml version="1.0" encoding="UTF-8"?> <androidx.constraintlayout.widget.ConstraintLayout     tools:context=".MainActivity"     android:layout_height="match_parent"     android:layout_width="match_parent"     xmlns:tools="http://schemas.android.com/tools"     xmlns:app="http://schemas.android.com/apk/res-auto"     xmlns:android="http://schemas.android.com/apk/res/android">      <Button         android:background="#000000"         android:layout_height="wrap_content"         android:layout_width="wrap_content"         app:layout_constraintStart_toStartOf="parent"         app:layout_constraintEnd_toEndOf="parent"         app:layout_constraintBottom_toBottomOf="parent"         android:text=CAMERA         android:layout_marginBottom="100dp"         android:padding="16dp"         android:id="@+id/camera_button"/> </androidx.constraintlayout.widget.ConstraintLayout> 

 
 

  • Now the UI will look like this.

  • Now go to layout -> new -> layout resource file -> Name: fragment_resultdialog.xml. This file has been created to customize the output screen, which will display a dialog box called Result Dialog box with a text view called Result Text with all the attributes of the detected image. Below is the XML file for the XML file created.

Advantage of Firebase ML Kit

Simplified Development: Firebase ML Kit provides pre-trained models for face detection, eliminating the need for complex machine learning expertise. This significantly reduces development time and resources.

Additional Tips:

  • Explore real-time face detection using the camera preview.
  • Implement additional functionalities like face tracking or emotion recognition (requires additional ML Kit components).
  • Thoroughly test your app on various devices and lighting conditions.
    XML
    <?xml version="1.0" encoding="UTF-8"?> <androidx.constraintlayout.widget.ConstraintLayout      android:layout_height="match_parent"      android:layout_width="match_parent"      xmlns:tools="http://schemas.android.com/tools"      xmlns:app="http://schemas.android.com/apk/res-auto"      xmlns:android="http://schemas.android.com/apk/res/android">      <ScrollView         android:layout_width="wrap_content"         android:layout_height="wrap_content"         app:layout_constraintBottom_toBottomOf="parent"         app:layout_constraintStart_toStartOf="parent"         app:layout_constraintTop_toTopOf="parent">           <RelativeLayout             android:id="@+id/relativeLayout"             android:layout_width="match_parent"             android:layout_height="wrap_content"             android:layout_marginStart="20dp"             android:layout_marginEnd="20dp"             app:layout_constraintEnd_toEndOf="parent"             app:layout_constraintStart_toStartOf="parent"             app:layout_constraintTop_toTopOf="parent">                        <!--text view to display the result text                           after reading an image-->             <TextView                 android:id="@+id/result_text_view"                 android:layout_width="match_parent"                 android:layout_height="wrap_content"                 android:gravity="center"                 android:text="LCOFaceDetection"                 android:textColor="#000000"                 android:textSize="18sp"                 app:layout_constraintEnd_toEndOf="parent"                 app:layout_constraintStart_toStartOf="parent"                 app:layout_constraintTop_toTopOf="parent"/>                        <!--a button with text 'ok' written on it-->             <Button                 android:id="@+id/result_ok_button"                 android:layout_width="wrap_content"                 android:layout_height="wrap_content"                 android:layout_below="@id/result_text_view"                 android:layout_centerInParent="true"                 android:layout_marginTop="20dp"                 android:layout_marginBottom="5dp"                 android:background="#75DA8B"                 android:padding="16dp"                 android:text="ok"                 app:layout_constraintEnd_toEndOf="parent"                 app:layout_constraintStart_toStartOf="parent"                 app:layout_constraintTop_toBottomOf="@+id/result_text_view"/>          </RelativeLayout>      </ScrollView>  </androidx.constraintlayout.widget.ConstraintLayout> 

     
     

    Step 5: Firebase App Initializer

    • Create a new java class by java -> new -> class -> Name: LCOFaceDetection.java -> superclass: Application(android.app.Application). Below is the example source code for the java class.


     

    Java
    import android.app.Application; import com.google.firebase.FirebaseApp;  public class LCOFaceDetection extends Application {     public final static String RESULT_TEXT = "RESULT_TEXT";     public final static String RESULT_DIALOG = "RESULT_DIALOG";      // initializing our firebase     @Override     public void onCreate()     {         super.onCreate();         FirebaseApp.initializeApp(this);     } } 

     
     

    Step 6: Inflating the Result Dialog Box

    • Create a new java class namely, ResultDialog.java and superclass, DialogFragment, which is the java file for the fragment_resultdialog.xml. Below is the example code for java file.


     

    Java
    import android.os.Bundle; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.Button; import android.widget.TextView; import androidx.annotation.NonNull; import androidx.annotation.Nullable; import androidx.fragment.app.DialogFragment;  public class ResultDialog extends DialogFragment {     Button okBtn;     TextView resultTextView;      @Nullable     @Override     public View     onCreateView(@NonNull LayoutInflater inflater,                  @Nullable ViewGroup container,                  @Nullable Bundle savedInstanceState)     {          // importing View so as to inflate         // the layout of our result dialog         // using layout inflater.         View view = inflater.inflate(             R.layout.fragment_resultdialog, container,             false);         String resultText = "";          // finding the elements by their id's.         okBtn = view.findViewById(R.id.result_ok_button);         resultTextView             = view.findViewById(R.id.result_text_view);          // To get the result text         // after final face detection         // and append it to the text view.         Bundle bundle = getArguments();         resultText = bundle.getString(             LCOFaceDetection.RESULT_TEXT);         resultTextView.setText(resultText);          // Onclick listener so as         // to make a dismissable button         okBtn.setOnClickListener(             new View.OnClickListener() {                 @Override                 public void onClick(View v)                 {                     dismiss();                 }             });         return view;     } } 

     
     

    Step 7: Open Camera on a Real Device and Enabling Face Detection

    • Below is the example code for the main java file.
    • There is a need of FirebaseVision and FirebaseVisionFaceDetector classes for this.
    • Here’s a list of all the settings you can configure in your face detection model.
    SettingDescription
    Performance mode

    FAST (default) | ACCURATE

    Favor speed or accuracy when detecting faces.

    Detect landmarks

    NO_LANDMARKS (default) | ALL_LANDMARKS

    Whether to attempt to identify facial "landmarks": 

    eyes, ears, nose, cheeks, mouth, and so on.

    Detect contours

    NO_CONTOURS (default) | ALL_CONTOURS

    Whether to detect the contours of facial features. 

    Contours are detected for only the most prominent face in an image.

    Classify faces

    NO_CLASSIFICATIONS (default) | ALL_CLASSIFICATIONS

    Whether or not to classify faces into categories

    such as "smiling", and "eyes open".

    Minimum face size

    float (default: 0.1f )

    The minimum size, relative to the image, of faces to detect.

    Enable face tracking

    false (default) | true

    Whether or not to assign faces an ID, which

    can be used to track faces across images.

    Note that when contour detection is enabled,  

    only one face is detected, so face tracking doesn't 

    produce useful results. For this reason, and to improve

    detection speed, don't enable both contour detection and face tracking.

    • It is suggested to read a detailed analysis of these classes and work on the code at the Firebase ML docs for text recognition.


     

    Java
    /*package whatever do not write package name here*/  import androidx.annotation.NonNull; import androidx.annotation.Nullable; import androidx.appcompat.app.AppCompatActivity; import androidx.fragment.app.DialogFragment; import android.content.Intent; import android.graphics.Bitmap; import android.os.Bundle; import android.provider.MediaStore; import android.view.View; import android.widget.Button; import android.widget.Toast; import com.google.android.gms.tasks.OnFailureListener; import com.google.android.gms.tasks.OnSuccessListener; import com.google.firebase.FirebaseApp; import com.google.firebase.ml.vision.FirebaseVision; import com.google.firebase.ml.vision.common.FirebaseVisionImage; import com.google.firebase.ml.vision.common.FirebaseVisionPoint; import com.google.firebase.ml.vision.face.FirebaseVisionFace; import com.google.firebase.ml.vision.face.FirebaseVisionFaceDetector; import com.google.firebase.ml.vision.face.FirebaseVisionFaceDetectorOptions; import com.google.firebase.ml.vision.face.FirebaseVisionFaceLandmark; import java.util.List;  public class MainActivity extends AppCompatActivity {     Button cameraButton;      // whenever we request for our customized permission, we     // need to declare an integer and initialize it to some     // value .     private final static int REQUEST_IMAGE_CAPTURE = 124;     FirebaseVisionImage image;     FirebaseVisionFaceDetector detector;      @Override     protected void onCreate(Bundle savedInstanceState)     {         super.onCreate(savedInstanceState);         setContentView(R.layout.activity_main);          // initializing our firebase in main activity         FirebaseApp.initializeApp(this);          // finding the elements by their id's allotted.         cameraButton = findViewById(R.id.camera_button);          // setting an onclick listener to the button so as         // to request image capture using camera         cameraButton.setOnClickListener(             new View.OnClickListener() {                 @Override                 public void onClick(View v)                 {                      // making a new intent for opening camera                     Intent intent = new Intent(                         MediaStore.ACTION_IMAGE_CAPTURE);                     if (intent.resolveActivity(                             getPackageManager())                         != null) {                         startActivityForResult(                             intent, REQUEST_IMAGE_CAPTURE);                     }                     else {                         // if the image is not captured, set                         // a toast to display an error image.                         Toast                             .makeText(                                 MainActivity.this,                                 "Something went wrong",                                 Toast.LENGTH_SHORT)                             .show();                     }                 }             });     }      @Override     protected void onActivityResult(int requestCode,                                     int resultCode,                                     @Nullable Intent data)     {         // after the image is captured, ML Kit provides an         // easy way to detect faces from variety of image         // types like Bitmap          super.onActivityResult(requestCode, resultCode,                                data);         if (requestCode == REQUEST_IMAGE_CAPTURE             && resultCode == RESULT_OK) {             Bundle extra = data.getExtras();             Bitmap bitmap = (Bitmap)extra.get("data");             detectFace(bitmap);         }     }      // If you want to configure your face detection model     // according to your needs, you can do that with a     // FirebaseVisionFaceDetectorOptions object.     private void detectFace(Bitmap bitmap)     {         FirebaseVisionFaceDetectorOptions options             = new FirebaseVisionFaceDetectorOptions                   .Builder()                   .setModeType(                       FirebaseVisionFaceDetectorOptions                           .ACCURATE_MODE)                   .setLandmarkType(                       FirebaseVisionFaceDetectorOptions                           .ALL_LANDMARKS)                   .setClassificationType(                       FirebaseVisionFaceDetectorOptions                           .ALL_CLASSIFICATIONS)                   .build();          // we need to create a FirebaseVisionImage object         // from the above mentioned image types(bitmap in         // this case) and pass it to the model.         try {             image = FirebaseVisionImage.fromBitmap(bitmap);             detector = FirebaseVision.getInstance()                            .getVisionFaceDetector(options);         }         catch (Exception e) {             e.printStackTrace();         }          // It’s time to prepare our Face Detection model.         detector.detectInImage(image)             .addOnSuccessListener(new OnSuccessListener<List<FirebaseVisionFace> >() {                 @Override                 // adding an onSuccess Listener, i.e, in case                 // our image is successfully detected, it will                 // append it's attribute to the result                 // textview in result dialog box.                 public void onSuccess(                     List<FirebaseVisionFace>                         firebaseVisionFaces)                 {                     String resultText = "";                     int i = 1;                     for (FirebaseVisionFace face :                          firebaseVisionFaces) {                         resultText                             = resultText                                   .concat("\nFACE NUMBER. "                                           + i + ": ")                                   .concat(                                       "\nSmile: "                                       + face.getSmilingProbability()                                             * 100                                       + "%")                                   .concat(                                       "\nleft eye open: "                                       + face.getLeftEyeOpenProbability()                                             * 100                                       + "%")                                   .concat(                                       "\nright eye open "                                       + face.getRightEyeOpenProbability()                                             * 100                                       + "%");                         i++;                     }                      // if no face is detected, give a toast                     // message.                     if (firebaseVisionFaces.size() == 0) {                         Toast                             .makeText(MainActivity.this,                                       "NO FACE DETECT",                                       Toast.LENGTH_SHORT)                             .show();                     }                     else {                         Bundle bundle = new Bundle();                         bundle.putString(                             LCOFaceDetection.RESULT_TEXT,                             resultText);                         DialogFragment resultDialog                             = new ResultDialog();                         resultDialog.setArguments(bundle);                         resultDialog.setCancelable(true);                         resultDialog.show(                             getSupportFragmentManager(),                             LCOFaceDetection.RESULT_DIALOG);                     }                 }             }) // adding an onfailure listener as well if             // something goes wrong.             .addOnFailureListener(new OnFailureListener() {                 @Override                 public void onFailure(@NonNull Exception e)                 {                     Toast                         .makeText(                             MainActivity.this,                             "Oops, Something went wrong",                             Toast.LENGTH_SHORT)                         .show();                 }             });     } } 

     Output
     



    Next Article
    How to create a Face Detection Android App using Machine Learning KIT on Firebase

    A

    anushree_mishra
    Improve
    Article Tags :
    • Java
    • Project
    • Machine Learning
    • Android
    • AI-ML-DS
    • Android Projects
    Practice Tags :
    • Java
    • Machine Learning

    Similar Reads

      Android Tutorial
      In this Android Tutorial, we cover both basic and advanced concepts. So whether you are a fresher (graduate) or an experienced candidate with several years of Android Development experience, you can follow this Android tutorial to kick-start your journey in Android app development. Our Android Tutor
      15+ min read

      Basics

      Introduction to Android Development
      Android operating system is the largest installed base among various mobile platforms across the globe. Hundreds of millions of mobile devices are powered by Android in more than 190 countries of the world. It conquered around 71% of the global market share by the end of 2021, and this trend is grow
      5 min read
      History of Android
      Android devices form a very essential part of a huge section of mobile phone users in today's world. With the global turmoil in the COVID-19 eras, the population has now entered a digital sphere. Android is the most used OS in smartphones during these days of transformation. But when did something l
      15+ min read
      Best Way to Become Android Developer – A Complete Roadmap
      Android is an open-source operating system, based on the Linux kernel and used in mobile devices like smartphones, tablets, etc. Further, it was developed for smartwatches and Android TV. Each of them has a specialized interface. Android has been one of the best-selling OS for smartphones. Android O
      7 min read
      Android Development Prerequisites [2025] - Things to Learn Before Android Development
      Have you ever wondered how your phone's apps—such as those for making calls, playing games, or checking the weather—are created? Android Development is the procedure used to generate these apps. The Android operating system powers the majority of phones, just like an engine powers a car. To ensure t
      8 min read
      Android App Development Fundamentals for Beginners
      Android is an operating system that is built basically for Mobile phones. It is based on the Linux Kernel and other open-source software and is developed by Google. It is used for touchscreen mobile devices such as smartphones and tablets. But nowadays these are used in Android Auto cars, TV, watche
      6 min read
      Android Architecture
      Android architecture contains a different number of components to support any Android device's needs. Android software contains an open-source Linux Kernel having a collection of a number of C/C++ libraries which are exposed through application framework services. Among all the components Linux Kern
      5 min read
      Android System Architecture
      The Android software stack generally consists of a Linux kernel and a collection of C/C++ libraries that are exposed through an application framework that provides services, and management of the applications and run time. Linux KernelAndroid was created on the open-source kernel of Linux. One main
      3 min read
      Android Boot Process
      Booting Process In computing, booting is starting up a computer or computer appliance until it can be used. It can be initiated by hardware such as a button press, or by software command. After the power is switched on the computer is relatively dumb, and can read only part of its storage called Rea
      4 min read
      Difference between Java and Kotlin in Android with Examples
      Kotlin KOTLIN is a cross platform, statically types, general purpose programming language with type inference. KOTLIN is designed to interoperate fully with java but type inference allows its syntax to be more concise.KOTLIN is sponsored by JetBrains and Google through the Kotlin Foundation. Java JA
      3 min read
      Interesting Facts About Android
      Android is a Mobile Operating System that was released on 23, September 2008. Android is free, open-source operating system and is based on modified version of Linux kernel. Open Handset Alliance (OHA) developed the Android and Google commercially sponsored it. It is mainly designed for touchscreen
      3 min read

      Software Setup and Configuration

      Download and Install Java Development Kit (JDK) on Windows, Mac, and Linux
      Java Development Kit (JDK) is one of the most important tools for developers who use it to build, compile, and run Java applications. It does not matter if you are a beginner or an experienced programmer; installing JDK is the first step towards working with Java development. We can download JDK to
      7 min read
      Guide to Install and Setup IntelliJ IDEA for Android App Development
      To start developing Android applications, one has to set up a proper development environment. It facilitates developers to use the tools needed in creating an app and ensure that all operations/processes carried out in a smooth manner. An IDE(Integrated Development Environment) is a complete applica
      5 min read
      Guide to Install and Setup Visual Studio for Android App Development
      To start developing Android applications, one has to set up a proper development environment. It facilitates developers to use the tools needed in creating an app and ensure that all operations/processes carried out in a smooth manner. An IDE(Integrated Development Environment) is a complete applica
      4 min read
      How to Run the Android App on a Real Device?
      The time comes when the Android Studio project is ready and you want to test that application. One can test the application by running the application which can be done in two ways. By running the app on an Android Virtual Device(AVD), andBy running the app on a real device So in this article, we ar
      2 min read
      Resolving frequently occurring errors in Android Development
      This article is for all the beginners who have just started Android development Tools on Eclipse IDE for developing Android applications. Most of the beginners often face errors while developing the android applications. The errors which we are going to discuss in this article are not syntax errors.
      3 min read
      Android Studio Tutorial
      It is stated that "If you give me six hours to chop down a tree then I will spend the first four hours in sharpening the axe". So in the Android Development World if we consider Android Development as the tree then Android Studio should be the axe. Yes, if you are starting Android Development then y
      9 min read

      File Structure & Components

      Components of an Android Application
      There are some necessary building blocks that an Android application consists of. These loosely coupled components are bound by the application manifest file which contains the description of each component and how they interact. The manifest file also contains the app’s metadata, its hardware confi
      3 min read
      Introduction to Activities in Android
      Activity class is one of the very important parts of the Android Component. Any app, don't matter how small it is (in terms of code and scalability), has at least one Activity class. Unlike most programming languages, in which the main() method is the entry point for that program or application to s
      6 min read
      Services in Android with Example
      Services in Android are a special component that facilitates an application to run in the background in order to perform long-running operation tasks. The prime aim of a service is to ensure that the application remains active in the background so that the user can operate multiple applications at t
      10 min read

      Core Topics

      How Does Android App Work?
      Developing an android application involves several processes that happen in a sequential manner. After writing the source code files, when developers click the Run button on the Android studio, plenty of operations and process starts at the backend. Every operation happening in the background is a c
      7 min read
      Activity Lifecycle in Android with Demo App
      In Android, an activity is referred to as one screen in an application. It is very similar to a single window of any desktop application. An Android app consists of one or more screens or activities. Each activity goes through various stages or a lifecycle and is managed by activity stacks. So when
      9 min read
      Introduction to Gradle
      Gradle is an excellent open-source construction tool that is capable of the development of any kind of software. This tool was developed by a gaggle of developers named Hans Dockter, Szczepan Faber Adam Murdoch, Luke Daley, Peter Niederwieser, Daz DeBoer, and Rene Gröschkebefore 13 years before. It
      8 min read
      What is Context in Android?
      Android Applications are popular for a long time and it is evolving to a greater level as users' expectations are that they need to view the data that they want in an easier smoother view. Hence, the android developers must know the important terminologies before developing the app. In Android Progr
      9 min read
      Bundle in Android with Example
      It is known that Intents are used in Android to pass to the data from one activity to another. But there is one another way, that can be used to pass the data from one activity to another in a better way and less code space ie by using Bundles in Android. Android Bundles are generally used for passi
      6 min read
      Activity State Changes In Android with Example
      Prerequisites: Activity lifecycle in android As it is known that every Android app has at least one activity associated with it. When the application begins to execute and runs, there are various state changes that activity goes through. Different events some user-triggered and some system triggered
      6 min read
      Processes and Application Lifecycle in Android
      As an android developer, if one does not know the application lifecycle of android application or does not have in-depth knowledge about it, there are very high chances that the application will not have a good user experience. Not having proper knowledge of the application lifecycle will not affect
      7 min read
      Desugaring in Android
      Google has officially announced Kotlin as a recommended language for Android Development and that's why so many developers are switching from Java to Kotlin for Android development. So day by day new APIs are been introduced in Android by the Google Team and which are available in newer versions of
      4 min read
      Difference Between AndroidX and Android Support Libraries
      Support library packages in Android are a set of code libraries whose prime purpose is to provide backward-compatibility to the code and Android API framework. In the real world, there is a strong possibility that an application that is developed on the latest Android version is used on an older ver
      3 min read
      Memory Leaks in Android
      A memory leak is basically a failure of releasing unused objects from the memory. As a developer one does not need to think about memory allocation, memory deallocation, and garbage collection. All of these are the automatic process that the garbage collector does by itself, but the situation become
      7 min read

      Layout & View

      Layouts in Android UI Design
      Layout Managers (or simply layouts) are said to be extensions of the ViewGroup class. They are used to set the position of child Views within the UI we are building. We can nest the layouts, and therefore we can create arbitrarily complex UIs using a combination of layouts.There is a number of layou
      3 min read
      Android UI Layouts
      Layouts in Android define the user interface and hold UI controls or widgets that appear on the screen of an application. Every Android application consists of View and ViewGroup elements. Since an application contains multiple activities—each representing a separate screen—every activity has multip
      5 min read
      LinearLayout and its Important Attributes with Examples in Android
      LinearLayout is one of the most basic layouts in android studio, that arranges multiple sub-views (UI elements) sequentially in a single direction i.e. horizontal or vertical manner by specifying the android:orientation attribute. If one applies android:orientation="vertical" then elements will be a
      3 min read
      Android LinearLayout in Kotlin
      LinearLayout in Android is a ViewGroup subclass, used to arrange child view elements one by one in a singular direction either horizontally or vertically based on the orientation attribute. We can specify the linear layout orientation using the android:orientation attribute. All the child elements a
      2 min read
      Android RelativeLayout in Kotlin
      RelativeLayout in Android is a ViewGroup subclass, that allows users to position child views relative to each other (e.g., view A to the right of view B) or relative to the parent (e.g., aligned to the top of the parent). Instead of using LinearLayout, we have to use RelativeLayout to design the use
      4 min read
      ConstraintLayout in Android
      ConstraintLayout is the most advanced layout in Android that lets you create complex and responsive UIs while minimizing nested views due to its flat view hierarchy. ConstraintLayout is similar to that of other View Groups which we have seen in Android such as RelativeLayout, LinearLayout, and many
      6 min read
      TextView widget in Android with Examples
      Widget refers to the elements of the UI (User Interface) that help the user interact with the Android App. TextView is one of many such widgets which can be used to improve the UI of the app. TextView refers to the widget which displays some text on the screen based on the layout, size, colour, etc
      5 min read
      TextView in Kotlin
      Android TextView is simply a view that are used to display the text to the user and optionally allow us to modify or edit it. First of all, open Kotlin project in Android Studio. Following steps are used to create Steps to Implement TextViewSteps by Step implementation for creating an application wh
      3 min read
      Working With the TextView in Android
      TextView in Android is one of the basic and important UI elements. This plays a very important role in the UI experience and depends on how the information is displayed to the user. This TextView widget in Android can be dynamized in various contexts. For example, if the important part of the inform
      7 min read
      Autosizing TextView in Android
      If the user is giving the input and the input needs to be shown as TextView and if the user inputs the stuff which can go out of the screen, then in this case the font TextView should be decreased gradually. So, in this article, it has been discussed how the developer can reduce the size of TextView
      6 min read

      Button

      Button in Android
      In Android applications, a Button is a user interface that is used to perform some action when clicked or tapped. It is a very common widget in Android and developers often use it. This article demonstrates how to create a button in Android Studio.Class Hierarchy of the Button Class in Kotlinkotlin.
      3 min read
      How to Add Radio Buttons in an Android Application?
      Android radio button is a widget that can have more than one option to choose from. The user can choose only one option at a time. Each option here refers to a radio button and all the options for the topic are together referred to as Radio Group. Hence, Radio Buttons are used inside a RadioGroup. F
      5 min read
      RadioButton in Kotlin
      Android Radio Button is bi-state button which can either be checked or unchecked. Also, it's working is same as Checkbox except that radio button can not allow to be unchecked once it was selected. Generally, we use RadioButton controls to allow users to select one option from multiple options. By d
      4 min read
      How to add Toggle Button in an Android Application
      ToggleButton is basically a stop/play or on/off button with an indicator light indicating the current state of ToggleButton. ToggleButton is widely used, some examples are on/off audio, Bluetooth, WiFi, hot-spot etc. This is a subclass of Composite Button. ToggleButton allows users to change setting
      3 min read
      ToggleButton in Kotlin
      In Android, the ToggleButton is just like a switch containing two states either ON or OFF which are represented using boolean values true and false respectively. ToggleButton unlike switch does not have a slider interface i.e. we cannot slide to change the states. It is just like a button. In this a
      2 min read
      RadioGroup in Kotlin
      RadioGroup class of Kotlin programming language is used to create a container which holds multiple RadioButtons. The RadioGroup class is beneficial for placing a set of radio buttons inside it because this class adds multiple-exclusion scope feature to the radio buttons. This feature assures that th
      3 min read

      Intent and Intent Filters

      What is Intent in Android?
      In Android, it is quite usual for users to witness a jump from one application to another as a part of the whole process, for example, searching for a location on the browser and witnessing a direct jump into Google Maps or receiving payment links in Messages Application (SMS) and on clicking jumpin
      4 min read
      Implicit and Explicit Intents in Android with Examples
      Pre-requisites: Android App Development Fundamentals for Beginners Guide to Install and Set up Android Studio Android | Starting with the first app/android project Android | Running your first Android app This article aims to tell about the Implicit and Explicit intents and how to use them in an and
      6 min read
      How to Send Data From One Activity to Second Activity in Android?
      This article aims to tell and show how to "Send the data from one activity to second activity using Intent" . In this example, we have two activities, activity_first which are the source activity, and activity_second which is the destination activity. We can send the data using the putExtra() method
      7 min read
      How to open dialer in Android through Intent?
      The phone dialer is an activity available with the Android operating system to call a number. Usually, such activity may or may not have an EditText, for taking the number as input, and a Call button. When the user presses the Call button, it invokes the dialer app activity. Use of 'tel:' prefix is
      3 min read
      Creating Multiple Screen Applications in Android
      This article shows how to create an android application to move from one activity to another using the concept of Explicit Intents. Below are the steps for Creating a Simple Android Application to move from one activity to another activity.Step By Step ImplementationStep 1: Create a New Project in A
      6 min read
      How to Open Camera Through Intent and Display Captured Image in Android?
      The purpose of this article is to show how to open a Camera from inside an App and click the image and then display this image inside the same app. An android application has been developed in this article to achieve this. The opening of the Camera from inside our app is achieved with the help of th
      6 min read

      Toast & RecyclerView

      Toasts for Android Studio
      A toast provides a simple popup message that is displayed on the current activity UI screen (e.g. Main Activity). Example: Syntax:// To get ContextContext context = getApplicationContext(); // Message to displayString text = "Toast message"; // Toast time duration, can also set manual value int dura
      2 min read
      What is Toast and How to Use it in Android with Examples?
      Pre-requisites: Android App Development Fundamentals for BeginnersGuide to Install and Set up Android StudioAndroid | Starting with the first app/android projectAndroid | Running your first Android appWhat is Toast in Android? A Toast is a feedback message. It takes a very little space for displayin
      6 min read
      Android Toast in Kotlin
      A Toast is a short alert message shown on the Android screen for a short interval of time. Android Toast is a short popup notification which is used to display information when we perform any operation in our app. In this tutorial, we shall not just limit ourselves by creating a lame toast but also
      3 min read
      How to Change Toast font in Android?
      A Toast is a feedback message. It takes a very little space for displaying while overall activity is interactive and visible to the user. It disappears after a few seconds. It disappears automatically. If user wants permanent visible message, Notification can be used. Note: Toast disappears automati
      3 min read
      How to add a custom styled Toast in Android
      A Toast is a feedback message. It takes very little space for displaying and it is displayed on top of the main content of an activity, and only remains visible for a short time period. This article explains how to create Custom Toast messages, which has custom background, image, icon, etc, which ar
      4 min read
      RecyclerView in Android with Example
      RecyclerView is a ViewGroup added to the android studio as a successor of the GridView and ListView. It is an improvement on both of them and can be found in the latest v-7 support packages. It has been created to make possible construction of any lists with XML layouts as an item which can be custo
      7 min read
      Android | Horizontal RecyclerView with Examples
      Recycler View is a ViewGroup added to Android Studio as a successor of the GridView and ListView. It is an improvement on both of them and can be found in the latest v-7 support packages. It has been created to make possible construction of any lists with XML layouts as an item which can be customiz
      4 min read
      How to create a nested RecyclerView in Android
      A nested RecyclerView is an implementation of a RecyclerView within a RecyclerView. An example of such a layout can be seen in a variety of apps such as the Play Store, where the outer (parent) RecyclerView is of vertical orientation, whereas the inner (child) RecyclerViews are of horizontal orienta
      5 min read
      How to Create RecyclerView with Multiple ViewType in Android?
      RecyclerView forms a crucial part of the UI in Android app development. It is especially important to optimize memory consumption when displaying a long list of items. A RecyclerView inflates a customized list of items, which can have either similar layouts or multiple distinct layouts. Here, we dev
      6 min read
      RecyclerView using ListView in Android With Example
      RecyclerView is a more flexible and advanced version of ListView and GridView. RecyclerView is used for providing a limited window to a large data set, which means it is used to display a large amount of data that can be scrolled very efficiently by maintaining a limited number of Views. In Recycler
      5 min read
    geeksforgeeks-footer-logo
    Corporate & Communications Address:
    A-143, 7th Floor, Sovereign Corporate Tower, Sector- 136, Noida, Uttar Pradesh (201305)
    Registered Address:
    K 061, Tower K, Gulshan Vivante Apartment, Sector 137, Noida, Gautam Buddh Nagar, Uttar Pradesh, 201305
    GFG App on Play Store GFG App on App Store
    Advertise with us
    • Company
    • About Us
    • Legal
    • Privacy Policy
    • In Media
    • Contact Us
    • Advertise with us
    • GFG Corporate Solution
    • Placement Training Program
    • Languages
    • Python
    • Java
    • C++
    • PHP
    • GoLang
    • SQL
    • R Language
    • Android Tutorial
    • Tutorials Archive
    • DSA
    • Data Structures
    • Algorithms
    • DSA for Beginners
    • Basic DSA Problems
    • DSA Roadmap
    • Top 100 DSA Interview Problems
    • DSA Roadmap by Sandeep Jain
    • All Cheat Sheets
    • Data Science & ML
    • Data Science With Python
    • Data Science For Beginner
    • Machine Learning
    • ML Maths
    • Data Visualisation
    • Pandas
    • NumPy
    • NLP
    • Deep Learning
    • Web Technologies
    • HTML
    • CSS
    • JavaScript
    • TypeScript
    • ReactJS
    • NextJS
    • Bootstrap
    • Web Design
    • Python Tutorial
    • Python Programming Examples
    • Python Projects
    • Python Tkinter
    • Python Web Scraping
    • OpenCV Tutorial
    • Python Interview Question
    • Django
    • Computer Science
    • Operating Systems
    • Computer Network
    • Database Management System
    • Software Engineering
    • Digital Logic Design
    • Engineering Maths
    • Software Development
    • Software Testing
    • DevOps
    • Git
    • Linux
    • AWS
    • Docker
    • Kubernetes
    • Azure
    • GCP
    • DevOps Roadmap
    • System Design
    • High Level Design
    • Low Level Design
    • UML Diagrams
    • Interview Guide
    • Design Patterns
    • OOAD
    • System Design Bootcamp
    • Interview Questions
    • Inteview Preparation
    • Competitive Programming
    • Top DS or Algo for CP
    • Company-Wise Recruitment Process
    • Company-Wise Preparation
    • Aptitude Preparation
    • Puzzles
    • School Subjects
    • Mathematics
    • Physics
    • Chemistry
    • Biology
    • Social Science
    • English Grammar
    • Commerce
    • World GK
    • GeeksforGeeks Videos
    • DSA
    • Python
    • Java
    • C++
    • Web Development
    • Data Science
    • CS Subjects
    @GeeksforGeeks, Sanchhaya Education Private Limited, All rights reserved
    We use cookies to ensure you have the best browsing experience on our website. By using our site, you acknowledge that you have read and understood our Cookie Policy & Privacy Policy
    Lightbox
    Improvement
    Suggest Changes
    Help us improve. Share your suggestions to enhance the article. Contribute your expertise and make a difference in the GeeksforGeeks portal.
    geeksforgeeks-suggest-icon
    Create Improvement
    Enhance the article with your expertise. Contribute to the GeeksforGeeks community and help create better learning resources for all.
    geeksforgeeks-improvement-icon
    Suggest Changes
    min 4 words, max Words Limit:1000

    Thank You!

    Your suggestions are valuable to us.

    What kind of Experience do you want to share?

    Interview Experiences
    Admission Experiences
    Career Journeys
    Work Experiences
    Campus Experiences
    Competitive Exam Experiences