Android Services. Services



Similar documents
App Development for Smart Devices. Lec #4: Services and Broadcast Receivers Try It Out

Android Services. Android. Victor Matos

Android For Java Developers. Marko Gargenta Marakana

Android Introduction. Hello Mihail L. Sichitiu 1

Now that we have the Android SDK, Eclipse and Phones all ready to go we can jump into actual Android development.

4. The Android System

Android Persistency: Files

Tutorial #1. Android Application Development Advanced Hello World App

Mobile Application Development

Operating System Support for Inter-Application Monitoring in Android

Android 多 核 心 嵌 入 式 多 媒 體 系 統 設 計 與 實 作

Developing Android Apps: Part 1

App Development for Android. Prabhaker Matet

BEGIN ANDROID JOURNEY IN HOURS

TomTom PRO 82xx PRO.connect developer guide

Android Security Lab WS 2014/15 Lab 1: Android Application Programming

Les Broadcast Receivers...

How To Develop Smart Android Notifications using Google Cloud Messaging Service

directory to "d:\myproject\android". Hereafter, I shall denote the android installed directory as

ANDROID TUTORIAL. Simply Easy Learning by tutorialspoint.com. tutorialspoint.com

Università Degli Studi di Parma. Distributed Systems Group. Android Development. Lecture 2 Android Platform. Marco Picone

Chapter 2 Getting Started

SDK Quick Start Guide

Tutorial: Setup for Android Development

Android Application Model

Using Sensors on the Android Platform. Andreas Terzis Android N00b

Android Java Live and In Action

MMI 2: Mobile Human- Computer Interaction Android

Based on Android 4.0. by Lars Vogel. Version 9.8. Copyright 2009, 2010, 2011, 2012 Lars Vogel Home Tutorials Trainings Books Social

Getting Started With Android

Developing apps for Android OS: Develop an app for interfacing Arduino with Android OS for home automation

Android Development Introduction

Introduction to Android SDK Jordi Linares

CSE476 Mobile Application Development. Yard. Doç. Dr. Tacha Serif Department of Computer Engineering Yeditepe University

Android Development. Marc Mc Loughlin

Android-Entwicklung. Michael secure Stapelberg

Android Fundamentals 1

Location-Based Services Design and Implementation Using Android Platforms

Building an Android client. Rohit Nayak Talentica Software

Android Programming. Android App. Høgskolen i Telemark Telemark University College. Cuong Nguyen,

Beginning Android Application Development

AdFalcon Android SDK Developer's Guide. AdFalcon Mobile Ad Network Product of Noqoush Mobile Media Group

Developing Android Applications: Case Study of Course Design

Android Programming Basics

Getting Started: Creating a Simple App

Android Development Introduction

Mocean Android SDK Developer Guide

ANDROID AS A PLATFORM FOR DATABASE APPLICATION DEVELOPMENT

ECWM511 MOBILE APPLICATION DEVELOPMENT Lecture 1: Introduction to Android

Android Bootcamp. Elaborado (com adaptações) a partir dos tutoriais:

Basics. Bruce Crawford Global Solutions Manager

Admin. Mobile Software Development Framework: Android Activity, View/ViewGroup, External Resources. Recap: TinyOS. Recap: J2ME Framework

PubMatic Android SDK. Developer Guide. For Android SDK Version 4.3.5

TUTORIAL. BUILDING A SIMPLE MAPPING APPLICATION

TUTORIALS AND QUIZ ANDROID APPLICATION SANDEEP REDDY PAKKER. B. Tech in Aurora's Engineering College, 2013 A REPORT

Android Application Development: Hands- On. Dr. Jogesh K. Muppala

MAP524/DPS924 MOBILE APP DEVELOPMENT (ANDROID) MIDTERM TEST OCTOBER 2013 STUDENT NAME STUDENT NUMBER

AN How to build a NFC Application on Android. Application note COMPANY PUBLIC. Rev September Document information

How to develop your own app

Android Concepts and Programming TUTORIAL 1

Internal Services. CSE 5236: Mobile Application Development Instructor: Adam C. Champion Course Coordinator: Dr. Rajiv Ramnath

Woubshet Behutiye ANDROID ECG APPLICATION DEVELOPMENT

Android Apps Development Boot Camp. Ming Chow Lecturer, Tufts University DAC 2011 Monday, June 6, 2011

andbook! Android Programming written by Nicolas Gramlich release with Tutorials from the anddev.org-community.

Android Development Tutorial

Developing Sensor Applications on Intel Atom Processor-Based Android* Phones and Tablets

ANDROID APPS DEVELOPMENT FOR MOBILE AND TABLET DEVICE (LEVEL I)

Saindo da zona de conforto resolvi aprender Android! by Daniel Baccin

Obsoleted chapter from The Busy Coder's Guide to Advanced Android Development

Building Your First App

Arduino & Android. A How to on interfacing these two devices. Bryant Tram

Android Environment SDK

Developing an Android App. CSC207 Fall 2014

Hacking your Droid ADITYA GUPTA

An Android-based Instant Message Application

HERE SDK for Android. Developer's Guide. Online Version 2.1

06 Team Project: Android Development Crash Course; Project Introduction

Android Environment SDK

Presenting Android Development in the CS Curriculum

Advantages. manage port forwarding, set breakpoints, and view thread and process information directly

Tutorial for developing the Snake Game in Android: What is Android?

Localization and Resources

App Development for Smart Devices. Lec #5: Android Sensors

By sending messages into a queue, we can time these messages to exit the cue and call specific functions.

Transcription:

Android Notes are based on: Android Developers http://developer.android.com/index.html 22. Android Android A Service is an application component that runs in the background, not interacting with the user, for an indefinite period of time. Note that services, like other application objects, run in the main thread of their hosting process. This means that, if your service is going to do any CPU intensive (such as MP3 playback) or blocking (such as networking) operations, it should spawn its own thread in which to do that work. Each service class must have a corresponding <service> declaration in its package's AndroidManifest.xml. can be started with Context.startService() and Context.bindService(). 2

22. Android Android Multiple calls to Context.startService() do not nest (though they do result in multiple corresponding calls to the onstart() method of the Service class), so no matter how many times it is started a service will be stopped once Context.stopService() or stopself() is called. A service can be started and allowed to run until someone stops it or it stops itself. Only one stopservice() call is needed to stop the service, no matter how many times startservice() was called. 3 22. Android Service Life Cycle Like an activity, a service has lifecycle methods that you can implement to monitor changes in its state. But they are fewer than the activity methods only three and they are public, not protected: 1. void oncreate () 2. void onstart (Intent intent) 3. void ondestroy () oncreate onstart ondestroy 4

22. Android Service Life Cycle The entire lifetime of a service happens between the time oncreate() is called and the time ondestroy() returns. Like an activity, a service does its initial setup in oncreate(), and releases all remaining resources in ondestroy(). For example, a music playback service could create the thread where the music will be played in oncreate(), and then stop the thread in ondestroy(). 5 22. Android Broadcast Receiver Lifecycle A Broadcast Receiver is an application class that listens for Intents that are broadcast, rather than being sent to a single target application/activity. The system delivers a broadcast Intent to all interested broadcast receivers, which handle the Intent sequentially. 6

22. Android Registering a Broadcast Receiver You can either dynamically register an instance of this class with Context.registerReceiver() or statically publish an implementation through the <receiver> tag in your AndroidManifest.xml. 7 22. Android Broadcast Receiver Lifecycle A broadcast receiver has a single callback method: void onreceive (Context curcontext, Intent broadcastmsg) 1. When a broadcast message arrives for the receiver, Android calls its onreceive() method and passes it the Intent object containing the message. 2. The broadcast receiver is considered to be active only while it is executing this method. 3. When onreceive() returns, it is inactive. 8

22. Android, BroadcastReceivers and the AdroidManifest The manifest of applications using Android must include: 1. A <service> entry for each service used in the application. 2. If the application defines a BroadcastReceiver as an independent class, it must include a <receiver> clause identifying the component. In addition an <intent-filter> entry is needed to declare the actual filter the service and the receiver use. See example 9 22. Android, BroadcastReceivers and the AdroidManifest <?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="bim224.demos" android:versioncode="1" android:versionname="1.0.0"> <uses-sdk android:minsdkversion="4"></uses-sdk> <application android:icon="@drawable/icon" android:label="@string/app_name"> <activity android:name= 1 <intent-filter> <action android:name="android.intent.action.main" /> <category android:name="android.intent.category.launcher" /> </intent-filter> </activity> <service android:name=".myservice2" /> <receiver android:name=".mybroadcastreceiver"> <intent-filter> <action android:name = "bim224.action.goservice2" /> </intent-filter> </receiver> </application> </manifest> 10

22. Android Types of Broadcasts There are two major classes of broadcasts that can be received: 1. Normal broadcasts (sent with Context.sendBroadcast) are completely asynchronous. All receivers of the broadcast are run in an undefined order, often at the same time. 2. Ordered broadcasts (sent with Context.sendOrderedBroadcast) are delivered to one receiver at a time. As each receiver executes in turn, it can propagate a result to the next receiver, or it can completely abort the broadcast so that it won't be passed to other receivers. The order receivers run in can be controlled with the android:priority attribute of the matching intent-filter; receivers with the same priority will be run in an arbitrary order. 11 22. Android Useful Methods The Driver Assume main activity MyService2Driver wants to interact with a service called MyService2. The main activity is responsible for the following tasks: 1. Start the service called MyService2. Intent intentmyservice = new Intent(this, MyService2.class); Service myservice = startservice(intentmyservice); 2. filter and register local receiver IntentFilter mainfilter = new IntentFilter("bim224.action.GOSERVICE2"); BroadcastReceiver receiver = new MyMainLocalReceiver(); registerreceiver(receiver, mainfilter); 3. Implement local receiver and override its main method public void onreceive(context localcontext, Intent callerintent) 12

22. Android Useful Methods The Service Assume main activity MyService2Driver wants to interact with a service called MyService2. The Service uses its onstart method to do the following: 1. Create an Intent with the appropriate broadcast filter (any number of receivers could match it). Intent myfilteredresponse = new Intent("bim224.action.GOSERVICE2"); myservicedata receiver(s) Object msg = some user data goes here; myfilteredresponse.putextra("myservicedata", msg); 3. Release the intent to all receivers matching the filter sendbroadcast(myfilteredresponse); 13 22. Android Useful Methods The Driver (again) Assume main activity MyService2Driver wants to interact with a service called MyService2. The main activity is responsible for cleanly terminating the service. Do the following 1. Assume intentmyservice is the original Intent used to start the service. Calling the termination of the service is accomplished by the method stopservice(new Intent(intentMyService) ); ondestroy method to assure that all of its running threads are terminated and the receiver is unregistered. unregisterreceiver(receiver); 14

22. Android Example 1. A very Simple Service The main application starts a service. The service prints lines on the DDMS LogCat until the main activity stops the service. No IPC occurs in the example. // a simple service is started & stopped package bim224.demos; import android.app.activity; import android.content.componentname; import android.content.intent; import android.os.bundle; import android.view.view; import android.view.view.onclicklistener; import android.widget.*; public class ServiceDriver1 extends Activity { TextView txtmsg; Button btnstopservice; ComponentName service; Intent intentmyservice; 15 22. Android Example 1. cont. public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.main); txtmsg = (TextView) findviewbyid(r.id.txtmsg); intentmyservice = new Intent(this, MyService1.class); service = startservice(intentmyservice); btnstopservice = (Button) findviewbyid(r.id.btnstopservice); btnstopservice.setonclicklistener(new OnClickListener() { public void onclick(view v) { try { stopservice((intentmyservice) ); txtmsg.settext("after stoping Service: \n" + service.getclassname()); catch (Exception e) { Toast.makeText(getApplicationContext(), e.getmessage(), 1).show(); ); 16

22. Android Example 1. cont. //non CPU intensive service running the main task in its main thread package bim224.demos; import android.app.service; import android.content.intent; import android.os.ibinder; import android.util.log; public class MyService1 extends Service { public IBinder onbind(intent arg0) { return null; public void oncreate() { super.oncreate(); Log.i ("<<MyService1-onCreate>>", "I am alive-1!"); public void onstart(intent intent, int startid) { super.onstart(intent, startid); Log.i ("<<MyService1-onStart>>", "I did something very quickly"); public void ondestroy() { super.ondestroy(); Log.i ("<<MyService1-onDestroy>>", "I am dead-1"); //MyService1 17 22. Android Example 1. cont. According to the Log 1. Main Activity is started (no displayed yet) 2. Service is started (oncreate, onstart) 3. Main Activity UI is displayed 4. User stops Service 18

22. Android Example 1. cont. Manifest <?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="cis493.demos" android:versioncode="1" android:versionname="1.0"> <application android:icon="@drawable/icon" android:label="@string/app_name"> <activity android:name=".servicedriver1" android:label="@string/app_name"> <intent-filter> <action android:name="android.intent.action.main" /> <category android:name="android.intent.category.launcher" /> </intent-filter> </activity> <service android:name=".myservice1"> </service> </application> <uses-sdk android:minsdkversion="4" /> </manifest> 19 22. Android Example 1. cont. Layout <?xml version="1.0" encoding="utf-8"?> <AbsoluteLayout android:id="@+id/widget32" android:layout_width="fill_parent" android:layout_height="fill_parent" xmlns:android="http://schemas.android.com/apk/res/android" > <EditText android:id="@+id/txtmsg" android:layout_width="fill_parent" android:layout_height="120px" android:textsize="18sp" android:layout_x="0px" android:layout_y="57px" > </EditText> <Button android:id="@+id/btnstopservice" android:layout_width="151px" android:layout_height="wrap_content" android:text=" Stop Service" android:layout_x="43px" android:layout_y="200px" > </Button> </AbsoluteLayout> 20

22. Android Example2. Realistic Activity-Service Interaction 1. The main activity starts the service and registers a receiver. 2. The service is slow, therefore it runs in a parallel thread its time consuming task. 3. When done with a computing cycle, the service adds a message to an intent. 4. The intent is broadcasted using the filter: bim224.action.goservice2. 5. A BroadcastReceiver (defined inside the main Activity) uses the previous filter and catches the message (displays the contents on the main UI ). 6. At some point the main activity stops the service and finishes executing. 21 22. Android Example 2. Layout <?xml version="1.0" encoding="utf-8"?> <LinearLayout android:id="@+id/widget32" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" xmlns:android="http://schemas.android.com/apk/res/android" > <EditText android:id="@+id/txtmsg" android:layout_width="fill_parent" android:layout_height="120px" android:textsize="12sp" > </EditText> <Button android:id="@+id/btnstopservice" android:layout_width="151px" android:layout_height="wrap_content" android:text="stop Service" > </Button> </LinearLayout> 22

22. Android Example 2. Manifest <?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="bim224.demos" android:versioncode="1" android:versionname="1.0.0"> <uses-sdk android:minsdkversion="4"></uses-sdk> <application android:icon="@drawable/icon" android:label="@string/app_name"> <activity android:name=".myservicedriver2" android:label="@string/app_name"> <intent-filter> <action android:name="android.intent.action.main" /> <category android:name="android.intent.category.launcher" /> </intent-filter> </activity> <service android:name=".myservice2"> </service> </application> </manifest> 23 22. Android Example 2. Main Activity // Application logic and its BroadcastReceiver in the same class package bim224.demos; import java.util.date; import android.app.activity; import android.content.broadcastreceiver; import android.content.componentname; import android.content.context; import android.content.intent; import android.content.intentfilter; import android.os.bundle; import android.os.systemclock; import android.util.log; import android.view.view; import android.view.view.onclicklistener; import android.widget.*; public class MyServiceDriver2 extends Activity { TextView txtmsg; Button btnstopservice; ComponentName service; Intent intentmyservice; BroadcastReceiver receiver; 24

22. Android Example 2. Main Activity public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.main); txtmsg = (TextView) findviewbyid(r.id.txtmsg); intentmyservice = new Intent(this, MyService3.class); service = startservice(intentmyservice); start txtmsg.settext("myservice2 started - (see DDMS Log)"); btnstopservice = (Button) findviewbyid(r.id.btnstopservice); btnstopservice.setonclicklistener(new OnClickListener() { public void onclick(view v) { try { stopservice(new Intent(intentMyService) ); stop txtmsg.settext("after stopping service: \n"+ service.getclassname()); catch (Exception e) { e.printstacktrace(); ); 25 22. Android Example 2. Main Activity // register & define filter for local listener IntentFilter mainfilter = new IntentFilter("bim224.action.GOSERVICE2"); receiver = new MyMainLocalReceiver(); registerreceiver(receiver, mainfilter); //oncreate register //////////////////////////////////////////////////////////////////////// protected void ondestroy() { super.ondestroy(); try { stopservice(intentmyservice); unregister unregisterreceiver(receiver); catch (Exception e) { Log.e ("MAIN2-DESTROY>>>", e.getmessage() ); Log.e ("MAIN2-DESTROY>>>", "Bye" ); //ondestroy 26

22. Android Example 2. Main Activity ////////////////////////////////////////////////////////////////////// // local (embedded) RECEIVER public class MyMainLocalReceiver extends BroadcastReceiver { public void onreceive(context localcontext, Intent callerintent) { Get String servicedata = callerintent.getstringextra("servicedata"); data Log.e ("MAIN>>>", servicedata + " -receiving data " + SystemClock.elapsedRealtime() ); String now = "\n" + servicedata + " --- " + new Date().toLocaleString(); txtmsg.append(now); //MyMainLocalReceiver //MyServiceDriver4 27 22. Android Example 2. The Service // Service3 uses a thread to run slow operation package bim224.demos; import android.app.service; import android.content.intent; import android.os.ibinder; import android.util.log; public class MyService2 extends Service { boolean isrunning = true; public IBinder onbind(intent arg0) { return null; public void oncreate() { super.oncreate(); 28

22. Android Example 2. The Service public void onstart(intent intent, int startid) { super.onstart(intent, startid); Log.e ("<<MyService2-onStart>>", "I am alive-2!"); // we place the slow work of the service in its own thread // so the caller is not hung up waiting for us Thread triggerservice = new Thread ( new Runnable(){ long startingtime = System.currentTimeMillis(); long tics = 0; public void run() { for(int i=0; (i< 120) & isrunning; i++) { //at most 10 minutes try { //fake that you are very busy here tics = System.currentTimeMillis() - startingtime; Set filter Intent myfilteredresponse = new Intent("bim224.action.GOSERVICE2"); String msg = i + " value: " + tics; myfilteredresponse.putextra("servicedata", msg); broadcasting sendbroadcast(myfilteredresponse); Thread.sleep(5000); //five seconds catch (Exception e) { e.printstacktrace(); //for //run ); triggerservice.start(); //onstart 29 22. Android Example 2. The Service public void ondestroy() { super.ondestroy(); Log.e ("<<MyService2-onDestroy>>", "I am dead-2"); isrunning = false; //ondestroy Stop thread //MyService3 30

Android - Location Location Example Obtain Location from GPS. In this example we request GPS services and display latitude and longitude values on the UI. Additionally we deliver an SMS with this information. Notes 1. Observe the GPS chip is not a synchronous device that will immediately respond to a give me a GPS reading 1. In order to engineer a good solution that takes into account the potential delays in obtaining location data we place the UI in the main activity and the request for location call in a background service. 2. Remember the service runs in the same process space as the main activity, therefore for the sake of responsiveness we must place the logic for location data request in a separate parallel thread. 3. A thread (unlike an Activity) needs the presence of a Looper control to manage IPC message sending. This implies and additional Looper.prepare and Looper.loop methods surrounding the locationupdate method. 23

Android - Location Location Example Obtain Location from GPS 24

Android - Location Location Example Obtain Location from GPS. 5556 5554 Use the DDMS > Emulator Control panel to enter test data reflecting Latitude and Longitude. Select emulator 5554. transmit the data. A text message will be sent to a second emulator (5556) 25

Android - Location Location Example Obtain Location from GPS. Layout <?xml version="1.0" encoding="utf-8"?> <LinearLayout android:id="@+id/widget32" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" xmlns:android="http://schemas.android.com/apk/res/android" > <EditText android:id="@+id/txtmsg" android:layout_width="fill_parent" android:layout_height="120px" android:textsize="12sp" > </EditText> <Button android:id="@+id/btnstopservice" android:layout_width="151px" android:layout_height="wrap_content" android:text="stop Service" > </Button> </LinearLayout> 26

Android - Location Location Example Obtain Location from GPS. Manifest <?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="bim224.mappinggps" android:versioncode="1" android:versionname="1.0"> <application android:icon="@drawable/icon" android:label="@string/app_name" android:debuggable="true" > <activity android:name=".mygps" android:label="@string/app_name"> <intent-filter> <action android:name="android.intent.action.main" /> <category android:name="android.intent.category.launcher" /> </intent-filter> </activity> <service android:name=".mygpsservice"> </service> </application> <uses-sdk android:minsdkversion="2" /> <uses-permission android:name="android.permission.send_sms" /> <uses-permission android:name="android.permission.access_fine_location" /> </manifest> 27

Android - Location Location Example Obtain Location from GPS. Main Activity: MyGPS // Request GPS location, show lat & long, deliver a text-message // Application logic and its BroadcastReceiver in the same class package bim224.mappinggps; import android.app.activity; import android.os.bundle; import android.content.broadcastreceiver; import android.content.componentname; import android.content.context; import android.content.intent; import android.content.intentfilter; import android.telephony.gsm.smsmanager; import android.util.log; import android.view.view; import android.view.view.onclicklistener; import android.widget.*; 28

Android - Location Location Example Obtain Location from GPS. Main Activity: MyGPS public class MyGPS extends Activity { Button btnstopservice; TextView txtmsg; Intent intentmyservice; ComponentName service; BroadcastReceiver receiver; String GPS_FILTER = "bim224.action.gps_location"; 29

Android - Location Location Example Obtain Location from GPS. Main Activity: MyGPS public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.main); txtmsg = (TextView) findviewbyid(r.id.txtmsg); // initiate the service intentmyservice = new Intent(this, MyGpsService.class); service = startservice(intentmyservice); txtmsg.settext("mygpsservice started - (see DDMS Log)"); // register & define filter for local listener IntentFilter mainfilter = new IntentFilter(GPS_FILTER); receiver = new MyMainLocalReceiver(); registerreceiver(receiver, mainfilter); 30

Android - Location Location Example Obtain Location from GPS. Main Activity: MyGPS btnstopservice = (Button) findviewbyid(r.id.btnstopservice); btnstopservice.setonclicklistener(new OnClickListener() { public void onclick(view v) { try { stopservice(new Intent(intentMyService) ); ); txtmsg.settext("after stoping Service: \n" + service.getclassname()); btnstopservice.settext("finished"); btnstopservice.setclickable(false); catch (Exception e) { Log.e("MYGPS", e.getmessage() ); //oncreate 31

Android - Location Location Example Obtain Location from GPS. Main Activity: MyGPS //////////////////////////////////////////////////////////////////////// protected void ondestroy() { super.ondestroy(); try { stopservice(intentmyservice); unregisterreceiver(receiver); catch (Exception e) { Log.e ("MAIN-DESTROY>>>", e.getmessage() ); Log.e ("MAIN-DESTROY>>>", "Adios" ); // ondestroy 32

Android - Location Location Example Obtain Location from GPS. Main Activity: MyGPS ////////////////////////////////////////////////////////////////////// // local RECEIVER private class MyMainLocalReceiver extends BroadcastReceiver { public void onreceive(context localcontext, Intent callerintent) { double latitude = callerintent.getdoubleextra("latitude",-1); double longitude = callerintent.getdoubleextra("longitude",-1); Log.e ("MAIN>>>", Double.toString(latitude)); Log.e ("MAIN>>>", Double.toString(longitude)); String msg = " lat: " + Double.toString(latitude) + " " + " lon: " + Double.toString(longitude); txtmsg.append("\n" + msg); //testing the SMS-texting feature texting(msg); //MyMainLocalReceiver 33

Android - Location Location Example Obtain Location from GPS. Main Activity: MyGPS ////////////////////////////////////////////////////////////// // sending a TEXT MESSAGE private void texting(string msg){ try { SmsManager smsmgr = SmsManager.getDefault(); // Parameter of sendtextmessage are: // destinationaddress, senderaddress, // text, sentintent, deliveryintent) //---------------------------------------------------------- smsmgr.sendtextmessage("5556", "5551234", "Please meet me at: " + msg, null, null); catch (Exception e) { Toast.makeText(this, "texting\n" + e.getmessage(), 1).show(); // texting //MyGPS 34

Android - Location Location Example Obtain Location from GPS. Main Activity: MyGpsService // This is the GPS service. Requests location updates // in a parallel thread. sends broadcast using filter. package bim224.mappinggps; import android.app.service; import android.content.context; import android.content.intent; import android.location.location; import android.location.locationlistener; import android.location.locationmanager; import android.os.bundle; import android.os.ibinder; import android.os.looper; import android.util.log; import android.widget.toast; public class MyGpsService extends Service { String GPS_FILTER = "bim224.action.gps_location"; Thread triggerservice; LocationManager lm; GPSListener mylocationlistener; boolean isrunning = true; 35

Android - Location Location Example Obtain Location from GPS. Main Activity: MyGpsService public IBinder onbind(intent arg0) { return null; public void oncreate() { super.oncreate(); public void onstart(intent intent, int startid) { super.onstart(intent, startid); Log.e("<<MyGpsService-onStart>>", "I am alive-gps!"); // we place the slow work of the service in its own thread so the // response we send our caller who run a "startservice(...)" method // gets a quick OK from us. 36

Android - Location Location Example Obtain Location from GPS. Main Activity: MyGpsServive triggerservice = new Thread(new Runnable() { public void run() { try { Looper.prepare(); // try to get your GPS location using the LOCATION.SERVIVE provider lm = (LocationManager) getsystemservice(context.location_service); // This listener will catch and disseminate location updates mylocationlistener = new GPSListener(); long mintime = 10000; // frequency update: 10 seconds float mindistance = 50; // frequency update: 50 meter lm.requestlocationupdates( //request GPS updates LocationManager.GPS_PROVIDER, mintime, mindistance, mylocationlistener); Looper.loop(); catch (Exception e) { Log.e("MYGPS", e.getmessage() ); // run ); triggerservice.start(); // onstart 37

Android - Location Location Example Obtain Location from GPS. Main Activity: MyGpsServive ///////////////////////////////////////////////////////////////////////// // location listener becomes aware of the GPS data and sends a broadcast private class GPSListener implements LocationListener { public void onlocationchanged(location location) { //capture location data sent by current provider double latitude = location.getlatitude(); double longitude = location.getlongitude(); //assemble data bundle to be broadcasted Intent myfilteredresponse = new Intent(GPS_FILTER); myfilteredresponse.putextra("latitude", latitude); myfilteredresponse.putextra("longitude", longitude); Log.e(">>GPS_Service<<", "Lat:" + latitude + " lon:" + longitude); //send the location data out sendbroadcast(myfilteredresponse); 38

Android - Location Location Example Obtain Location from GPS. Main Activity: MyGpsServive public void onproviderdisabled(string provider) { public void onproviderenabled(string provider) { public void onstatuschanged(string provider, int status, Bundle extras) { ;//GPSListener class // MyService3 interface 39

22. Android Questions 31