#IoT Starter for Android IoT Starter is a demo application for interacting with the IBM Internet of Things (IoT) Foundation. The application turns your mobile device into a sensor that publishes and receives data to and from the cloud using the MQTT protocol.
For the iOS version, refer to IoT Starter for iOS
##Short Description IoT Foundation is a cloud-hosted service to simplify managing all of your IoT devices. It provides functionality for creating recipes which determine how devices communicate with each other. This application demonstrates using an Android device as one of those IoT devices, and provides a variety of events and commands that it can publish or receive data to and from.
IoT events and commands are user defined values used to differentiate the data that you publish or receive. For example, if you have a device that is publishing GPS coordinates, you may choose to publish it as a 'GPS' event. Or, if you want to send a reboot command to a device, you may choose to publish it as a 'system' or 'reboot' command.
The application can publish data to the following IoT event topics:
- Accelerometer (accel event)
- Touchmove (touchmove event)
- Text (text event)
The application can receive data on the following IoT command topics:
- Color (color command)
- Light (light command)
- Text (text command)
- Alert (alert command)
For more information on IoT Foundation, refer to https://internetofthings.ibmcloud.com/#/
##How it works A device that is registered with IoT Foundation may publish and subscribe to data that is presented as either an event or command using the MQTT protocol. The Eclipse Paho MQTT Android Service is used to publish and subscribe to IoT Foundation. This can be downloaded from Eclipse Paho MQTT Android Service.
MQTT is a lightweight messaging protocol that supports publish/subscribe messaging. With MQTT, an application publishes messages to a topic. These messages may then be received by another application that is subscribed to that topic. This allows for a detached messaging network where the subscribers and publishers do not need to be aware of each other. The topics used by this application can be seen in the table below:
##Topics
| Topic | Sample Topic | Sample Message | 
|---|---|---|
| iot-2/evt/your_event_name/fmt/json | iot-2/evt/touchmove/fmt/json | {"d":{"screenX":0,"screenY":0,"deltaX":0,"deltaY":0}} | 
| iot-2/cmd/your_command_name/fmt/json | iot-2/cmd/light/fmt/json | {"d":{"light":"toggle"}} | 
For more information on the MQTT protocol, see http://mqtt.org/
##Try it The IoT Starter application can be used in 2 ways.
In order to connect to IoT Quickstart, all you need to do is specify 'quickstart' as the organization and enter a valid device id. The Auth Token field can be left blank. The device-id is a 12 hexadecimal character MAC address in lower case, without delimiting characters. For example, a36d7c91bf9e. For more details, refer to the Connect to Quickstart recipe.
Once the app is connected, you can see the data visualized by going to IoT Quickstart and entering the same device-id in the MAC address field.
In order to try the application as a registered device, you must have an IoT Foundation organization. This can be done by signing up for an IBM Bluemix trial and creating an instance of the IBM Internet of Things Foundation service. This will create an IoT organization where you can register devices. Next, you must register your device with your organization. When registering your device, create a new device type called Android (case sensitive). More detailed instructions on registering devices can be found at IBM Internet of Things Foundation.
On launching the application for the first time, you will need to enter your credentials to connect your device to the IoT Foundation. The required information to connect your device includes:
- Your Organization ID, e.g. ab1cde
- Your Device ID, e.g. the MAC Address of your device. This should be the same ID as the device that you registered in your IoT Foundation organization.
- Your device authorization token. This is returned when registering your device with the IoT Foundation.
Once you have entered the necessary credentials, you may activate your device as a sensor. Pressing the 'Activate Sensor' button will connect the device to the IoT Foundation and allow it to begin publishing and receiving data.
##Prerequisites Required:
- An IBM Bluemix account. A 30 day trial account is free.
- An Internet of Things service registered in Bluemix.
- An Android SDK installation
##Installation
- To install the application, download this project and import it into an IDE of your choice (IntelliJ, Android Studio, Eclipse, etc).
- Set the project to use your Android SDK installation.
- Set the project libraries to include the Eclipse Paho jar files in the libs directory.
- Run the application.
##Notes In order to really see this demo do something, you must have an application to consume its data and publish data back to the application. For examples, refer to the IoT Starter demo.
##Resources