Una de las características que más llamó la atención desde el primer dispositivo Android, es la implementación de diferentes tipos sensores, los cuales no parecen tener límites en los nuevos dispositivos que salen a la luz (¿De verdad se necesita un barómetro en el móvil?) y a la par de ello, su implementación a través de código se realiza de manera sencilla y rápida.
Para el manejo de los diferentes sensores disponibles es necesario hacer uso de estas clases:
- Sensor, que representa al sensor de turno que estamos por utilizar.
- SensorManager, que nos permite acceder a los sensores del dispositivo y la Interfaz.
- SensorEventListener, que registra los cambios hechos en el sensor indicado con eso podemos empezar a registrar los cambios hechos en los sensores, y ahora…
Crear la Interfaz a utilizar
Para poder ver los cambios registrados por los sensores de nuestros dispositivos, vamos a implementar en nuestra interfaz dos TextView que nos permitirá mostrar el valor de los cambios ocurridos en nuestros sensores.
Código :
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent"> <TextView android:id = "@+id/etiqSensorDeMovimiento" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="@string/etiqSensorDeMovimiento"> </TextView> <TextView android:id = "@+id/sensorDeMovimiento" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="@string/hello"> </TextView> <TextView android:id = "@+id/etiqSensorDeOrientacion" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="@string/etiqSensorDeOrientacion"> </TextView> <TextView android:id="@+id/sensorDeOrientacion" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="@string/hello"> </TextView> </LinearLayout>
Crear la Actividad
La actividad que vamos a crear hereda de Activity para otorgarle las características de una actividad e implementa SensorEventListener para el registro de cambios en el sensor.
Código :
public class SensorActivity extends Activity implements SensorEventListener{
Definir las variables a utilizar
En este caso, he definido 5 variables del tipo Sensor, los cuales utilizaré para guardar una instancia de cada sensor que pueda detectar usando un objeto de SensorManager, y 2 objetos de TextView, los cuales ya definimos en la interfaz y modificaremos a través de código.
Código :
private SensorManager sensorManager = null; private Sensor sensorDeTemperatura = null; private Sensor sensorDeProximidad = null; private Sensor sensorDeLuz = null; private Sensor sensorAcelerometro = null; private Sensor sensorDeOrientacion = null; private TextView textViewAcelerometro = null; private TextView textViewOrientacion = null;
Detección de Sensores
Para poder obtener instancias de los sensores embebidos en el dispositivo Android, se utiliza SensorManager a través de la llamada al método getSystemService() que nos retorna un servicio a nivel de sistema, dependiendo del parámetro que le pasemos, en este caso SENSOR_SERVICE, pues queremos hacer uso de los sensores.
Una vez inicializado sensorManager, podemos hacer uso de este objeto para solicitar instancias de los diferentes tipo de sensores haciendo uso del método getDefaultSensor() y añadiendo el tipo de sensor que queremos como parámetro.
Código :
public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); sensorManager = (SensorManager) getSystemService(SENSOR_SERVICE); sensorDeProximidad = sensorManager.getDefaultSensor(Sensor.TYPE_PROXIMITY); sensorDeTemperatura = sensorManager.getDefaultSensor(Sensor.TYPE_TEMPERATURE); sensorDeLuz = sensorManager.getDefaultSensor(Sensor.TYPE_LIGHT); sensorAcelerometro = sensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER); sensorDeOrientacion = sensorManager.getDefaultSensor(Sensor.TYPE_ORIENTATION);
Registro del manejador de Eventos de los sensores
Existe la posibilidad de que nuestro dispositivo no tenga todos estos sensores que pensamos, por ejemplo, en el dispositivo que yo estoy utilizando no hay sensor de Temperatura, por lo que siempre es buena idea hacer un filtro que nos permita identificar con cuáles sí contamos, y añadir el manejador de eventos de acuerdo a eso.
El siguiente código lo hace de una manera sencilla: si el sensor existe, registra el manejador de eventos usando el método registerListener() del objeto sensorManager, al que se le pasa como parámetros la clase que está implementando la interfaz SensorEventListener, el sensor que se quiera registrar y la velocidad de registro de cambios en el sensor.
Código :
if(sensorAcelerometro == null){ Toast.makeText(getApplicationContext(), "No hay Sensor movimiento", Toast.LENGTH_SHORT).show(); } else{ Toast.makeText(getApplicationContext(), "Hay Sensor de movimiento", Toast.LENGTH_SHORT).show(); sensorManager.registerListener(this, sensorAcelerometro, SensorManager.SENSOR_DELAY_NORMAL); } if(sensorDeProximidad == null){ Toast.makeText(getApplicationContext(), "No hay Sensor de Proximidad", Toast.LENGTH_SHORT).show(); } else{ Toast.makeText(getApplicationContext(), "Hay Sensor de Proximidad", Toast.LENGTH_SHORT).show(); sensorManager.registerListener(this, sensorDeProximidad, SensorManager.SENSOR_DELAY_NORMAL); } if(sensorDeLuz == null){ Toast.makeText(getApplicationContext(), "No hay Sensor de Luz", Toast.LENGTH_SHORT).show(); } else{ Toast.makeText(getApplicationContext(), "Hay Sensor de Luz", Toast.LENGTH_SHORT).show(); sensorManager.registerListener(this, sensorDeLuz, SensorManager.SENSOR_DELAY_NORMAL); } if(sensorDeTemperatura == null){ Toast.makeText(getApplicationContext(), "No hay sensor de Temperatura", Toast.LENGTH_SHORT).show(); } else{ Toast.makeText(getApplicationContext(), "Hay sensor de Temperatura", Toast.LENGTH_SHORT).show(); sensorManager.registerListener(this, sensorDeTemperatura, SensorManager.SENSOR_DELAY_NORMAL); } if(sensorDeOrientacion == null){ Toast.makeText(getApplicationContext(), "No hay sensor de Orientacion", Toast.LENGTH_SHORT).show(); } else{ Toast.makeText(getApplicationContext(), "Hay sensor de Orientacion", Toast.LENGTH_SHORT).show(); sensorManager.registerListener(this, sensorDeOrientacion, SensorManager.SENSOR_DELAY_NORMAL); }
Registro de Variables de la Interfaz
Esta parte es sencilla, es sólo inicializar los TextView definidos en la interfaz anterior
Código :
setContentView(R.layout.main); textViewAcelerometro = (TextView) findViewById(R.id.sensorDeMovimiento); textViewAcelerometro.setTextSize(30); textViewOrientacion = (TextView) findViewById(R.id.sensorDeOrientacion); textViewOrientacion.setTextSize(30); }
Implementación de los métodos de la Interfaz
La Interfaz SensorEventListener nos pide implementar 2 métodos:
- onAccuracyChanged(Sensor sensor, int accuracy), en la cual implementaremos las acciones a realizar cuando se cambia la precisión de un sensor.
- onSensorChanged(SensorEvent event), la cual nos permite implementar las acciones a realizar cuando un sensor registre un cambio.
Código :
@Override public void onAccuracyChanged(Sensor arg0, int arg1) { } @Override public void onSensorChanged(SensorEvent arg0) { synchronized (this){ float[] masData; float x; float y; float z; // TODO Auto-generated method stub switch(arg0.sensor.getType()){ case Sensor.TYPE_PROXIMITY: masData = arg0.values; if(masData[0]==0){ textViewAcelerometro.setTextSize(textViewAcelerometro.getTextSize()+10); } else{ textViewAcelerometro.setTextSize(textViewAcelerometro.getTextSize()-10); } break; case Sensor.TYPE_ACCELEROMETER: masData = arg0.values; x = masData[0]; y = masData[1]; z = masData[2]; textViewAcelerometro.setText("x: " + x + "\ny: "+y + "\nz: "+z); break; case Sensor.TYPE_ORIENTATION: masData = arg0.values; x = masData[0]; y = masData[1]; textViewOrientacion.setText("x: " + x + "\ny: "+y); break; default: break; } } }
En este caso se ha implementado de manera que muestre en un TextView las variaciones registradas por los sensores.
Recomendaciones
El uso de los sensores requiere de más energía por parte de la aplicación a diferencia de las que no lo hacen, por lo que es recomendable liberar al manejador de eventos cuando se vaya a salir de la aplicación e implementarla de nuevo cuando se vaya a hacer uso de ésta nuevamente. Esto se puede hacer de la siguiente manera:
Código :
@Override protected void onResume() { super.onResume(); sensorManager.registerListener(this,sensorManager.getDefaultSensor(Sensor.TYPE_PROXIMITY),SensorManager.SENSOR_DELAY_NORMAL); } @Override protected void onPause() { sensorManager.unregisterListener(this); super.onStop(); }
Espero les sea de utilidad este tutorial, dudas, preguntas, quejas o sugerencias, nos encontramos en los comentarios más abajo, si les gustó no se olviden de compartir =)
ENJOY!!!
¿Sabes SQL? ¿No-SQL? Aprende MySQL, PostgreSQL, MongoDB, Redis y más con el Curso Profesional de Bases de Datos que empieza el martes, en vivo.
Por Acreonte el 01 de Mayo de 2012
Interesante el tutorial, lastima que no puedo jugar con ello porque no se donde escribir el codigo ni como compilarlo...
Por kerpie el 01 de Mayo de 2012
Esta programado en Eclipse, usando java puro y duro, para que lo compiles tienes que instalarte el android sdk y el adt desde developer.google.com, y seguir los pasos que te indican ahi mismo.
Saludos! =)
Por virtualblog1 el 02 de Mayo de 2012
Acreonte :
Interesante el tutorial, lastima que no puedo jugar con ello porque no se donde escribir el codigo ni como compilarlo...
el lenguaje es java
es cierto aveces las personas comparten buena información como esta pero es normal que se tienda a olvidar que no todos saben de que trata exactamente el tema, que se esta haciendo, que necesito e.t.c por eso estaré viendo si mañana publico un tutorial acerca de la programación para android, aunque el que lo pongan el la portada no depende de mi, pero igual are lo posible
buen trabajo kerpie!!
Por hanselacacia el 22 de Octubre de 2012
Por Fredy el 15 de Julio de 2013
Saludos desde colombia.
Visca el Barca
Por nando-7a el 05 de Septiembre de 2013
face:fernando almaraz
e amil: [email protected]
[email protected]
Por Capppa el 08 de Noviembre de 2013
Estoy aprendiendo a programar android, pero estoy en los inicios.. uff
Mi pregunta es que debo modificar de este codigo.
Ahora mismo con el sensor de proximidad pasa dos imagenes.
que tendria que añadir par aque fueran mas imagenes.
graciassss saludosss
package com.example.sen;
import android.app.Activity;
import android.hardware.Sensor;
import android.hardware.SensorEvent;
import android.hardware.SensorEventListener;
import android.hardware.SensorManager;
import android.os.Bundle;
import android.widget.ImageView;
public class MainActivity extends Activity implements SensorEventListener {
private SensorManager mSensorManager;
private Sensor mSensor;
ImageView iv;
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mSensorManager = (SensorManager)getSystemService(SENSOR_SERVICE);
mSensor = mSensorManager.getDefaultSensor(Sensor.TYPE_PROXIMITY);
iv=(ImageView)findViewById(R.id.imageView1);
}
protected void onResume() {
super.onResume();
mSensorManager.registerListener(this, mSensor, SensorManager.SENSOR_DELAY_NORMAL);
}
protected void onPause() {
super.onPause();
mSensorManager.unregisterListener(this);
}
public void onAccuracyChanged(Sensor sensor, int accuracy) {
}
Por Capppa el 08 de Noviembre de 2013
Estoy aprendiendo a programar android, pero estoy en los inicios.. uff
Mi pregunta es que debo modificar de este codigo.
Ahora mismo con el sensor de proximidad pasa dos imagenes.
que tendria que añadir par aque fueran mas imagenes.
graciassss saludosss
package com.example.sen;
import android.app.Activity;
import android.hardware.Sensor;
import android.hardware.SensorEvent;
import android.hardware.SensorEventListener;
import android.hardware.SensorManager;
import android.os.Bundle;
import android.widget.ImageView;
public class MainActivity extends Activity implements SensorEventListener {
private SensorManager mSensorManager;
private Sensor mSensor;
ImageView iv;
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mSensorManager = (SensorManager)getSystemService(SENSOR_SERVICE);
mSensor = mSensorManager.getDefaultSensor(Sensor.TYPE_PROXIMITY);
iv=(ImageView)findViewById(R.id.imageView1);
}
protected void onResume() {
super.onResume();
mSensorManager.registerListener(this, mSensor, SensorManager.SENSOR_DELAY_NORMAL);
}
protected void onPause() {
super.onPause();
mSensorManager.unregisterListener(this);
}
public void onAccuracyChanged(Sensor sensor, int accuracy) {
}
public void onSensorChanged(SensorEvent event) {
if(event.values[0] == 9){
iv.setImageResource(R.drawable.near);
}else if(event.values[0] == {
iv.setImageResource(R.drawable.far);
}else if(event.values[0] == 7){
iv.setImageResource(R.drawable.fir);
}
Object status;
return;
}
}
Por brayhan el 23 de Noviembre de 2013
quien sabe como generar un tab en el cual en una pestaña capturo una imagen y los valores del sensor de temperatura y luz y cuando oprima en la otra pestaña me aparece en la cual cada una de las celdas contiene la imgen capturada y los valores de los sensores, no se como hacer para guardar los datos en la primera pestaña y que cuando seleccione la otra pestaña aparezcan alli.
Por Edgar GT el 12 de Mayo de 2014