We will continue from what we learnt and developed in the previous post. We already have the app running, with a simple interface, but yet to perform the BMI calculations.
Open up the MainActivity.java file, which will contain the codes to control our interface. The file, which was generated by the wizard, currently contains three methods:
- onCreate: This function will be called when the activity is first created. We usually will initialise things, setup variables, or bind views here.
- onCreateOptionMenu: This function will be called to setup the settings menu. This menu is opened when the setting button is pressed, or the three-dots “overflow” button is pressed.
- onOptionsItemSelected: This function will be called when the items in the menu is pressed.
Firstly, we need to have the reference to the widgets/views in the interface. Take a look again in the activity_main.xml file.
You may have noticed these several ids such as tv_results_bmi, tv_result_text, et_height, etc. If you don’t have those, you can write it the properties panel. If you are using the text editor, write it this way: <EditText android:id=”@+id/et_weight” />.
There are no specific ways on how the ids should look like, though I prefer putting tv_ for TextView, and et_ for EditText.
Now lets head back to MainActivity.java. To retrieve these views, use findViewById. In the Java file, we retrieve the ids through the generated R variable, in this case R.id.id_in_file.
The BMI Formula
Let prepare the BMI formula as a function.
Now we need to get inputs and show the results. Typically, there would be a “Calculate” button. To make it simple, I want the results is automatically shown the users as the input is keyed in. So, we need to know when the EditText contents changes. To do this, we need to add a text change listener to both of the weight and height inputs.
In the performCalculations method, I’ve put the codes to retrieve the inputs’ contents using getText function. Also there are Log functions for logging purposes. You will and should utilise this throughout any Android developments. All error, messages pertaining to the app will appear in the LogCat panel.
Sometimes there are users feel cumbersome trying to convert between meters and centimeters. The phone is powerful enough to calculate that, allow the app to that for the users. The tallest man in the world is around 2.5 meters, so lets assume if the user’s input is more than 3 meters, it might be in centimeters. If it is less than that, it should be in meters.
There will be sometime the BMI results will be unrealistic since it is always updated upon input. To make this nicer, we simply put the results as “less than 15″ or “more than 40″, as the numbers in the other ranges are probably not useful anyway. Finally, we put appropriate messages depending on the BMI results.
We should have a fully functional BMI calculator app upon completing this tutorial. In the next post, we can try out some libraries and store the BMI results.
The codes for this part also can be found in this repository. As always, thanks for reading. Feel free to leave comments or questions!