domingo, 26 de enero de 2014

BroadcastReceiver

BroadcastReceiver

Un broadcastReceiver es un componente que está destinado a recibir y responder ante eventos globales generados por el sistema. como por ejemplo: Bateria baja, llamada entrante, sms recibido... o por otras aplicaciones.

Para registrar un broadcastreceiver existen dos técnicas:


  • Implementar un elemento <receiver> en el archivo AndroidManifest.xml, donde escribiremos el nombre de la clase BroadcastReceiver y enumeramos sus IntentFilter.
  • Realizando en tiempo de ejecución mediante el método registerReceiver de la clase Context.

Igual que ocurre con Service, broadcastReceiver:
  • no tiene IU
  • el código ejecutado en el onReceive() del BroadcastReceiver no debe asumir operaciones de persistencia o de ejecución prolongada.

Ejemplo de funcionamiento:

Interceptar eventos Android. Vamos hacer que el sistema capture el texto de SMS y el emisor de dicho mensaje SMS.

1) Antes de empezar a programar suscribimos este tipo de evento.

Creamos proyecto, lo llamamos: jamelgasBroadcastReceiver.

Una vez creado modificamos el AndroidManifest.xml:


<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.jamelgas.ejemplo.BroadcastReceiver" android:versionCode="1"
android:versionName="1.0">
<uses-sdk android:minSdkVersion="3" />

<application android:icon="@drawable/icon" android:label="@string/app_name">
<activity android:name="BroacastReceiver" android:label="@string/app_name">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<receiver android:name="RecibirSMSEntrante">
<intent-filter>
<action android:name="android.provider.Telephony.SMS_RECEIVED" />
</intent-filter>
</receiver>

</application>

<uses-permission android:name="android.permission.RECEIVE_SMS" />

</manifest>


Hasta ahora lo que se ha realizado es dar permisos a la aplicación para interceptar los mensajes mediante el uses-permission e implementar la clase RecivierSMSEntrante.java que se hereda de BroadcastReceiver.

package com.jamelgas.ejemplo.BroadcastReceiver;

import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.telephony.gsm.SmsMessage;
import android.util.Log;
public class RecibirSMSEntrante extends BroadcastReceiver {
 private final static String LOGTAG = "RecibirSMSEntrante";
 @Override
 public void onReceive(Context context, Intent intent) {
  Log.d(LOGTAG, "SMS recibido");
  Bundle bundle = intent.getExtras();
  if (bundle != null) {
   Object[] pdus = (Object[]) bundle.get("pdus");
   final SmsMessage[] messages = new SmsMessage[pdus.length];
   for (int i = 0; i < pdus.length; i++) {
    messages[i] = SmsMessage.createFromPdu((byte[]) pdus[i]);
    
    String idMensaje = messages[i].getOriginatingAddress();
    String textoMensaje = messages[i].getMessageBody();
    
    Log.d(LOGTAG, "Mensaje recibido: id="+idMensaje+" texto="+textoMensaje);
    
   }
  }
 }
}


El fichero MainActivity.java principal le he llamado BroadcastReceive.java

package com.jamelgas.ejemplo.BroadcastReceiver;

import com.jamelgas.ejemplo.BroadcastReceiver.R;

import android.app.Activity;
import android.os.Bundle;

public class BroadcastReceiver extends Activity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
    }
}


1) Esta aplicación se ejecutará de una manera diferente ya que vamos a realizar un envío de SMS para eso voy usar el perfil DDMS de eclipse.

2) En la opción de emular SMS en "Telephony Actions" enviamos el SMS.

3) Y en LogCat de DDMS vemos a modo de log en tiempo real con su PID asociado como capturamos el id y el mensaje de texto que hemos enviado.

Nota: Como no dispone de IU si lo intentamos ejecutar como aplicación en el emulador nos dará un error.