In the previous article, we have discussed How to create a COVID-19 Tracker Android App which shows only the Global Stats. In this article, we will learn how to create a COVID-19 Tracker Android App which will show the details of any city in any State in India. Details like – Total Active cases, Cured Cases, Deaths, and the total number of confirmed cases of any respective city. Here in this App, let’s track demo of 5 cities and one can change according to his/her needs.
Approach
Step 1: Create a New Project
To create a new project in Android Studio please refer to How to Create/Start a New Project in Android Studio. Note that select Java as the programming language.
Step 2: Now Add Some Files Before writing the XML and Java Code
- Go to app -> res -> values -> colors.xml section and set the colors for the app.
- These Colors are Used In the apps In various Places.
colors.xml
| <?xmlversion="1.0"encoding="utf-8"?><resources>    <colorname="colorPrimary">#024265</color>    <colorname="colorPrimaryDark">#024265</color>    <colorname="colorAccent">#05af9b</color>     <colorname="color_one">#fb7268</color>    <colorname="color_white">#ededf2</color>    <colorname="color_two">#E3E0E0</color>     <colorname="cases">#FFA726</color>    <colorname="recovered">#66BB6A</color>    <colorname="deaths">#EF5350</color>    <colorname="active">#29B6F6</color></resources> | 
- Go to Gradle Scripts -> build.gradle (Module: app) section and import the following dependencies and click the “Sync Now” button to Sync the APP.
- To Learn More About Volley Library Click Here.
implementation ‘com.android.volley:volley:1.1.1’
- Now Go to the app -> manifests -> AndroidManifests.xml section and allow “Internet Permission” because this App will use Internet Permission.
AndroidManifests.xml
| <?xmlversion="1.0"encoding="utf-8"?>    package="com.example.statewise">    <uses-permissionandroid:name="android.permission.INTERNET"/>     <application        android:allowBackup="true"        android:icon="@mipmap/ic_launcher"        android:label="@string/app_name"        android:roundIcon="@mipmap/ic_launcher_round"        android:supportsRtl="true"        android:theme="@style/AppTheme">        <activityandroid:name=".MainActivity">            <intent-filter>                <actionandroid:name="android.intent.action.MAIN"/>                 <categoryandroid:name="android.intent.category.LAUNCHER"/>            </intent-filter>        </activity>    </application> </manifest> | 
Step 3: Use JSON Parsing to fetch data from the website
- Click on this URL- https://api.covid19india.org/state_district_wise.json
- It will Show Data of the whole Country and in this, We Are Going to fetch data from here Only.
Step 4: Design the Layout of the activity_main.xml
- Go to app -> res -> layout -> activity_main.xml
- Add A TextView To the layout: To display GEEKSFORGEEKS at the top of the screen.
- Add A ListView To the Layout: To display the list of cities tracking details on the screen.
activity_main.xml
| <?xmlversion="1.0"encoding="utf-8"?><RelativeLayout    android:layout_width="match_parent"    android:layout_height="match_parent">     <TextView        android:id="@+id/textView"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:layout_alignParentTop="true"        android:layout_centerHorizontal="true"        android:layout_marginTop="17dp"        android:text="GEEKSFORGEEKS"        android:textColor="@color/recovered"        android:textSize="24sp"/>     <ListView        android:id="@+id/listView"        android:layout_width="match_parent"        android:layout_height="550dp"        android:layout_alignParentTop="true"        android:layout_alignParentBottom="true"        android:layout_marginStart="10dp"        android:layout_marginTop="60dp"        android:layout_marginEnd="10dp"        android:layout_marginBottom="10dp"/>   </RelativeLayout> | 
Output UI:
Step 5: Design the Layout for The ListView
- Create A new Layout by right click on the layout folder inside res Folder
- Then Click Layout Resource File and Set the name testing.xml
- Click Finish To save
- Click testing.xml and Start Design UI Layout for the ListView
- The Drawable file used in testing.xml is “arrow upward“. Go to drawable -> New -> Vector Asset and search for “arrow upward” and add it to your file.
testing.xml
| <?xmlversion="1.0"encoding="utf-8"?><RelativeLayout    android:layout_width="match_parent"    android:layout_height="match_parent"    tools:context=".MainActivity">     <LinearLayout        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:layout_margin="10dp"        android:background="@color/color_white"        android:orientation="vertical">         <LinearLayout            android:layout_width="match_parent"            android:layout_height="wrap_content"            android:layout_margin="10dp"            android:orientation="horizontal"            android:weightSum="2">             <LinearLayout                android:layout_width="wrap_content"                android:layout_height="match_parent"                android:layout_gravity="center_vertical"                android:layout_weight="1"                android:orientation="vertical">                 <!--Text view to display City name-->                <TextView                    android:id="@+id/state"                    android:layout_width="210dp"                    android:layout_height="match_parent"                    android:gravity="center_vertical"                    android:text="City Name"                    android:textColor="@color/colorAccent"                    android:textSize="14sp"                    android:textStyle="bold"/>            </LinearLayout>             <LinearLayout                android:layout_width="match_parent"                android:layout_height="wrap_content"                android:layout_weight="1"                android:orientation="vertical">                 <LinearLayout                    android:layout_width="match_parent"                    android:layout_height="match_parent"                    android:orientation="horizontal">                     <!--Text view to display Active Cases-->                    <TextView                        android:layout_width="107dp"                        android:layout_height="match_parent"                        android:gravity="center_horizontal"                        android:text="Active- "                        android:textStyle="bold"/>                     <!--Text view to display Active Cases in Numbers-->                    <TextView                        android:id="@+id/active"                        android:layout_width="72dp"                        android:layout_height="wrap_content"                        android:text="2323223 "                        android:textColor="@color/active"                        android:textStyle="bold"/>                     <!--Image view to display increase in Cases -->                    <ImageView                        android:layout_width="17dp"                        android:layout_height="match_parent"                        android:src="@drawable/change"/>                     <!--Text view to display Todays Active Cases in Numbers-->                    <TextView                        android:id="@+id/incactive"                        android:layout_width="wrap_content"                        android:layout_height="match_parent"                        android:gravity="center_horizontal"                        android:text="32"                        android:textColor="@color/active"                        android:textStyle="bold"/>                </LinearLayout>                 <LinearLayout                    android:layout_width="match_parent"                    android:layout_height="match_parent"                    android:orientation="horizontal">                     <!--Text view to display Cured Cases -->                    <TextView                        android:layout_width="107dp"                        android:layout_height="match_parent"                        android:gravity="center_horizontal"                        android:text="Cured- "                        android:textStyle="bold"/>                     <!--Text view to display Total Cured Cases in Numbers -->                    <TextView                        android:id="@+id/cured"                        android:layout_width="72dp"                        android:layout_height="wrap_content"                        android:text="2323223 "                        android:textColor="@color/recovered"                        android:textStyle="bold"/>                     <!--Image view to display increase in Cases -->                    <ImageView                        android:layout_width="18dp"                        android:layout_height="match_parent"                        android:src="@drawable/change"/>                     <!--Text view to display Todays Cured Cases in Numbers -->                    <TextView                        android:id="@+id/inccured"                        android:layout_width="wrap_content"                        android:layout_height="match_parent"                        android:gravity="center_horizontal"                        android:text="32"                        android:textColor="@color/recovered"                        android:textStyle="bold"/>                 </LinearLayout>                 <LinearLayout                    android:layout_width="match_parent"                    android:layout_height="match_parent"                    android:orientation="horizontal">                     <!--Text view to display deths Cases -->                    <TextView                        android:layout_width="107dp"                        android:layout_height="match_parent"                        android:gravity="center_horizontal"                        android:text="death- "                        android:textStyle="bold"/>                     <!--Text view to display total death Cases in Numbers -->                    <TextView                        android:id="@+id/death"                        android:layout_width="72dp"                        android:layout_height="wrap_content"                        android:text="2323223 "                        android:textColor="@color/deaths"                        android:textStyle="bold"/>                     <!--Image view to display increase in Cases -->                    <ImageView                        android:layout_width="18dp"                        android:layout_height="match_parent"                        android:src="@drawable/change"/>                     <!--Text view to display todays death Cases in Numbers -->                    <TextView                        android:id="@+id/incdeath"                        android:layout_width="wrap_content"                        android:layout_height="match_parent"                        android:gravity="center"                        android:text="32"                        android:textColor="@color/deaths"                        android:textStyle="bold"/>                 </LinearLayout>                 <LinearLayout                    android:layout_width="match_parent"                    android:layout_height="match_parent"                    android:orientation="horizontal">                     <!--Text view to display total Number of cases Cases  -->                    <TextView                        android:layout_width="107dp"                        android:layout_height="match_parent"                        android:gravity="center_horizontal"                        android:text="total- "                        android:textStyle="bold"/>                     <!--Text view to display total Number of cases Cases in Numbers -->                    <TextView                        android:id="@+id/total"                        android:layout_width="match_parent"                        android:layout_height="wrap_content"                        android:text="2323223 "                        android:textStyle="bold"/>                 </LinearLayout>             </LinearLayout>         </LinearLayout>     </LinearLayout>     <View        android:layout_width="391dp"        android:layout_height="6dp"        android:layout_alignParentStart="true"        android:layout_alignParentTop="true"        android:layout_alignParentEnd="true"        android:layout_marginStart="11dp"        android:layout_marginLeft="20dp"        android:layout_marginTop="113dp"        android:layout_marginEnd="10dp"        android:layout_marginRight="20dp"        android:background="@color/color_two"/> </RelativeLayout> | 
Output UI:
Step 6: Create a New JAVA Class to fetch the data we want to fetch from the Website
- Create a new JAVA class name it as Model.java
- Use getters and setters functions to create a function for the data you want to fetch from the website.
Model.java
| publicclassModel {    privateString name, total, death, cured, active, incAct, incDec, incRec;     publicModel(String name, String total, String death, String cured,                 String active, String incAct, String incDec, String incRec)    {        this.name = name;        this.total = total;        this.death = death;        this.cured = cured;        this.active = active;        this.incAct = incAct;        this.incDec = incDec;        this.incRec = incRec;    }     publicString getIncAct()     {        returnincAct;    }     publicvoidsetIncAct(String incAct)     {        this.incAct = incAct;    }     publicString getIncDec()     {        returnincDec;    }     publicvoidsetIncDec(String incDec)     {        this.incDec = incDec;    }     publicString getIncRec()     {        returnincRec;    }     publicvoidsetIncRec(String incRec)    {        this.incRec = incRec;    }     publicString getName()     {        returnname;    }     publicvoidsetName(String name)    {        this.name = name;    }     publicString getTotal()     {        returntotal;    }     publicvoidsetTotal(String total)    {        this.total = total;    }     publicString getDeath()     {        returndeath;    }     publicvoidsetDeath(String death)     {        this.death = death;    }     publicString getCured()     {        returncured;    }     publicvoidsetCured(String cured)    {        this.cured = cured;    }     publicString getActive()    {        returnactive;    }     publicvoidsetActive(String active)    {        this.active = active;    }} | 
Step 7: Create an Adapter Class
Now create a new JAVA Adapter Class to put the data that have fetched into a ListView that has created before.
Java
| importandroid.content.Context;importandroid.view.LayoutInflater;importandroid.view.View;importandroid.view.ViewGroup;importandroid.widget.ArrayAdapter;importandroid.widget.TextView;importandroidx.annotation.NonNull;importandroidx.annotation.Nullable;importjava.util.List; // Create A Class AdapterpublicclassAdapter extendsArrayAdapter<Model> {    privateContext context;    privateList<Model> modelList;         publicAdapter(Context context, List<Model> modelList) {        super(context, R.layout.testing, modelList);                 this.context = context;        this.modelList = modelList;    }     @NonNull    @Override    publicView getView(intposition, @NullableView convertView, @NonNullViewGroup parent) {         View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.testing, null,true);         // In this step we connect the XML with Java File        TextView state = view.findViewById(R.id.state);        TextView active = view.findViewById(R.id.active);        TextView cured = view.findViewById(R.id.cured);        TextView death = view.findViewById(R.id.death);        TextView total = view.findViewById(R.id.total);        TextView incactive = view.findViewById(R.id.incactive);        TextView inccured = view.findViewById(R.id.inccured);        TextView incdeath = view.findViewById(R.id.incdeath);         // Adding Data to modellist        state.setText(modelList.get(position).getName());        active.setText(modelList.get(position).getActive());        cured.setText(modelList.get(position).getCured());        death.setText(modelList.get(position).getDeath());        total.setText(modelList.get(position).getTotal());        incactive.setText(modelList.get(position).getIncAct());        inccured.setText(modelList.get(position).getIncRec());        incdeath.setText(modelList.get(position).getIncDec());         returnview;    }} | 
Step 8: Working with MainActivity.java file
In this file, we are going to use the Volley library. Refer to the comments inside the code to understand the code.
MainActivity.java
| importandroid.os.Bundle;importandroid.widget.ListView;importandroid.widget.Toast;importandroidx.appcompat.app.AppCompatActivity;importcom.android.volley.Request;importcom.android.volley.RequestQueue;importcom.android.volley.Response;importcom.android.volley.VolleyError;importcom.android.volley.toolbox.StringRequest;importcom.android.volley.toolbox.Volley;importorg.json.JSONException;importorg.json.JSONObject;importjava.util.ArrayList;importjava.util.List; publicclassMainActivity extendsAppCompatActivity {     ListView listView;     publicstaticList<Model> modelList = newArrayList<>();    Model model;    Adapter adapter;     @Override    protectedvoidonCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);         listView = findViewById(R.id.listView);        fetchData();     }     privatevoidfetchData() {        // The Link Through Which We Can Fetch Data         StringRequest request = newStringRequest(Request.Method.GET, url, newResponse.Listener<String>() {            @Override            publicvoidonResponse(String response) {                 try{                    // Creating JSON Object                    JSONObject object = newJSONObject(response);                     // From that object we are fetching data                    JSONObject object1 = object.getJSONObject("Uttar Pradesh");                    JSONObject object2 = object1.getJSONObject("districtData");                    JSONObject object3 = object2.getJSONObject("Prayagraj");                    JSONObject object4 = object3.getJSONObject("delta");                      String active = object3.getString("active");                    String confirmed = object3.getString("confirmed");                    String deceased = object3.getString("deceased");                    String recovered = object3.getString("recovered");                     String confInc = object4.getString("confirmed");                    String confDec = object4.getString("deceased");                    String confRec = object4.getString("recovered");                     model = newModel("Prayagraj", confirmed, deceased, recovered, active,                                                                      confInc, confDec, confRec);                    // placing data into the app using AdapterClass                    modelList.add(model);                     // Creating JSON Object                    object3 = object2.getJSONObject("Ballia");                     // From that object we are fetching data                    active = object3.getString("active");                    confirmed = object3.getString("confirmed");                    deceased = object3.getString("deceased");                    recovered = object3.getString("recovered");                    object4 = object3.getJSONObject("delta");                    confInc = object4.getString("confirmed");                    confDec = object4.getString("deceased");                    confRec = object4.getString("recovered");                     model = newModel("Ballia", confirmed, deceased, recovered, active,                                                                   confInc, confDec, confRec);                    // placing data into the app using AdapterClass                    modelList.add(model);                     // Creating JSON Object                    object3 = object2.getJSONObject("Lucknow");                     // From that object we are fetching data                    active = object3.getString("active");                    confirmed = object3.getString("confirmed");                    deceased = object3.getString("deceased");                    recovered = object3.getString("recovered");                    object4 = object3.getJSONObject("delta");                     confInc = object4.getString("confirmed");                    confDec = object4.getString("deceased");                    confRec = object4.getString("recovered");                     model = newModel("Lucknow", confirmed, deceased, recovered, active,                                                                    confInc, confDec, confRec);                    // placing data into the app using AdapterClass                    modelList.add(model);                     // Creating JSON Object                    object3 = object2.getJSONObject("Varanasi");                     // From that object we are fetching data                    active = object3.getString("active");                    confirmed = object3.getString("confirmed");                    deceased = object3.getString("deceased");                    recovered = object3.getString("recovered");                    object4 = object3.getJSONObject("delta");                     confInc = object4.getString("confirmed");                    confDec = object4.getString("deceased");                    confRec = object4.getString("recovered");                     model = newModel("Varanasi", confirmed, deceased, recovered, active,                                                                    confInc, confDec, confRec);                    // placing data into the app using AdapterClass                    modelList.add(model);                     // Creating JSON Object                    object3 = object2.getJSONObject("Agra");                     // From that object we are fetching data                    active = object3.getString("active");                    confirmed = object3.getString("confirmed");                    deceased = object3.getString("deceased");                    recovered = object3.getString("recovered");                    object4 = object3.getJSONObject("delta");                    confInc = object4.getString("confirmed");                    confDec = object4.getString("deceased");                    confRec = object4.getString("recovered");                     model = newModel("Agra", confirmed, deceased, recovered, active,                                                                 confInc, confDec, confRec);                    // placing data into the app using AdapterClass                    modelList.add(model);                     adapter = newAdapter(MainActivity.this, modelList);                    listView.setAdapter(adapter);                     // In case of error it will run                }   catch(JSONException e) {                    e.printStackTrace();                }             }        }, newResponse.ErrorListener() {            @Override            publicvoidonErrorResponse(VolleyError error) {                // In case of error it will run                Toast.makeText(MainActivity.this, error.getMessage(), Toast.LENGTH_SHORT).show();            }        });         RequestQueue requestQueue = Volley.newRequestQueue(this);        requestQueue.add(request);    }} | 


 
                                    








