codes
codes
1. Permissions in AndroidManifest.xml:
xml
CopyEdit
<uses-permission android:name="android.permission.BLUETOOTH"/>
<uses-permission
android:name="android.permission.BLUETOOTH_ADMIN"/>
<uses-permission
android:name="android.permission.ACCESS_FINE_LOCATION"/>
2. Simple activity_main.xml:
xml
CopyEdit
<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="16dp">
<ListView
android:id="@+id/pairingListView"
android:layout_width="match_parent"
android:layout_height="wrap_content"/>
</LinearLayout>
3. Simplified MainActivity.java:
java
CopyEdit
package com.example.bluetoothdevices;
import android.bluetooth.BluetoothAdapter;
import android.bluetooth.BluetoothDevice;
import android.os.Bundle;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import androidx.appcompat.app.AppCompatActivity;
import java.util.Set;
BluetoothAdapter mBluetoothAdapter;
ListView mListView;
@Override
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mListView = findViewById(R.id.pairingListView);
mBluetoothAdapter = BluetoothAdapter.getDefaultAdapter();
Set<BluetoothDevice> pairedDevices =
mBluetoothAdapter.getBondedDevices();
mListView.setAdapter(adapter);
1. Permissions in AndroidManifest.xml:
xml
CopyEdit
<uses-permission android:name="android.permission.BLUETOOTH"/>
<uses-permission
android:name="android.permission.BLUETOOTH_ADMIN"/>
<uses-permission
android:name="android.permission.ACCESS_FINE_LOCATION"/>
In your layout file, you need two buttons to turn on and turn off
Bluetooth.
xml
CopyEdit
<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="16dp"
android:gravity="center">
<Button
android:id="@+id/btnTurnOn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Turn ON Bluetooth"
android:layout_marginBottom="20dp"/>
<Button
android:id="@+id/btnTurnOff"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
</LinearLayout>
Explanation:
java
CopyEdit
package com.example.bluetoothcontrol;
import android.bluetooth.BluetoothAdapter;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;
import androidx.appcompat.app.AppCompatActivity;
BluetoothAdapter mBluetoothAdapter;
@Override
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// Initialize BluetoothAdapter
mBluetoothAdapter = BluetoothAdapter.getDefaultAdapter();
if (mBluetoothAdapter == null) {
return;
btnTurnOn.setOnClickListener(new View.OnClickListener() {
@Override
if (!mBluetoothAdapter.isEnabled()) {
} else {
});
btnTurnOff.setOnClickListener(new View.OnClickListener() {
@Override
if (mBluetoothAdapter.isEnabled()) {
mBluetoothAdapter.disable(); // Turn Bluetooth OFF
} else {
});
✅ Converts:
xml
CopyEdit
<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="24dp"
android:gravity="center">
<EditText
android:id="@+id/temperatureInput"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="Enter Temperature"
android:inputType="numberDecimal" />
<ToggleButton
android:id="@+id/toggleConvert"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textOff="F to C"
android:textOn="C to F"
android:layout_marginTop="16dp"/>
<Button
android:id="@+id/convertButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Convert"
android:layout_marginTop="16dp"/>
<TextView
android:id="@+id/resultText"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Result: "
android:textSize="18sp"
android:layout_marginTop="16dp"/>
</LinearLayout>
🔹 Step 2: Java Code (MainActivity.java)
java
CopyEdit
package com.example.temperatureconverter;
import android.os.Bundle;
import android.view.View;
import android.widget.*;
import androidx.appcompat.app.AppCompatActivity;
EditText temperatureInput;
ToggleButton toggleConvert;
Button convertButton;
TextView resultText;
@Override
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
temperatureInput = findViewById(R.id.temperatureInput);
toggleConvert = findViewById(R.id.toggleConvert);
convertButton = findViewById(R.id.convertButton);
resultText = findViewById(R.id.resultText);
convertButton.setOnClickListener(new View.OnClickListener() {
@Override
return;
double result;
if (toggleConvert.isChecked()) {
// Celsius to Fahrenheit
} else {
// Fahrenheit to Celsius
});
🌼 1. LinearLayout
🔹 Main properties:
android:orientation="vertical" or "horizontal"
Child views appear one after the other in the specified direction.
🔹 Example:
xml
CopyEdit
<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="16dp">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
<EditText
android:layout_width="match_parent"
android:layout_height="wrap_content" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Submit" />
</LinearLayout>
🌼 2. FrameLayout
This is used to stack views on top of each other. Only one view is visible at
a time usually, and the others are hidden or behind.
🔹 Main idea:
🔹 Example:
xml
CopyEdit
<FrameLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ImageView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:src="@drawable/background" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Welcome!"
android:textSize="24sp"
android:textColor="#FFFFFF"
android:layout_gravity="center"/>
</FrameLayout>
💠 What is GridView?
Attribute Description
auto_fit)
android:horizontalSpa
Space between columns
cing
android:verticalSpacin
Space between rows
g
xml
CopyEdit
<GridView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/gridView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:numColumns="2"
android:verticalSpacing="10dp"
android:horizontalSpacing="10dp"
android:gravity="center"
android:columnWidth="100dp"
android:stretchMode="columnWidth"/>
java
CopyEdit
package com.example.gridviewexample;
import android.os.Bundle;
import android.widget.ArrayAdapter;
import android.widget.GridView;
import androidx.appcompat.app.AppCompatActivity;
GridView gridView;
@Override
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
gridView = findViewById(R.id.gridView);
this,
android.R.layout.simple_list_item_1,
items
);
gridView.setAdapter(adapter);
ObjectAnimator.ofFloat()
ObjectAnimator.ofInt()
AnimatorSet (to combine multiple animations)
xml
CopyEdit
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<Button
android:id="@+id/myButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Click Me"
android:layout_centerInParent="true"/>
</RelativeLayout>
java
CopyEdit
package com.example.animationdemo;
import android.animation.ObjectAnimator;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import androidx.appcompat.app.AppCompatActivity;
@Override
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
myButton = findViewById(R.id.myButton);
myButton.setOnClickListener(new View.OnClickListener() {
@Override
animator.setDuration(1000); // 1 second
animator.start();
});
When you click the button, it slides 200 pixels to the right smoothly
in 1 second.
🎯 Goal: A basic login screen with username, password fields, and a login
button using TableLayout.
xml
CopyEdit
<TableLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="24dp"
android:stretchColumns="1">
<TableRow>
<TextView
android:text="Username:"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<EditText
android:id="@+id/editTextUsername"
android:layout_width="match_parent"
android:layout_height="wrap_content"
</TableRow>
<TableRow>
<TextView
android:text="Password:"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<EditText
android:id="@+id/editTextPassword"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="Enter Password"
android:inputType="textPassword" />
</TableRow>
<TableRow>
<View
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1" />
<Button
android:id="@+id/buttonLogin"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Login" />
</TableRow>
</TableLayout>
java
CopyEdit
package com.example.loginpage;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import androidx.appcompat.app.AppCompatActivity;
Button buttonLogin;
@Override
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
editTextUsername = findViewById(R.id.editTextUsername);
editTextPassword = findViewById(R.id.editTextPassword);
buttonLogin = findViewById(R.id.buttonLogin);
buttonLogin.setOnClickListener(new View.OnClickListener() {
@Override
} else {
Toast.makeText(MainActivity.this, "Invalid Credentials",
Toast.LENGTH_SHORT).show();
});
🟡 Component: Button
xml
CopyEdit
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:gravity="center"
android:padding="20dp">
<Button
android:id="@+id/buttonClick"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
</LinearLayout>
java
CopyEdit
package com.example.uicomponent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;
import androidx.appcompat.app.AppCompatActivity;
Button buttonClick;
@Override
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
buttonClick = findViewById(R.id.buttonClick);
buttonClick.setOnClickListener(new View.OnClickListener() {
@Override
});
✅ Output:
When the user taps the “Click Me!” button, a Toast message pops up
saying “Button Clicked!”
What is RelativeLayout?
Common Attributes:
1. XML (activity_main.xml)
xml
CopyEdit
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:padding="16dp">
<TextView
android:id="@+id/usernameLabel"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Username:"
android:layout_alignParentTop="true" />
<EditText
android:id="@+id/usernameField"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_below="@id/usernameLabel"
<TextView
android:id="@+id/passwordLabel"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Password:"
android:layout_below="@id/usernameField"
android:layout_marginTop="16dp" />
<EditText
android:id="@+id/passwordField"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_below="@id/passwordLabel"
android:hint="Enter Password"
android:inputType="textPassword" />
<Button
android:id="@+id/loginButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Login"
android:layout_below="@id/passwordField"
android:layout_marginTop="16dp" />
</RelativeLayout>
It can contain only one child view, but that child can be any layout
or view that supports multiple elements (like LinearLayout or
RelativeLayout).
Attributes of ScrollView:
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fillViewport="true">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:padding="16dp">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
<EditText
android:id="@+id/nameField"
android:layout_width="match_parent"
android:layout_height="wrap_content"
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Email:" />
<EditText
android:id="@+id/emailField"
android:layout_width="match_parent"
android:layout_height="wrap_content"
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
<EditText
android:id="@+id/phoneField"
android:layout_width="match_parent"
android:layout_height="wrap_content"
<Button
android:id="@+id/submitButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Submit"
android:layout_gravity="center_horizontal"
android:layout_marginTop="20dp" />
</LinearLayout>
</ScrollView>
Fragments are used to create flexible and dynamic UIs, especially for
devices with varying screen sizes (e.g., phones and tablets). You can
combine multiple fragments within a single activity to create a more
dynamic UI, enabling better user experience.
Fragment Lifecycle:
Fragments have their own lifecycle methods, which are similar to the
activity lifecycle but with some additional methods specific to fragments:
onCreate()
onCreateView()
onStart()
onResume()
onPause()
onStop()
onDestroy()
xml
CopyEdit
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:gravity="center">
<fragment
android:id="@+id/myFragment"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:name="com.example.myapp.MyFragment" />
</LinearLayout>
Here is the layout for the fragment, where it displays a simple message
using a TextView.
xml
CopyEdit
<FrameLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@android:color/holo_blue_light">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center"
android:textSize="30sp"
android:textColor="@android:color/white" />
</FrameLayout>
xml
CopyEdit
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:gravity="center">
<!-- Radio Buttons to select an option -->
<RadioButton
android:id="@+id/radioButton1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
<RadioButton
android:id="@+id/radioButton2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
<RadioButton
android:id="@+id/radioButton3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
<Button
android:id="@+id/btnShowSelection"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
<TextView
android:id="@+id/tvSelectedOption"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="18sp" />
</LinearLayout>
Here’s the Java code to handle the selection and display the result.
java
CopyEdit
package com.example.radiobuttonexample;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.RadioButton;
import android.widget.TextView;
import androidx.appcompat.app.AppCompatActivity;
Button btnShowSelection;
TextView tvSelectedOption;
@Override
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
radioButton1 = findViewById(R.id.radioButton1);
radioButton2 = findViewById(R.id.radioButton2);
radioButton3 = findViewById(R.id.radioButton3);
btnShowSelection = findViewById(R.id.btnShowSelection);
tvSelectedOption = findViewById(R.id.tvSelectedOption);
// Set button click listener
btnShowSelection.setOnClickListener(new View.OnClickListener() {
@Override
if (radioButton1.isChecked()) {
} else if (radioButton2.isChecked()) {
} else if (radioButton3.isChecked()) {
} else {
});
1) App Signing:
Just mention trusted signatures in your app, and Android will check
them.
To protect certain features, you can create your own permission like
this:
For example, an app that needs to control which other apps can
start one of its activities can declare a permission for this
operation as follows:
<manifest
xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.myapp" > <permission
android:name="com.example.myapp.permission.DEADLY_ACTIVIT
Y" android:label="@string/permlab_deadlyActivity"
android:description="@string/permdesc_deadlyActivity"
android:permissionGroup="android.permission-
group.COST_MONEY" android:protectionLevel="dangerous" /> ...
</manifest>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:id="@+id/textView"
android:gravity="center"
android:textSize="20dp"
android:textColor="#000000"/>
<EditText
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:hint="ID"
android:id="@+id/editid"
android:layout_below="@+id/textView"/>
<EditText
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:hint="Name"
android:id="@+id/editname"
android:layout_below="@+id/editid"/>
<EditText
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:hint="Mobile No."
android:id="@+id/editmobile"
android:layout_below="@+id/editname"/>
<EditText
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:hint="Address"
android:lines="3"
android:id="@+id/editaddress"
android:layout_below="@+id/editmobile"/>
<EditText
android:layout_width="fill_parent"
android:hint="Pin Code"
android:id="@+id/editpincode"
android:layout_below="@+id/editaddress"/>
<Button
android:text="Submit Details"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_below="@+id/editpincode"
android:layout_centerHorizontal="true"
android:id="@+id/button" />
</RelativeLayout>
xml
CopyEdit
<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="16dp">
<EditText
android:id="@+id/edtName"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="Name"/>
<EditText
android:id="@+id/edtEmail"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="Email"/>
<Button
android:id="@+id/btnSubmit"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Submit"/>
</LinearLayout>
java
CopyEdit
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import androidx.appcompat.app.AppCompatActivity;
Button btnSubmit;
@Override
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// Initialize UI components
edtName = findViewById(R.id.edtName);
edtEmail = findViewById(R.id.edtEmail);
btnSubmit = findViewById(R.id.btnSubmit);
btnSubmit.setOnClickListener(new View.OnClickListener() {
@Override
});
activity_main.xml
xml
CopyEdit
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<!-- ListView to display the list of items -->
<ListView
android:id="@+id/listView"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
</LinearLayout>
MainActivity.java
java
CopyEdit
import android.os.Bundle;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import androidx.appcompat.app.AppCompatActivity;
ListView listView;
@Override
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
listView = findViewById(R.id.listView);
String[] items = {
"Item 1",
"Item 2",
"Item 3",
"Item 4",
"Item 5",
"Item 6"
};
listView.setAdapter(adapter);
java
CopyEdit
package com.example.sensordisplay;
import android.hardware.Sensor;
import android.hardware.SensorManager;
import android.os.Bundle;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import androidx.appcompat.app.AppCompatActivity;
import java.util.List;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// Initialize SensorManager
List<Sensor> sensorList =
sensorManager.getSensorList(Sensor.TYPE_ALL);
listView.setAdapter(adapter);
Explanation:
xml
CopyEdit
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<ListView
android:id="@+id/sensorListView"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
</LinearLayout>
2. Set the language: You can set the language for the speech, for
example, English.
3. Convert Text to Speech: Once the text and language are set, you
can trigger the speech conversion.
java
CopyEdit
package com.example.texttospeechdemo;
import android.os.Bundle;
import android.speech.tts.TextToSpeech;
import android.speech.tts.TextToSpeech.OnInitListener;
import android.widget.Button;
import androidx.appcompat.app.AppCompatActivity;
import java.util.Locale;
@Override
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
speakButton = findViewById(R.id.speakButton);
@Override
if (status == TextToSpeech.SUCCESS) {
@Override
if (textToSpeech != null) {
textToSpeech.stop();
textToSpeech.shutdown();
super.onDestroy();
xml
CopyEdit
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:gravity="center"
android:padding="16dp">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Thanks"
android:textSize="30sp"
android:textStyle="bold"/>
<!-- Button to trigger text-to-speech -->
<Button
android:id="@+id/speakButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Click to Speak"
android:textSize="18sp"/>
</LinearLayout>
Explanation:
Button click listener: When the button is clicked, the app speaks
the text "Thanks".
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android
"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<EditText
android:layout_width="wrap_content"
android:hint="Enter a number"
android:id="@+id/number"
android:inputType="number"
android:textSize="30dp"
/>
<Button
android:layout_height="wrap_content"
android:id="@+id/btn1"
android:layout_below="@id/number"
android:textSize="20dp"
android:text="Calculate Factorial"
/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/tv"
android:layout_below="@id/btn1"
android:textSize="20dp"/>
</RelativeLayout>
MainActivity.java
package com.example.factorial;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
public class MainActivity extends AppCompatActivity {
EditText number;
Button btn1;
TextView tv;
int num;
int factor;
String s;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
number=(EditText)findViewById(R.id.number);
btn1=(Button)findViewById(R.id.btn1);
tv=(TextView)findViewById(R.id.tv);
btn1.setOnClickListener(new View.OnClickListener() {
@Override
String strnum;
strnum = number.getText().toString();
num = Integer.parseInt(strnum);
factorial(num);
});
int i = 1;
factor = i;
factor = factor * i;
i++;
tv.setText(s);
Develop the android application for student marksheets using table layout
atleast five subject marks with total and percentage (Write both Java and
xml code)1. Java Code (MainActivity.java):
java
CopyEdit
package com.example.marksheetapp;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TableRow;
import android.widget.TextView;
import androidx.appcompat.app.AppCompatActivity;
Button calculateButton;
@Override
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
subject1 = findViewById(R.id.subject1);
subject2 = findViewById(R.id.subject2);
subject3 = findViewById(R.id.subject3);
subject4 = findViewById(R.id.subject4);
subject5 = findViewById(R.id.subject5);
calculateButton = findViewById(R.id.calculateButton);
totalText = findViewById(R.id.totalText);
percentageText = findViewById(R.id.percentageText);
calculateButton.setOnClickListener(new View.OnClickListener() {
@Override
});
<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="16dp"
android:gravity="center">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Student Marksheet"
android:textSize="20sp"
android:layout_marginBottom="20dp"
android:gravity="center"/>
<TableLayout
android:layout_width="match_parent"
android:layout_height="wrap_content">
<TableRow>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Subject 1:"/>
<EditText
android:id="@+id/subject1"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:inputType="number"
android:hint="Marks"/>
</TableRow>
<TableRow>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Subject 2:"/>
<EditText
android:id="@+id/subject2"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:inputType="number"
android:hint="Marks"/>
</TableRow>
<TableRow>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Subject 3:"/>
<EditText
android:id="@+id/subject3"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:inputType="number"
android:hint="Marks"/>
</TableRow>
<TableRow>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Subject 4:"/>
<EditText
android:id="@+id/subject4"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:inputType="number"
android:hint="Marks"/>
</TableRow>
<!-- Row for Subject 5 -->
<TableRow>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Subject 5:"/>
<EditText
android:id="@+id/subject5"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:inputType="number"
android:hint="Marks"/>
</TableRow>
</TableLayout>
<Button
android:id="@+id/calculateButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Calculate"/>
<TextView
android:id="@+id/totalText"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Total: "/>
<TextView
android:id="@+id/percentageText"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Percentage: "/>
</LinearLayout>
xml
CopyEdit
<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">
<CheckBox
android:id="@+id/checkbox1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
<CheckBox
android:id="@+id/checkbox2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/checkbox3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
<CheckBox
android:id="@+id/checkbox4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
<CheckBox
android:id="@+id/checkbox5"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
<Button
android:id="@+id/button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
<TextView
android:id="@+id/resultText"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="10dp"/>
</LinearLayout>
CopyEdit
import android.os.Bundle;
import android.widget.Button;
import android.widget.CheckBox;
import android.widget.TextView;
import androidx.appcompat.app.AppCompatActivity;
Button button;
TextView resultText;
@Override
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
c1 = findViewById(R.id.checkbox1);
c2 = findViewById(R.id.checkbox2);
c3 = findViewById(R.id.checkbox3);
c4 = findViewById(R.id.checkbox4);
c5 = findViewById(R.id.checkbox5);
button = findViewById(R.id.button);
resultText = findViewById(R.id.resultText);
button.setOnClickListener(v -> {
int count = 0;
if (c1.isChecked()) count++;
if (c2.isChecked()) count++;
if (c3.isChecked()) count++;
if (c4.isChecked()) count++;
if (c5.isChecked()) count++;
});
Ans activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity">
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Student Feedback Form" />
<EditText
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="Name"
android:id="@+id/editname"/>
<EditText
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="Roll No."
android:id="@+id/editrollno"/>
<EditText
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="Class"
android:id="@+id/editclass"/>
<EditText
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="Enter your Feedback"
android:lines="3"
android:id="@+id/editfeedback"/>
<Button
android:text="Submit Feedback"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:id="@+id/button" />
</LinearLayout>
MapsActivity.java
package com.example.feedback;
import androidx.appcompat.app.AppCompatActivity;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity {
SQLiteDatabase sqLiteDatabaseObj;
Button submitBtn;
EditText std_name, std_rollno, std_class, std_feedback;
String sname, srollno, sclass, sfeedback, sql_query;
@Override