Intro to Android Development
with
by
Parthiban Loganathan
data:image/s3,"s3://crabby-images/86be6/86be6b2c120ff0674fd3ac887e2ec8dfb69406e3" alt=""
data:image/s3,"s3://crabby-images/256b5/256b511a3ad10a28c541059169c19739927ab789" alt=""
Am I ready to become one with the Android?
(aka prereqs)
- You know Java (1004, 1007 is fine)
- You own an Android device
- You want to build cool apps!
What are we going to do today?
- Learn the basic components of a simple Android app
- Go over some app code and see the results
- Learn about amazing libraries you should use to build apps
- Learn how to learn - I'll point you to the best resources for Android
But first...
Let's understand the pros and cons of the Android OS because other mobile platforms do exist... sort of.
data:image/s3,"s3://crabby-images/98347/983479efe593de5b84a7772b7d48385ca6b75189" alt=""
Android is fragmented
data:image/s3,"s3://crabby-images/22503/22503967418278dd334e048a2e2c4bae9e54f625" alt=""
data:image/s3,"s3://crabby-images/f8f8b/f8f8bdd789b34b273fd08ea73e0a2d20e15fd0ee" alt=""
data:image/s3,"s3://crabby-images/ce079/ce079b76cf2320fb2c318f143d4000f4df0d7e86" alt=""
Different screen sizes
Different OS versions
... leading to frustrated Android developers
data:image/s3,"s3://crabby-images/445e0/445e063e306bad80a28f97858da4507b342b19f3" alt=""
Then why Android?
-
52% of US and 85% of the global mobile market + it's growing
-
Growing ecosystem - Android Wear, Google Glass
data:image/s3,"s3://crabby-images/c81ce/c81ce703bb053754205650a5ca3840dc2e2db584" alt=""
No review process from an evil overlord (*cough* Apple *cough*)
data:image/s3,"s3://crabby-images/80e18/80e18f7ddbe724066506fb1fc584e844396504ed" alt=""
Build awesome apps and help the world be a better place!
data:image/s3,"s3://crabby-images/a6077/a607755d5f62164b8a0e9cd5781f8ed663dfadaa" alt=""
data:image/s3,"s3://crabby-images/64fa2/64fa22f90d4f00609e0c5ff5b8d8f09f5105c779" alt=""
Dev Environment
You will need:
- Android Studio with SDK+AVD Manager (https://developer.android.com/sdk/installing/studio.html)
- Android SDK (https://developer.android.com/sdk/installing/index.html?pkg=tools)
- USB drivers for your device if applicable
Setup can sometimes be complicated and often machine specific.
Come to Cookies & Code for help.
Main components of an app
-
Activities (stuff you can see)
-
Services (happen in background)
-
Broadcast receivers (react to system broadcasted messages)
-
Content providers (accessing data)
We will only use Activities today
We will look at
- Building a simple UI in XML
- Reacting to interactions UI in our Activity
- How to store static resources as XML
- How to start activities and use external features of the Android OS
- A very brief overview of using 3rd party libraries, APIs and networking
Architecture Choices?
Doesn't matter at this stage.
Pick your favorite:
- MVC
- MVVM
- VIPER
- JKALDGSDB *
* result of banging head on keyboard
How do I make UIs?
(aka shiny stuff)
- Layouts (View Groups): Organize UI elements in XML
- You can add Views and widgets to these Layouts to organize UI
- Reminiscent of HTML in web development
- Android Studio has a GUI builder (but it stinks)
data:image/s3,"s3://crabby-images/b04b9/b04b9059d11cd52d449f251d95a9d410c48af3ce" alt=""
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:paddingTop="10px"
android:paddingLeft="10px"
<Button
android:id="@+id/sample_button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="@color/white"
android:background="#50AD21"
android:text="Click me!" />
</LinearLayout>
A LinearLayout with a Button
data:image/s3,"s3://crabby-images/a8349/a8349aa3236850a8b803a1e7d6df30e58b1de4dd" alt=""
Activities
- Loosely translates to a single thing you can do. For our purposes, it's a screen.
- Many methods like onCreate(Bundle), onPause()
- Can load your UI layout
- Controllers to react to user interactions
- and much more that we're not going to cover here
data:image/s3,"s3://crabby-images/3a061/3a0611c203074c1129c9dee60d6d7ad856c1a4ee" alt=""
"Controllers"
- React to button presses
- Get text from text boxes
- Perform API requests
Plain old Java + Android specific methods via interfaces to start new activities, access SharedPreferences, etc.
// Get an object that represents the button view declared in the XML
mButton = (Button) findViewById(R.id.sample_button);
// Set an onClickListener to react to it
mButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// Do stuff here on click
}
});
Context
data:image/s3,"s3://crabby-images/b1bce/b1bce8011eab83ebf0018b91dc18995c062f29f8" alt=""
- An instance of context lets you access information about the application environment - global parameters, resources like text, images.
- Need it to write to disk, get GPS data, access volume, handle intents and more
- WARNING: Mishandling context is the biggest source of memory leaks!
Files we will touch
- app/src/main/java/com/adi/awesomeapp/MainActivity.java
- app/src/main/res/layout/activity_main.xml
- app/src/main/res/values/strings.xml
- app/src/main/AndroidManifest.xml
* default project structure varies with different versions of Android Studio (it's still in beta)
Let's look at some real code
data:image/s3,"s3://crabby-images/c3060/c3060ea73165a014362cf4ba3a68e4d220429023" alt=""
Step 1
- We added a blank MainActivity.java which just loads the UI activity_main.xml
- activity_main.xml contains a simple RelativeLayout with a TextView saying "Hello world!" using the resource from strings.xml
Step 2
- We modified activity_main.xml to use a ScrollView with an ImageView that loads a picture of a puppy.
- Changed the message in the TextView by pointing to a different string resource.
Step 3
- We modified activity_main.xml to also contain a Button
- In MainActivity.java, we loaded objects referring to the UI components mImage and mButton. We added an onClickListener to the button which creates a camera intent and starts a new activity.
- The result of the intent is parsed and if the camera succeeded in taking a picture, we read it from disk and set it to the image view.
- We added <uses-feature> to the manifest so that only devices with cameras can download our app on Google Play.
Step 4
I went crazy and added 2 libraries and a bunch of other stuff to let us tweet pictures.
But seriously, the concepts to know are:
- Using threads for network requests to not block the main UI thread
- How to use 3rd party libraries with the gradle build tool.
- How to use features that need permissions (like internet, GPS)
Pro Tips
Remember to handle edge cases - there are a ton of them. Eg - storing state on screen rotation, exiting and resuming app, starting duplicate services by accident, etc.
data:image/s3,"s3://crabby-images/1fe8e/1fe8ea2d097c9d9f7862db6e33a47e4665031895" alt=""
Learn the Activity Life Cycle
data:image/s3,"s3://crabby-images/00efd/00efd7b5a8776d5aeb681323a3e8dfb2c0f64d85" alt=""
...also applies to some stuff I didn't cover like Fragments
Rule of thumb to avoid memory leaks
-
Don't use getBaseContext(). Avoid using activity context to prevent memory leaks. Be wary of passing the context around since it won't be garbage collected.
-
Try getApplicationContext() when possible.
data:image/s3,"s3://crabby-images/f5c5f/f5c5f53a244cc9a5d08523684e46232b3dc46cf7" alt=""
Great libraries to use
data:image/s3,"s3://crabby-images/dafd5/dafd5d3e1ce3d7bd96ed7117c5cf4dd1c8caae12" alt=""
RxJava by Netflix
data:image/s3,"s3://crabby-images/7e588/7e588ffa844008bcc87749e109743074ddd8b04f" alt=""
Flow
Mortar
Dagger
ButterKnife
Retrofit
Full tutorial from ADI
Do Android Developers Dream of Electric Sheep?
github.com/parthibanloganathan/android-tutorial
data:image/s3,"s3://crabby-images/9178c/9178c5ce1fdd1f457108760a8c7950c969ae65de" alt=""
adicu.com/resources > Android
Further learning
-
(bit.ly/1hqDdmv)
-
Programming Mobile Applications for Android Handheld Systems (coursera.org/course/android)
-
Docs (developer.android.com)
data:image/s3,"s3://crabby-images/78212/78212e66af3fffba1f79e6a9b6381612c5e97cfd" alt=""
data:image/s3,"s3://crabby-images/5be86/5be86a9ba5b3c2e33055fa2532e8694fb8d4ae32" alt=""
data:image/s3,"s3://crabby-images/e8401/e840181c5670255ff43ec895979664245b8a8cb1" alt=""
What did we learn today?
- Why Android development
- A rough idea of what comprises an app
- A few good tips and tools to use
- How to learn more about Android on your own
- I use too many memes
data:image/s3,"s3://crabby-images/efe9b/efe9bce0143ad9a082640ddc349c97c56494f7d7" alt=""
data:image/s3,"s3://crabby-images/eaa13/eaa135aeb33db59f76cfd27e2f61d67b82f13526" alt=""
Hopefully you're not too confused...
Contact me at
parthi (at) adicu.com
@parthiban_logan
OR
come to Cookies and Code on Wednesdays at 10 PM in
Satow Room, Lerner 5th Floor
data:image/s3,"s3://crabby-images/8bc24/8bc2403fdb49d17e236da6847fca9956cbf93977" alt=""
data:image/s3,"s3://crabby-images/37d94/37d949cc4e93d564af95c61d254304ab65672812" alt=""
data:image/s3,"s3://crabby-images/106bc/106bcc11aad7b39e81444960eb8a6bf4e117d328" alt=""
Intro to Android Development
By Parthiban Loganathan
Intro to Android Development
- 3,413