PDA

Ver la Versión Completa : Sonido aleatorio al pulsar boton


kaiser75
02/10/13, 19:36:37
Alguien sabe como se puede hacer para que al pulsar un boton se reproduzca un sonido aleatorio desde la carpeta "raw" ?

mocelet
02/10/13, 20:31:14
Hazte un array int[] con todos los R.raw.cosas que tengas como sonido y elige un índice del array al azar con la clase Random y el método nextInt.

Entiendo que ya sabes reproducir un fichero sabiendo su nombre de recurso

kaiser75
03/10/13, 10:20:31
Lo de reproducir sonido si , lo del array int[] y nextInt no, algun tutorial de ayuda?, gracias por tu respuesta mocelet :ok:

mocelet
03/10/13, 10:52:54
Es algo básico de Java... sería algo así:

int[] sonidos = new int[]{R.raw.sonido1, R.raw.sonido2, R.raw.sonido3};
Random r = new Random();
int sonidoAlAzar = sonidos[r.nextInt(sonidos.length)];

kriogeN
03/10/13, 12:59:53
También puedes acceder mediante reflexión a los sonidos, siempre y cuando se llamen como ha puesto de ejemplo mocelet

Random r = new Random();
int sonidoAlAzar = getResources().getIdentifier( "sonido"+r.nextInt(NUMERO_TOTAL_SONIDOS) , "raw" , this.class.getPackageName());

kaiser75
03/10/13, 20:20:11
Pues muchas gracias, voy a probar y ya os digo...:ok:

kaiser75
04/10/13, 21:23:06
He probado los codigos y no me van (igual me equivoco yo al poner los codigos), el de kriogeN me da error en "class"...

Random r = new Random();
int sonidoAlAzar = getResources().getIdentifier( "sonido"+r.nextInt(NUMERO_TOTAL_SONIDOS) , "raw" , this.class.getPackageName());

Me explico, este es el codigo que tengo para que suene el sonido 3.

public class Pagina2 extends Activity implements OnClickListener {

Button btnrandom; // id del boton a pulsar
SoundPool sp; // soundpool
// los Sonidos
int so1 = 0;
int so2 = 0;
int so3 = 0;
int so4 = 0;
}


@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.pagina2);

// el boton para random
btnrandom = (Button) findViewById(R.id.btnrandom);
btnrandom.setOnClickListener(this);

// Cargar Sonidos
sp = new SoundPool(1, AudioManager.STREAM_MUSIC, 0);
so1 =sp.load(this, R.raw.sonido1, 1);
so2 =sp.load(this, R.raw.sonido2, 1);
so3 =sp.load(this, R.raw.sonido3, 1);
so4 =sp.load(this, R.raw.sonido4, 1);
}


@Override
public void onClick(View v) {
// TODO Auto-generated method stu
switch (v.getId()) {
case R.id.btnrandom:
sp.play(so3, 1, 1, 0, 0, 1);
}
}

mocelet
04/10/13, 23:06:33
Empieza por conceptos básicos de programación como los arrays. Si no te vas a perder, antes de meterse con Android hay que tener nociones de Java.

En vez de tener int so1, so2, so3... crea un array int[] sonidos y al ir a reproducir le pasas el índice aleatorio.

kaiser75
05/10/13, 09:56:17
Gracias mocelet :-) , lo de java estoy en ello, es complicado al principio pero no imposible

kaiser75
19/10/13, 20:45:47
He conseguido hacer el random con el boton, pero hay veces que me repite el mismo sonido 2 y 3 veces y luego cambia...a que es debido?

mocelet
19/10/13, 21:28:10
Por la misma razón que en el juego del parchís puedes tirar el dado tres veces y salirte las tres veces el 6 :) Que sea un número aleatorio no te garantiza que sea distinto que el anterior.

Si quieres forzar que sea distinto tendrías que sacar un número al azar, ver si es el mismo de antes y sacar otro número aleatorio en su caso hasta que sea distinto.

kaiser75
21/10/13, 12:09:19
Cuantos mas sonidos añado menos se repiten, hice la prueba con unos 6 sonidos, pero al añadir 20 no se repiten tanto :ok:, lo que pasa es que si lo hago con soundpool va bien pero tarda en cargar y los sonidos mas largos se cortan al reproducirlos, entonces he probado a hacer el random con mediaplayer, que va perfecto solo que por ejemplo pulsas dos veces el boton y se reproducen dos sonidos a la vez, si pulsas 4 reproduce 4 i asi sucesivamente y es molesto, en cambio en la lista de sonidos que tengo si me funciona, pulso un boton y reproduce, si pulsas otro boton para el que se reproduce y suena el nuevo, en cambio con el boton random no, hay manera de parar el sonido que suena en el random?

mocelet
21/10/13, 12:43:34
El MediaPlayer tiene un método stop() y el SoundPool también especificando el identificador del stream... así que si puedes reproducirlo puedes pararlo.

kaiser75
21/10/13, 15:49:00
Si, el metodo stop() me funciona en soundpool, pero en mediaplayer no, en mediaplayer solo me funciona con la lista de sonidos, unos 30 cada uno con su id de boton diferente.
Este es mi codigo, el cual me funciona perfecto, pero con un solo boton random no, no los detiene, seguire investigando haver X-D:

@Override
public void onClick(View v) {
//click boton
switch (v.getId()) {

case R.id.btnrandom:
stopPlaying();
int sonidos = rnd.nextInt(sonidos.length);
final MediaPlayer mp = MediaPlayer.create(Pagina2.this, sonidos[sonidos] );
mp.start();
break;

default:
break;
}
}

// Liberar MediaPlayer y parar sonidos activos
private void stopPlaying() {
if (mp != null) {
mp.stop();
mp.release();
mp = null;
}
}

kriogeN
21/10/13, 16:18:14
Esto es lo que tienes en el "onClick":

final MediaPlayer mp = MediaPlayer.create(Pagina2.this, sonidos[sonidos] );
mp.start();

Y esto en el "stopPlaying":

if (mp != null) {
mp.stop();
mp.release();
mp = null;
}

Y aunque en el fragmento que has puesto no se ve seguro que tienes una variable global llamada:

MediaPlayer mp;

¿De verdad tenemos que explicarte porque el sonido no se para cuando pulsas el stop? Como siempre digo, primero Java, después Android.

Aunque suene muy borde, son errores muy básicos que a poco que depures un poco te das cuenta.

Solución:

Quita el "final MediaPlayer" en la línea:

final MediaPlayer mp = MediaPlayer.create(Pagina2.this, sonidos[sonidos] );

Quedando así:

mp = MediaPlayer.create(Pagina2.this, sonidos[sonidos] );

NOTA: Aunque funcione bien, no queda muy legible tener un array llamado "sonidos" y que su posición también la llames "sonidos".

kaiser75
21/10/13, 18:46:02
Muchas Gracias kriogeN, efectivamente tengo la variable creada "MediaPlayer mp;" ahora si funciona, fallo mio en el "final MediaPlayer"...entendido para la proxima vez :rolleyes:.