CameraImageMonitor now follows the Producer/Consumer model. Other assorted minor changes.
This commit is contained in:
@@ -10,7 +10,7 @@
|
|||||||
<string name="start_button">Comenzar streaming de video</string>
|
<string name="start_button">Comenzar streaming de video</string>
|
||||||
<string name="title_activity_cam">CamActivity</string>
|
<string name="title_activity_cam">CamActivity</string>
|
||||||
<string name="ipAddressLabel">Dirección IP de NxtAR</string>
|
<string name="ipAddressLabel">Dirección IP de NxtAR</string>
|
||||||
<string name="badIpToast">La dirección IP no es válida</string>
|
<string name="badIpToast">No se encontró un servidor válido</string>
|
||||||
<string name="emptyIpToast">Rellene el campo de dirección IP</string>
|
<string name="emptyIpToast">Rellene el campo de dirección IP</string>
|
||||||
<string name="wifi_on_title">Esta app requiere WiFi</string>
|
<string name="wifi_on_title">Esta app requiere WiFi</string>
|
||||||
<string name="wifi_on_msg">¿Encender el WiFi?</string>
|
<string name="wifi_on_msg">¿Encender el WiFi?</string>
|
||||||
@@ -18,7 +18,7 @@
|
|||||||
<string name="wifi_on_button">Encender</string>
|
<string name="wifi_on_button">Encender</string>
|
||||||
<string name="wifi_on_success">El radio del WiFi está encendido</string>
|
<string name="wifi_on_success">El radio del WiFi está encendido</string>
|
||||||
<string name="wifi_on_fail">Esta app no puede funcionar sin wifi, cerrando.</string>
|
<string name="wifi_on_fail">Esta app no puede funcionar sin wifi, cerrando.</string>
|
||||||
<string name= "bt_no_support">Este dispositivo no soporta Bluetooth</string>
|
<string name="bt_no_support">Este dispositivo no soporta Bluetooth</string>
|
||||||
<string name="bt_on_fail">Esta app no puede funcionar sin Bluetooth, cerrando</string>
|
<string name="bt_on_fail">Esta app no puede funcionar sin Bluetooth, cerrando</string>
|
||||||
<string name="lens_icon">Ícono de lente</string>
|
<string name="lens_icon">Ícono de lente</string>
|
||||||
<string name="robot_pair_button">Conectar con el robot</string>
|
<string name="robot_pair_button">Conectar con el robot</string>
|
||||||
|
@@ -10,7 +10,7 @@
|
|||||||
<string name="get_server_button">Connect with NxtAR</string>
|
<string name="get_server_button">Connect with NxtAR</string>
|
||||||
<string name="start_button">Start video streaming</string>
|
<string name="start_button">Start video streaming</string>
|
||||||
<string name="ipAddressLabel">NxtAR IP Address</string>
|
<string name="ipAddressLabel">NxtAR IP Address</string>
|
||||||
<string name="badIpToast">Invalid IP address</string>
|
<string name="badIpToast">No proper server found</string>
|
||||||
<string name="emptyIpToast">Fill out the IP address field</string>
|
<string name="emptyIpToast">Fill out the IP address field</string>
|
||||||
<string name="wifi_on_title">This app requires WiFi</string>
|
<string name="wifi_on_title">This app requires WiFi</string>
|
||||||
<string name="wifi_on_msg">Turn on the WiFi?</string>
|
<string name="wifi_on_msg">Turn on the WiFi?</string>
|
||||||
|
@@ -2,6 +2,7 @@ package ve.ucv.ciens.ccg.nxtcam;
|
|||||||
|
|
||||||
import ve.ucv.ciens.ccg.nxtcam.camera.CameraPreview;
|
import ve.ucv.ciens.ccg.nxtcam.camera.CameraPreview;
|
||||||
import ve.ucv.ciens.ccg.nxtcam.network.ImageTransferThread;
|
import ve.ucv.ciens.ccg.nxtcam.network.ImageTransferThread;
|
||||||
|
import ve.ucv.ciens.ccg.nxtcam.network.LCPThread;
|
||||||
import ve.ucv.ciens.ccg.nxtcam.utils.Logger;
|
import ve.ucv.ciens.ccg.nxtcam.utils.Logger;
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
@@ -16,12 +17,13 @@ import android.widget.Toast;
|
|||||||
|
|
||||||
public class CamActivity extends Activity{
|
public class CamActivity extends Activity{
|
||||||
private final String TAG = "NXTCAM_CAM";
|
private final String TAG = "NXTCAM_CAM";
|
||||||
private final String CLASS_NAME = MainActivity.class.getSimpleName();
|
private final String CLASS_NAME = CamActivity.class.getSimpleName();
|
||||||
|
|
||||||
private Camera hwCamera;
|
private Camera hwCamera;
|
||||||
private CameraPreview cPreview;
|
private CameraPreview cPreview;
|
||||||
private CameraSetupTask camSetupTask;
|
private CameraSetupTask camSetupTask;
|
||||||
private ImageTransferThread imThread;
|
private ImageTransferThread imThread;
|
||||||
|
private LCPThread botThread;
|
||||||
private String serverIp;
|
private String serverIp;
|
||||||
|
|
||||||
/*******************
|
/*******************
|
||||||
@@ -37,6 +39,7 @@ public class CamActivity extends Activity{
|
|||||||
|
|
||||||
Intent intent = getIntent();
|
Intent intent = getIntent();
|
||||||
serverIp = intent.getStringExtra("address");
|
serverIp = intent.getStringExtra("address");
|
||||||
|
imThread = new ImageTransferThread(serverIp);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -70,21 +73,27 @@ public class CamActivity extends Activity{
|
|||||||
camSetupTask = new CameraSetupTask();
|
camSetupTask = new CameraSetupTask();
|
||||||
camSetupTask.execute();
|
camSetupTask.execute();
|
||||||
|
|
||||||
imThread = new ImageTransferThread(serverIp);
|
// imThread.start();
|
||||||
imThread.start();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onPause(){
|
public void onPause(){
|
||||||
super.onPause();
|
super.onPause();
|
||||||
|
|
||||||
// TODO: Disconnect and destroy the imThread object.
|
// TODO: pause the imThread and botThread objects.
|
||||||
|
|
||||||
cPreview.removePreviewCallback();
|
cPreview.removePreviewCallback();
|
||||||
cPreview.setCamera(null);
|
cPreview.setCamera(null);
|
||||||
releaseCamera();
|
releaseCamera();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onDestroy(){
|
||||||
|
super.onDestroy();
|
||||||
|
// TODO: Destroy the network threads.
|
||||||
|
imThread = null;
|
||||||
|
}
|
||||||
|
|
||||||
/******************
|
/******************
|
||||||
* My own methods *
|
* My own methods *
|
||||||
******************/
|
******************/
|
||||||
|
@@ -334,11 +334,6 @@ public class MainActivity extends Activity implements WifiOnDialogListener, Conn
|
|||||||
Logger.log_d(TAG, CLASS_NAME + ".doInBackground() :: Packet payload is\n" + received);
|
Logger.log_d(TAG, CLASS_NAME + ".doInBackground() :: Packet payload is\n" + received);
|
||||||
if(received.compareTo("NxtAR server here!") == 0)
|
if(received.compareTo("NxtAR server here!") == 0)
|
||||||
done = true;
|
done = true;
|
||||||
Socket client1, client2;
|
|
||||||
client1 = new Socket(packet.getAddress(), ProjectConstants.SERVER_TCP_PORT_1);
|
|
||||||
client1.close();
|
|
||||||
client2 = new Socket(packet.getAddress(), ProjectConstants.SERVER_TCP_PORT_2);
|
|
||||||
client2.close();
|
|
||||||
}
|
}
|
||||||
result = true;
|
result = true;
|
||||||
}catch(IOException io){
|
}catch(IOException io){
|
||||||
@@ -367,10 +362,10 @@ public class MainActivity extends Activity implements WifiOnDialogListener, Conn
|
|||||||
|
|
||||||
if(packet != null){
|
if(packet != null){
|
||||||
showToast(R.string.serv_connected, Toast.LENGTH_SHORT);
|
showToast(R.string.serv_connected, Toast.LENGTH_SHORT);
|
||||||
// startCamActivity(result, packet.getAddress().getHostAddress());
|
startCamActivity(result, packet.getAddress().getHostAddress());
|
||||||
}else{
|
}else{
|
||||||
showToast(R.string.serv_fail, Toast.LENGTH_SHORT);
|
showToast(R.string.serv_fail, Toast.LENGTH_SHORT);
|
||||||
// startCamActivity(false, null);
|
startCamActivity(false, null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -7,10 +7,12 @@ public class CameraImageMonitor{
|
|||||||
private final String CLASS_NAME = CameraImageMonitor.class.getSimpleName();
|
private final String CLASS_NAME = CameraImageMonitor.class.getSimpleName();
|
||||||
|
|
||||||
private byte[] image;
|
private byte[] image;
|
||||||
private boolean imgChanged;
|
private boolean imgProduced;
|
||||||
|
private boolean imgConsumed;
|
||||||
|
|
||||||
private CameraImageMonitor(){
|
private CameraImageMonitor(){
|
||||||
imgChanged = false;
|
imgProduced = false;
|
||||||
|
imgConsumed = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class SingletonHolder{
|
private static class SingletonHolder{
|
||||||
@@ -22,33 +24,40 @@ public class CameraImageMonitor{
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void setImageData(byte[] image){
|
public void setImageData(byte[] image){
|
||||||
|
if(imgConsumed){
|
||||||
Logger.log_d(TAG, CLASS_NAME + ".setImageData() :: Copying new image.");
|
Logger.log_d(TAG, CLASS_NAME + ".setImageData() :: Copying new image.");
|
||||||
synchronized(image){
|
synchronized(this.image){
|
||||||
this.image = new byte[image.length];
|
//this.image = new byte[image.length];
|
||||||
System.arraycopy(image, 0, this.image, 0, image.length);
|
//System.arraycopy(image, 0, this.image, 0, image.length);
|
||||||
imgChanged = true;
|
this.image = image;
|
||||||
image.notifyAll();
|
imgProduced = true;
|
||||||
|
imgConsumed = false;
|
||||||
|
this.image.notifyAll();
|
||||||
}
|
}
|
||||||
Logger.log_d(TAG, CLASS_NAME + ".setImageData() :: Data copy finished.");
|
Logger.log_d(TAG, CLASS_NAME + ".setImageData() :: Data copy finished.");
|
||||||
|
}else{
|
||||||
|
Logger.log_d(TAG, CLASS_NAME + ".setImageData() :: Old image still valid, ignoring new image.");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public byte[] getImageData(){
|
public byte[] getImageData(){
|
||||||
byte[] returnImg;
|
byte[] returnImg;
|
||||||
Logger.log_d(TAG, CLASS_NAME + ".getImageData() :: Entry point.");
|
Logger.log_d(TAG, CLASS_NAME + ".getImageData() :: Entry point.");
|
||||||
synchronized(image){
|
synchronized(image){
|
||||||
while(!imgChanged){
|
while(!imgProduced){
|
||||||
Logger.log_d(TAG, CLASS_NAME + ".getImageData() :: Waiting for new data.");
|
Logger.log_d(TAG, CLASS_NAME + ".getImageData() :: Waiting for new image.");
|
||||||
try{ image.wait(); }catch(InterruptedException ie){}
|
try{ image.wait(); }catch(InterruptedException ie){ }
|
||||||
}
|
}
|
||||||
Logger.log_d(TAG, CLASS_NAME + ".getImageData() :: Retrieving new data.");
|
Logger.log_d(TAG, CLASS_NAME + ".getImageData() :: Retrieving new image.");
|
||||||
returnImg = image.clone();
|
returnImg = image;
|
||||||
imgChanged = false;
|
imgProduced = false;
|
||||||
|
imgConsumed = true;
|
||||||
}
|
}
|
||||||
Logger.log_d(TAG, CLASS_NAME + ".getImageData() :: New data retreived.");
|
Logger.log_d(TAG, CLASS_NAME + ".getImageData() :: New image retrieved.");
|
||||||
return returnImg;
|
return returnImg;
|
||||||
}
|
}
|
||||||
|
|
||||||
public synchronized boolean hasChanged(){
|
public synchronized boolean hasChanged(){
|
||||||
return imgChanged;
|
return imgProduced;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user