bytes.cat

La wiki d'FP d'informàtica

Eines de l'usuari

Eines del lloc


Barra lateral

ASIX Administració de Sistemes Informàtics i Xarxes
Tots els mòduls del cicle
MP01 Implantació de sistemes operatius
Totes les UFs del modul
MP02 Gestió de bases de dades
Totes les UFs del modul
MP03 Programació bàsica
Totes les UFs del modul
MP04 Llenguatges de marques i sistemes de gestió d'informació
Totes les UFs del modul
MP05 Fonaments de maquinari
Totes les UFs del modul
MP06 Administració de sistemes operatius
Totes les UFs del modul
MP07 Planificació i administració de xarxes
Totes les UFs del modul
MP08 Serveis de xarxa i Internet
Totes les UFs del modul
MP09 Implantació d'aplicacions web
Totes les UFs del modul
MP10 Administració de sistemes gestors de bases de dades
Totes les UFs del modul
MP11 Seguretat i alta disponibilitat
Totes les UFs del modul
MP12 Formació i orientació laboral
Totes les UFs del modul
MP13 Empresa i iniciativa emprenedora
Totes les UFs del modul
MP14 Projecte
Totes les UFs del modul
DAM Desenvolupament d’aplicacions multiplataforma
Tots els mòduls del cicle
MP01 Sistemes informàtics
Totes les UFs del modul
MP02 Bases de dades
Totes les UFs del modul
MP03 Programació bàsica
Totes les UFs del modul
MP04 Llenguatges de marques i sistemes de gestió d'informació
Totes les UFs del modul
MP05 Entorns de desenvolupament
Totes les UFs del modul
MP06 Accés a dades
Totes les UFs del modul
MP07 Desenvolupament d’interfícies
Totes les UFs del modul
MP08 Programació multimèdia i dispositius mòbils
Totes les UFs del modul
MP09 Programació de serveis i processos
Totes les UFs del modul
MP10 Sistemes de gestió empresarial
Totes les UFs del modul
MP11 Formació i orientació laboral
Totes les UFs del modul
MP12 Empresa i iniciativa emprenedora
Totes les UFs del modul
MP13 Projecte de síntesi
Totes les UFs del modul
MPDual Mòdul Dual / Projecte
DAW Desenvolupament d’aplicacions web
Tots els mòduls del cicle
MP01 Sistemes informàtics
Totes les UFs del modul
MP02 Bases de dades
Totes les UFs del modul
MP03 Programació
Totes les UFs del modul
MP04 Llenguatge de marques i sistemes de gestió d’informació
Totes les UFs del modul
MP05 Entorns de desenvolupament
Totes les UFs del modul
MP06 Desenvolupament web en entorn client
Totes les UFs del modul
MP07 Desenvolupament web en entorn servidor
Totes les UFs del modul
MP08 Desplegament d'aplicacions web
Totes les UFs del modul
MP09 Disseny d'interfícies web
Totes les UFs del modul
MP10 Formació i Orientació Laboral
Totes les UFs del modul
MP11 Empresa i iniciativa emprenedora
Totes les UFs del modul
MP12 Projecte de síntesi
Totes les UFs del modul
SMX Sistemes Microinformàtics i Xarxes
Tots els mòduls del cicle
MP01 Muntatge i manteniment d’equips
Totes les UFs del modul
MP02 Sistemes Operatius Monolloc
Totes les UFs del modul
MP03 Aplicacions ofimàtiques
Totes les UFs del modul
MP04 Sistemes operatius en xarxa
Totes les UFs del modul
MP05 Xarxes locals
Totes les UFs del modul
MP06 Seguretat informàtica
Totes les UFs del modul
MP07 Serveis de xarxa
Totes les UFs del modul
MP08 Aplicacions Web
Totes les UFs del modul
MP09 Formació i Orientació Laboral
Totes les UFs del modul
MP10 Empresa i iniciativa emprenedora
Totes les UFs del modul
MP11 Anglès
Totes les UFs del modul
MP12 Síntesi
Totes les UFs del modul
CETI Ciberseguretat en Entorns de les Tecnologies de la Informació
Tots els mòduls del cicle
CiberOT Ciberseguretat en Entorns d'Operació
Tots els mòduls del cicle
android_sensors

Sensors de moviment d'Android

eixos-accelerometre.jpg

Referències:


Sensors

Quan parlem de «sensors» en Android solem referir-nos als de moviment: l'acceleròmetre i el giroscopi (brúixola 3D).

També son sensors (però no de moviment) la càmera, el micro, la pantalla tàctil i el GPS.

Si mirem la documentació oficial podrem veure que la llibreria Android disposa dels següents deteccions:

  • Sensor.TYPE_GRAVITY
  • Sensor.TYPE_LINEAR_ACCELERATION
  • Sensor.TYPE_ROTATION_VECTOR
  • Sensor.TYPE_SIGNIFICANT_MOTION
  • Sensor.TYPE_STEP_COUNTER
  • Sensor.TYPE_STEP_DETECTOR
  • Sensor.TYPE_ACCELEROMETER
  • Sensor.TYPE_GYROSCOPE

Els dos darrers son les dades «en cru» tal i com arriben dels sensors. Els altres son mecanismes de la llibreria per facilitar-nos la programació.

Exemple amb dades de l'acceleròmetre

Versió Kotlin

En aquesta versió apareix la clàssica herència de AppCompatActivity però alhora s'aplica la interface SensorEventListener, fet que ens obligarà a implementar els mètodes onSensorChanged i onAccuracyChanged:

MainActivity.kt
class MainActivity : AppCompatActivity(), SensorEventListener {
 
    private lateinit var sensorManager: SensorManager
    private lateinit var accelerometre: Sensor
    private lateinit var binding: ActivityMainBinding
 
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        enableEdgeToEdge()
 
        // Utilitzem bindings per facilitar accés als elements gràfics
        // recorda activar-los a build.gradle.kts afegint:
        // viewBinding { enable = true }
        binding = ActivityMainBinding.inflate(layoutInflater)
        setContentView(binding.root)
 
        // escoltar variacions dels sensors
        sensorManager = getSystemService(
                        Context.SENSOR_SERVICE) as SensorManager
        accelerometre = sensorManager.getDefaultSensor(
                        Sensor.TYPE_ACCELEROMETER) as Sensor
        sensorManager.registerListener(this, accelerometre,
                        SensorManager.SENSOR_DELAY_NORMAL)
    }
 
    override fun onSensorChanged(event: SensorEvent) {
        // emprem les dades del sensor
        val x = event.values[0]
        val y = event.values[1]
        val z = event.values[2]
        // 1g = 9,8 m/s² , què és un valor força alt.
        // Al fer *10 ens acostem als 100, que és el valor màxim per defecte de la ProgressBar
        binding.xProgressBar.progress = abs(x*10.0).toInt()
        binding.yProgressBar.progress = abs(y*10.0).toInt()
        binding.zProgressBar.progress = abs(z*10.0).toInt()
    }
 
    override fun onAccuracyChanged(sensor: Sensor?, accuracy: Int) {
        // TODO("Not yet implemented")
    }
}

Versió Java

Versió amb objecte SensorEventListener que encapsula les callbacks onSensorChanged i onAccuracyChanged:

MainActivity.java
public class MainActivity extends AppCompatActivity {
 
    private SensorManager sensorManager;
    private Sensor sensor;
    SensorEventListener sensorListener;
 
    @Override protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
 
        sensorListener = new SensorEventListener() {
            @Override
            public void onSensorChanged(SensorEvent sensorEvent) {
                // Valors de l'acceleròmetre en m/s^2
                float xAcc = sensorEvent.values[0];
                float yAcc = sensorEvent.values[1];
                float zAcc = sensorEvent.values[2];
 
                // Processament o visualització de dades...
            }
 
            @Override
            public void onAccuracyChanged(Sensor sensor, int i) {
                // Es pot ignorar aquesta CB de moment
            }
        };
 
        // Seleccionem el tipus de sensor (veure doc oficial)
        sensorManager = (SensorManager) getSystemService(Context.SENSOR_SERVICE);        
        sensor = sensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);
 
        // registrem el Listener per capturar els events del sensor
        if( sensor!=null ) {
            sensorManager.registerListener(sensorListener,sensor,
                    SensorManager.SENSOR_DELAY_NORMAL);
        }
    }
}


Exercici

Implementa una app que visualitzi els valors de l'acceleròmetre seguint l'exemple anterior on emprem el Sensor.TYPE_ACCELEROMETER. Tens unes captures de pantalla més a baix de com pots fer la app.

Llença l'app al teu dispositiu mòbil.

Com has de col·locar el mòbil per aconseguir aquests valors (aproximats)?:

tapapp1.jpg tapapp2.jpg tapapp3.jpg

Substitueix els TextView amb número per una ProgressBar, i mostra-ho en valor absolut (si no, els valors negatius no es visualitzaran).

Compara amb el resultat de Sensor.TYPE_LINEAR_ACCELERATION. Quina diferència veus?

Double «thud»

Normalment parlem de tap o double tap per a interaccions de «toc» de la pantalla. Aquest exercici vol detectar «tocs» però no de pantalla, sinó «tocs» a qualsevol part del mòbil. Per això en direm thud enlloc de tap (consultant un sinònim de "tap").

Implementarem un detector de «double thud». No ha de reaccionar amb 1 sol «thud» ni tampoc si ens desplacem ràpid o fem una sacsejada del mòbil.

Una primera aproximació podria ser implementar un comptador de thuds en cadascun dels eixos XYZ. Hauràs d'establir un llindar d'acceleració a partir del qual consideres que ha succeït un «thud». Defineix el llindar en una constant de l'aplicació (fàcilment localitzable i ajustable).

Assegura que al canviar la orientació (portrait/landscape) no es reinicien els comptadors a zero (un canvi d'orientació reconstrueix l'objecte Activity de nou). El mètode més directe és implementar onSaveInstanceState de la Activity Lifecycle.

android_sensors.txt · Darrera modificació: 2025/01/13 18:28 per enric_mieza_sanchez