Create a new Android Project in Android Studio (Start a new Android Studio Project). In the first screen in the Phone and Tablet section, choose Empty Activity. On the sidebar on the left choose Project and open java > student.example.com > MainActivity. This activity is very simple right now but is a fully functional Android application.
Run the project by clicking the green arrow on the toolbar above the editing area, . Android Studio will prompt you to choose a device. Follow the steps in the next task to create a new virtual device.
When the project has opened the MainActivity.java file should be displayed. If not, open it using the Package Explorer pane. You will find it in the src folder.
The Activity should be very simple. It has an onCreate method which is called when the Activity gets started.
The onCreate
method:
setContentView(R.layout.activity_main);
This sets the layout for the Activity.
Go back to MainActivity.java.
Add the following code to the onCreate
method. Make sure the IDs match the ones in your layout.
Button button = findViewById(R.id.button); /* make sure the button ID matches */ final TextView textView = findViewById(R.id.textView); /* make sure the textView ID matches */ button.setOnClickListener(new View.OnClickListener() { int n = 1; @Override public void onClick(View v) { textView.setText("Hello again! " + Integer.toString(n++)); } });
The findViewById calls are used to get the objects corresponding to the Button and the TextView that were already declared. TextView is declared as final in order to be visible inside the View.OnClickListener call (anonymous class). The View.OnClickListener object contains an onClick method which gets executed when the button is pressed. In this case, it updates the TextView to reflect the number of clicks on the button.
Run the project again to see the changes.
Select the Logcat tab (situated by default in the bottom panel of Android Studio). This panel shows all the log entries written by the Android applications running on connected mobile devices or emulators.
It is possible to filter these log entries: above the logs themselves there is a text entry input which allows textual filtering. It accepts Java-style regular expressions. To the left of this text field there is a drop-down which allows you to select verbosity. Choosing a level will only allow messages of that level or higher to be displayed. To the right of the text field there is a drop-down which allows you to create custom filters. Click on it and select Edit Filter Configuration. From here you can create different filters which limit searches scope using PID:, Tag:, Package Name: or Message:.
Import the LogLevel project into Android Studio (File > New > Import Project) and navigate to the project in the archive. Look over the code. Each button has a method attached which calls a static method from the Log class. These methods generate log entries on different levels of importance: d=debug, i=info, w=warning, e=error.
Add another two buttons to the application:
For the second button if the previous entry was an assert entry, then the next entry will also be an assert entry. If there is no previously generated log entry, then a debug entry will be logged.
Use the LogLevel project as a start.
Notice that the EditText box only takes up one line of the screen and there should be some screen space left at the bottom of the screen.
The weight parameter is used to distribute empty screen space to the elements which need it. First, the layout builder will place all the elements for which the size is easy to determine. Then, the empty space will be distributed to the elements with weight, based on their weight: if the total weight of all elements is 4, an element with a weight of 1 will get 1/4 of the empty screen space, an element with 2 weight will get 2/4, and so on.
The Activity goes through a series of different states in its lifecycle. onCreate, onStart, onResume, onPause, onStop, onRestart and onDestroy are the callbacks from the Activity class which inform the activity about transitions through states:
In this exercise we are going to see which lifecycle callback methods are called in different scenarios. For this override the callback methods in the MainActivity. As in the previous task you need to add a Log statement to every callback with its name as in the example:
@Override protected void onStart() { super.onStart(); Log.i("MainActivity", "onStart"); // You can choose any type of log level }
What calls are done when:
Connect to the mobile device/emulator using ADB. ADB can be used from a terminal on all operating systems.
On Windows, the ADB executable can be found in the Android SDK Platform-Tools e.g. D:\Android\sdk\platform-tools\adb.exe.
On Linux, the ADB executable can be launched by issuing the following command:
/home/student/Android/SDK/platform-tools/adb
To get a list of connected devices use can use:
adb devices
To get a shell on the connected device use:
adb shell
Create a text file on your machine. Copy it to the connected device using:
adb push <local> <remote>
where <remote> represents the location on the device where you copy the file e.g. /sdcard/.
The file should be copied to the /sdcard/ partition on the phone. Connect to the device using adb shell, and use cat to check the contents of the file. To copy from the device use:
adb pull <remote> [<local>]
Both push and pull can be used with both directories and files.
To install an application through adb use:
adb install <file>
Install LogLevel.apk (in the laboratory archive). At first if the installation fails due to a signature mismatch, make sure to uninstall the previous LogLevel application from the mobile device.
To check all available options of ADB use:
adb --help