SD-211 - fix case when the app was sending request on the ui thread
-fix audio hadler -small refactor
This commit is contained in:
@ -1,84 +1,65 @@
|
||||
package com.safemobile.lib.sound;
|
||||
|
||||
import com.safemobile.lib.SM;
|
||||
|
||||
import android.media.AudioFormat;
|
||||
import android.media.AudioManager;
|
||||
import android.media.AudioRecord;
|
||||
import android.media.AudioTrack;
|
||||
import android.media.MediaRecorder;
|
||||
|
||||
import com.safemobile.lib.SM;
|
||||
|
||||
public class RecordingHandle {
|
||||
public Boolean isAlive = false;
|
||||
public Boolean soundNeeded = false;
|
||||
private AudioTrack playDev =null;
|
||||
private int bufferSize;
|
||||
private TCPaudioClient tcp;
|
||||
private int recport = 50002;
|
||||
|
||||
public RecordingHandle(String IP)
|
||||
{
|
||||
private Boolean soundNeeded = false;
|
||||
private AudioTrack playDev = null;
|
||||
|
||||
public RecordingHandle(String ip) {
|
||||
try {
|
||||
tcp = new TCPaudioClient(IP,recport);
|
||||
int sampleRate = 8000;
|
||||
int bufsize = AudioTrack.getMinBufferSize(sampleRate, AudioFormat.CHANNEL_OUT_MONO, AudioFormat.ENCODING_PCM_16BIT);
|
||||
final int RECORDING_PORT = 50003;
|
||||
TCPaudioClient tcp = new TCPaudioClient(ip, RECORDING_PORT);
|
||||
final int sampleRate = 8000;
|
||||
int bufferSize = AudioTrack.getMinBufferSize(sampleRate, AudioFormat.CHANNEL_OUT_MONO, AudioFormat.ENCODING_PCM_16BIT);
|
||||
//init play device
|
||||
playDev = new AudioTrack(AudioManager.STREAM_MUSIC,sampleRate,AudioFormat.CHANNEL_OUT_MONO, AudioFormat.ENCODING_PCM_16BIT,bufsize, AudioTrack.MODE_STREAM);
|
||||
|
||||
tcp.addTCPListener(new ITCPaudioLis()
|
||||
{
|
||||
|
||||
@Override
|
||||
public void dataRecv(TCPaudioEvent event) {
|
||||
byte[] data = event.data();
|
||||
int len = event.len();
|
||||
SM.Debug("recv b:"+len+" data.length:"+data.length);
|
||||
if(data!=null)
|
||||
PlaySound(data, len);
|
||||
|
||||
}
|
||||
playDev = new AudioTrack(AudioManager.STREAM_MUSIC, sampleRate, AudioFormat.CHANNEL_OUT_MONO, AudioFormat.ENCODING_PCM_16BIT, bufferSize, AudioTrack.MODE_STREAM);
|
||||
|
||||
tcp.addTCPListener(event -> {
|
||||
byte[] data = event.data();
|
||||
int len = event.len();
|
||||
SM.Debug("received b:" + len + " data.length:" + data.length);
|
||||
playSound(data);
|
||||
});
|
||||
}
|
||||
catch(Exception ex) {
|
||||
} catch (Exception ex) {
|
||||
SM.Exception("recordings", ex.toString());
|
||||
}
|
||||
}
|
||||
|
||||
private void PlaySound(byte[] data, int len)
|
||||
{
|
||||
if(soundNeeded)
|
||||
{
|
||||
if(playDev.getState() == playDev.STATE_INITIALIZED)
|
||||
{
|
||||
playDev.write(data, 0 , data.length);
|
||||
|
||||
private void playSound(byte[] data) {
|
||||
if (Boolean.TRUE.equals(getSoundNeeded())) {
|
||||
if (playDev.getState() == AudioTrack.STATE_INITIALIZED) {
|
||||
playDev.write(data, 0, data.length);
|
||||
playDev.play();
|
||||
|
||||
}
|
||||
else
|
||||
{
|
||||
} else {
|
||||
SM.Debug("Cannot play sound playDev NOT init corectly");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void StartSound()
|
||||
{
|
||||
|
||||
soundNeeded = true;
|
||||
|
||||
public void startSound() {
|
||||
setSoundNeeded(true);
|
||||
}
|
||||
|
||||
public void StopSound()
|
||||
{
|
||||
if(playDev.getState() == playDev.STATE_INITIALIZED)
|
||||
{
|
||||
if(playDev.getPlayState() == playDev.PLAYSTATE_PLAYING)
|
||||
|
||||
public void stopSound() {
|
||||
if (playDev != null && playDev.getState() == AudioTrack.STATE_INITIALIZED) {
|
||||
if (playDev.getPlayState() == AudioTrack.PLAYSTATE_PLAYING)
|
||||
playDev.stop();
|
||||
|
||||
}
|
||||
else
|
||||
{
|
||||
} else {
|
||||
SM.Debug("Cannot STOP playDev");
|
||||
}
|
||||
soundNeeded= false;
|
||||
setSoundNeeded(false);
|
||||
}
|
||||
}
|
||||
|
||||
public Boolean getSoundNeeded() {
|
||||
return soundNeeded;
|
||||
}
|
||||
|
||||
public void setSoundNeeded(Boolean soundNeeded) {
|
||||
this.soundNeeded = soundNeeded;
|
||||
}
|
||||
}
|
@ -15,7 +15,7 @@ import com.safemobile.lib.SM;
|
||||
public class UDPclient implements Runnable{
|
||||
|
||||
public String serverHostname = new String ("10.120.1.114");//
|
||||
private int UDP_SERVER_PORT_IN = 50002;
|
||||
private int UDP_SERVER_PORT_IN = 50003;
|
||||
private int UDP_SERVER_PORT_OUT = 50001;
|
||||
private DatagramSocket ds = null;
|
||||
private Thread listenThread;
|
||||
|
Reference in New Issue
Block a user