Los smartphone al no tener los típicos botones de los celulares, su pantalla es sensible al movimiento, esto se llama «touchscreen» y claro, este evento esta disponible para su uso en la programación. Los eventos touch, pueden ser simples (un solo dedo) o multiples (varios dedos), su implementación no es complicada y es justamente lo que haremos en este tutorial, crearemos una aplicación que haga uso del evento touch simple y que muestre en pantalla las coordenadas XY que se realiza al mover el dedo sobre la pantalla.
Herramientas necesarias
– Eclipse indigo con android
Nivel: Android novato, java intermedio
La Aplicación
1. Crea un proyecto nuevo Android Application Project llamado «Touch Me» 🙂
Activity: Blank Activity
Activity Name: TouchActivity
Layout Name: activity_touch
2. Utilizaremos el textView (Hello World!) que se crea por defecto. Seleccionamos, y re nombraremos su ID, clic derecho -> Assign ID… por ID «strXY»
Modificamos también el tamaño que ocupa el textView en la pantalla, para realizar esto, teniendo aún seleccionado el textView:
clic derecho -> Layout Width -> Match Parent
clic derecho -> Layout Height -> Match Parent
Match Parent, hace que el control, en este caso un textView tome las dimensiones de su contenedor
3. Abrimos el archivo TouchActivity.java que se encuentra en la carpeta SRC, el código que tenemos es:
package com.tutorial.touchme; import android.os.Bundle; import android.app.Activity; import android.view.Menu; public class TouchActivity extends Activity { //code here @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_touch); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.touch, menu); //code here return true; } }
Para implementar los eventos Touch, se hace uso de la interface onTouchListener que tiene como único método onTouch:
onTouch( View v, MotionEvent event )
donde View es el elemento que se envía y el segundo es una instancia de la clase Motion Event .
Clase Motion Event
– MotionEvent.getX(): Coordenada X
– MotionEvent.getY(): Coordenada Y
Las coordenadas se miden en pixeles y el punto (0,0) se encuentra en la esquina superior izquierda del view
– MotionEvent.getAction(), retorna el tipo de evento que se produce, los valores pueden ser :
MotionEvent.ACTION_DOWN, se produce cuando el dedo toca la pantalla
MotionEvent.ACTION_MOVE, se produce cuando el dedo se mueve en la pantalla
MotionEvent.ACTION_CANCEL, se produce cuando el evento es cancelado
MotionEvent.ACTION_UP, cuando el dedo deja de tocar la pantalla
4. Dicho todo esto implementamos el código para el evento Touch move, quedando nuestra clase TouchActivity de la siguiente forma:
package com.tutorial.touchme; import android.os.Bundle; import android.app.Activity; import android.view.Menu; import android.view.MotionEvent; import android.view.View; import android.view.View.OnTouchListener; import android.widget.TextView; public class TouchActivity extends Activity { StringBuilder stringBuilder = new StringBuilder(); TextView textView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_touch); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.touch, menu); //new code this.textView = (TextView) findViewById( R.id.strXY ); this.textView.setText("X: ,Y: ");//texto inicial //evento Touch this.textView.setOnTouchListener( new OnTouchListener() { @Override public boolean onTouch( View arg0, MotionEvent arg1 ) { stringBuilder.setLength(0); //si la acción que se recibe es de movimiento if( arg1.getAction() == MotionEvent.ACTION_MOVE ) { stringBuilder.append("Moviendo, X:" + arg1.getX() + ", Y:" + arg1.getY() ); } else { stringBuilder.append( "Detenido, X:" + arg1.getX() + ", Y:" + arg1.getY() ); } //Se muestra en pantalla textView.setText( stringBuilder.toString() ); return true; } }); //end return true; } }
Ejecutamos la aplicación
Proyecto android eclipse
bye 🙂
Yo soy yo :) JC Mouse, Soy orgullosamente boliviano soy fundador y CEO de la web jc-Mouse.net uno de las pocas web en emprendimiento y tecnología en Bolivia.
Toda la información que encuentres en este sitio es y sera completamente gratis siempre, puedes copiar, descargar y re-publicar si así lo deseas en otros blogs o sitios web, solo te pido a cambio que dejes una referencia a esta web. Esto nos ayuda a crecer y seguir aportando. Bye
Enjoy! :)
Cuando se hace uso de programas a veces no importa que este cree más de una instancia al mismo tiempo, por ejemplo podem...
En este tutorial conoceremos una forma de conectar una aplicación en Laravel con tres bases de datos diferentes, 2 en My...
Instagram es una red social y aplicación para subir fotos y videos. Sus usuarios también pueden aplicar efectos fotográf...
1. En la ventana de comandos de matlab escribe «mbuild -setup«, sin comillas y presiona enter. >> mbuild -setup We...
Gallery.io es una herramienta de colaboración gratuita desarrollada por Google para cargar trabajos de diseño, obtener c...
Una Prueba Unitaria, es una forma de comprobar que nuestro código, hace lo que se supone debe hacer; es decir, se asegur...
El gigante tecnologico Google a puesto un bonito Doodle en su buscador que esta fascinando a sus millones de usuarios qu...
WhatsApp anuncio a través de su blog que ya se encuentra disponible la función de envío de fotos y videos TEMPORALES, es...
Muchas de las innovaciones computacionales de la NASA se desarrollaron para ayudar a explorar el espacio, pero ahora la...
TikTok es una plataforma de microvideos muy popular entre los jóvenes el cual cuenta ya con millones de videos cortps de...