2. Agenda
Invio e ricezione SMS
Broadcast Receiver
Intent
Le applicazioni di esempio relative a
questa lezione le troverete su github:
https://github.com/inuyasha82/ItalialinuxExample/tree/master/LezioniAndroid
3. Riassunto puntate precedenti
Abbiamo visto come gestire i click di
un bottone, facendo implementare
alla nostra activity l'interfaccia
OnClickListener, e implementando il
metodo onClick(View v),
associandolo al bottone mediante il
metodo setOnClickListener(this)
4. Riassunto puntate precedenti/2
Abbiamo visto creare un elemento
via codice e aggiungerlo alla gui. I
passi sono:
Creare l'oggetto che vogliamo
aggiungere
Ottenere un istanza del layout con
findViewById
Aggiungerlo nel layout con il
metodo addView
6. Layout dell'applicazione
Prima di tutto
disegnamo un layout
adeguato per spedire
sms. Dovreste gia
saperlo fare :)
Partiremo dall'invio
sms che dei due 竪 il
pi湛 semplice
7. Spedire SMS - Intro
Android fornisce la maggior parte delle
funzionalit叩 del telefono mediante dei Manager.
Alcuni esmpi:
SMSManager - Gestione SMS
AudioManager - Gestione Audio
BluetoothManager - Gestione Bluetooth.
etc. etc.
8. Spedire SMS - Intro/2
Ovviamente per l'accesso a queste funzionalit叩
ci servono gli adeguati permessi. Da inserire
nel Manifest dell'applicazione. Nel nostro caso
serviranno:
SEND_SMS
RECEIVE_SMS
<uses-permission android:name="android.
permission.SEND_SMS" />
<uses-permission android:name="android.
permission.RECEIVE_SMS" />
9. Spedire SMS - Intro/3
Vediamo il workflow della nostra applicazione
(anche se abbastanza intuitivo):
1. L'utente inserisce il messaggio
2. L'utente inserisce il numero di telefono
3. Preme il pulstante Invia per spedire l'sms.
L'invio verr effettutato quindi sar叩 gestito
dall'evento onClick del bottone.
Ma questo sapete farlo (se avete seguito la
lazione 2)...
10. Spedire SMS - Intro/3
Quindi l'evento onClick deve leggere il testo
contenuto nelle due caselle di testo (messaggio
e numero) e inviarlo attraverso l'SmsManager.
Leggiamo il testo inserito nelle due EditText:
EditText numberinput = (EditText) findViewById(R.id.number) ;
EditText messageinput = (EditText) findViewById(R.id.message) ;
String phoneNumber = numberinput.getText();
String messageText = messageInput.getText();
11. Spedire SMS - SMSManager
Come accennato l'SmsManager 竪 una classe
che ci permette di gestire gli aspetti dell'invio di
un sms direttamente dal nostro programma.
Essendo un servizio offerto dal telefono, non
dobbiamo crearne uno nuovo, ma ottenere
quello esistente.
SmsManager manager = SmsManager.getDefault();
12. Spedire SMS - SMSManager/2
Per spedire il messaggio:
public void sendTextMessage (String destinationAddress, String
scAddress, String text, PendingIntent sentIntent, PendingIntent
deliveryIntent)
destinationAddress 竪 il numero di telefono del
destinatario
text 竪 il messaggio.
scAddress 竪 il numero del service center (se null si usa
quello di default)
sentIntent e deliveryIntent sono utili per tracciare la
spedizione del messaggio (invio in corso, spedito)
13. Spedire SMS - SMSManager/3
Nel nostro caso vogliamo solo spedirlo, senza
tracciamento.
Quindi avremo pi湛 o meno:
smsManager.sendTextMessage(sendTo, null, myMessage, null,
null);
14. Spedire SMS - Come testarlo?
Possiamo usare l'emulatore.
Il numero di telefono si trova nella barra del
titolo (si tratta della porta del debugger). Quindi
apriamo due emulatori su uno girer叩 la nostra
app e l'altro ricever叩 i messaggi.
15. Ricevere SMS - Introduzione
Per ricevere un messaggio dobbiamo far s狸 che la nostra
applicazione sia informata di quando arriva un SMS.
Questo lo facciamo introducendo un nuovo Oggetto:
il BroadCastReceiver
Come la Activity anche questa 竪 una classe astratta, quindi
creeremo una classe che la estende.
Serve per ricevere dati dalle Intent che vengono generate.
16. Ricevere SMS - Nel manifest
Un broadcast receiver, al pari di una activity va registrato
nel manifest, non come activity ma come receiver:
<receiver android:name=".SMSReceiver" android:enabled="true">
<intent-filter>
<action android:name="android.provider.Telephony.
SMS_RECEIVED" />
</intent-filter>
</receiver>
Dove in android:name metteremo il nome della classe
BroadCastReceiver.
17. Ricevere SMS - Intent-filter
<intent-filter>
<action android:name="android.provider.Telephony.
SMS_RECEIVED" />
</intent-filter>
Questo pezzetto di codice informa il sistema che questo
receiver vuole essere "svegliato" solo se si verifica l'action
SMS_RECEIVED.
Le action come dice la parola stessa sono delle azioni che
vengono sollevate dal sistema al verificarsi di alcuni eventi.
18. Ricevere SMS - Creiamo la classe
Andiamo nel package principale e creiamo la classe
SMSReceiver.
public class SMSReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
....
}
}
L'oggetto BroadCastReceiver richiede, per poter essere
chiamato al verificarsi delle action definite,
l'implementazione del metodo onReceive:
19. Ricevere SMS - Ma dove sta l'sms?
@Override
public void onReceive(Context context, Intent intent) {
....
}
A giudicare dalla firma di questo metodo non si vede alcun
SMS al suo interno! :)
Invece non 竪 cos狸, si trova come extra nell'intent.
Le Intent sono una definizione astratta dell'azione che si
vuole eseguire (l'action appunto).
Ricevere un sms genera una Intent RECEIVE_SMS che la
nostra app intercetter.
20. Ricevere SMS - Prendere l'sms/2
Per ottenere l'insieme degli extra di una Intent, possiamo
usare il metodo getExtras, che ci torna un oggetto di tipo
Bundle (un semplice contenitore di variabili).
Bundle bundle = intent.getExtras();
Ogni variabile salvata nel bundle 竪 identificata da una
chiave, e quella del messaggio 竪 chiamata "pdus" quindi
dal bundle prendiamo l'oggetto pdus:
Object[] pdus = (Object[])bundle.get("pdus");
21. Ricevere SMS - Prendere l'sms/3
Object[] pdus = (Object[])bundle.get("pdus");
Ma ancora non basta! Abbiamo un semplice Object
generico, dobbiamo poterlo leggere in qualche modo
L'object[] pdus contiene il o i messaggi ricevuti dal
telefonino.
Per poterli leggere comodamente dobbiamo convertirli in
un oggetto pi湛 specifico: SmsMessage.
22. Ricevere SMS - Prendere l'sms/3
Quindi creiamo una vettore di SmsMessage della stessa
dimensione del vettore pdus:
SmsMessage[] messages = new SmsMessage[pdus.length];
Convertiamo quindi ogni elemento di pdus in SmsMessage,
utilizzando il metodo statico createFromPdu:
for(int i = 0; i < pdus.length; i++){
messages[i] = SmsMessage.createFromPdu((byte[]) pdus[i]);
}
23. Ricevere SMS - Leggere l'sms
Ora possiamo leggere tranquillamente il testo del
messaggio, e in questo esempio mostrarlo su una notifica
Toast:
for(SmsMessage message: messages){
String messagestr = message.getMessageBody();
String sender = message.getOriginatingAddress();
Toast.makeText(context, sender + ": " + messagestr, Toast.
LENGTH_SHORT).show();
}
Dove getMessageBody ritorna il testo del messaggio.
Mentre getOriginatingAddress torna il mittente del
messaggio.