際際滷

際際滷Share a Scribd company logo
Android @Tulug
Lezione 3
By IvanGualandri
Twitter: @Italialinux
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
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)
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
Ricevere e inviare sms
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
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.
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" />
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)...
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();
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();
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)
Spedire SMS - SMSManager/3
Nel nostro caso vogliamo solo spedirlo, senza
tracciamento.
Quindi avremo pi湛 o meno:
smsManager.sendTextMessage(sendTo, null, myMessage, null,
null);
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.
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.
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.
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.
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:
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.
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");
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.
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]);
}
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.
Ricevere SMS - Risultato
Fine...
Grazie per l'attenzione
Ivan

More Related Content

Introduzione alla programmazione android - Android@tulug lezione 3

  • 1. Android @Tulug Lezione 3 By IvanGualandri Twitter: @Italialinux
  • 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.
  • 24. Ricevere SMS - Risultato