Practical No. 14 Design and Develop a Temperature Converter Android Application

Practical No. 14

Design and Develop a Temperature Converter Android Application


Aim

To design and develop an Android Temperature Converter application that converts:

  • Celsius to Fahrenheit

  • Fahrenheit to Celsius

and displays the text:

Student Name: FirstName LastName

on the application screen.


I. Practical Significance

This practical enables students to:

  • Design a user-friendly Android interface using standard UI components.

  • Accept numeric input and apply arithmetic logic.

  • Handle button click events in Android applications.


II. Industry / Employer Expected Outcome(s)

Students will be able to:

  • Design functional converter applications.

  • Implement event-driven logic.

  • Process user input accurately in mobile applications.


III. Course Level Learning Outcome(s)

CO3 – Develop Android applications using UI components and layouts.


IV. Laboratory Learning Outcome(s)

LLO 14.1 – Design and implement a converter application.


V. Relevant Affective Domain Related Outcomes

  • Promotes curiosity and experimentation.

  • Encourages confidence in applying formulas in real applications.


VI. Relevant Theoretical Background

GUI Components

  • TextView – Display labels and results

  • EditText – Accept numeric input

  • Spinner – Select conversion type

  • Button – Trigger conversion

Event Handling

  • setOnClickListener() is used to perform conversion when the button is clicked.

Temperature Conversion Formula

  • Celsius → Fahrenheit
    F = (C × 9/5) + 32

  • Fahrenheit → Celsius
    C = (F − 32) × 5/9


VII. Application File Structure (Tree Diagram)

TemperatureConverter/
├── app/
│   └── src/
│       └── main/
│           ├── java/com/example/temperatureconverter/
│           │   └── MainActivity.java
│           ├── res/
│           │   ├── layout/
│           │   │   └── activity_main.xml
│           │   ├── values/
│           │   │   ├── strings.xml
│           │   │   └── themes.xml
│           └── AndroidManifest.xml
└── build.gradle

VIII. XML Layout Code

File: activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:padding="20dp">

    <TextView
        android:id="@+id/txtStudent"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Student Name: FirstName LastName"
        android:textSize="18sp"
        android:textStyle="bold"
        android:layout_marginBottom="20dp" />

    <EditText
        android:id="@+id/edtInput"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="Enter Temperature"
        android:inputType="numberDecimal" />

    <Spinner
        android:id="@+id/spinnerType"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginTop="10dp" />

    <Button
        android:id="@+id/btnConvert"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="Convert"
        android:layout_marginTop="15dp" />

    <TextView
        android:id="@+id/txtResult"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Result:"
        android:textSize="16sp"
        android:layout_marginTop="20dp" />

</LinearLayout>

IX. Java Code

File: MainActivity.java

package com.example.temperatureconverter;

import android.os.Bundle;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Spinner;
import android.widget.TextView;
import android.widget.Toast;

import androidx.appcompat.app.AppCompatActivity;

public class MainActivity extends AppCompatActivity {

    EditText edtInput;
    Spinner spinnerType;
    Button btnConvert;
    TextView txtResult;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        edtInput = findViewById(R.id.edtInput);
        spinnerType = findViewById(R.id.spinnerType);
        btnConvert = findViewById(R.id.btnConvert);
        txtResult = findViewById(R.id.txtResult);

        String[] options = {
                "Celsius to Fahrenheit",
                "Fahrenheit to Celsius"
        };

        ArrayAdapter<String> adapter = new ArrayAdapter<>(
                this,
                android.R.layout.simple_spinner_item,
                options
        );
        adapter.setDropDownViewResource(
                android.R.layout.simple_spinner_dropdown_item
        );
        spinnerType.setAdapter(adapter);

        btnConvert.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {

                if (edtInput.getText().toString().isEmpty()) {
                    Toast.makeText(
                            MainActivity.this,
                            "Please enter temperature",
                            Toast.LENGTH_SHORT
                    ).show();
                    return;
                }

                double input =
                        Double.parseDouble(edtInput.getText().toString());
                String selected =
                        spinnerType.getSelectedItem().toString();
                double result;

                if (selected.equals("Celsius to Fahrenheit")) {
                    result = (input * 9 / 5) + 32;
                    txtResult.setText("Result: " + result + " °F");
                } else {
                    result = (input - 32) * 5 / 9;
                    txtResult.setText("Result: " + result + " °C");
                }
            }
        });
    }
}

X. AndroidManifest.xml (Verified)

<application
    android:allowBackup="true"
    android:label="Temperature Converter"
    android:theme="@style/Theme.Material3.DayNight.NoActionBar">

    <activity android:name=".MainActivity">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>

</application>

XI. Expected Output (UI)







Output Description

  • Student name displayed at the top

  • User enters temperature value

  • Conversion type selected using Spinner

  • Converted result displayed after clicking Convert


XII. Result

Thus, a Temperature Converter Android application was successfully designed and developed using UI components, event handling, and mathematical logic, fulfilling the objectives of Practical.


Popular posts from this blog