2013-11-05 11:44:26 -04:30
|
|
|
package ve.ucv.ciens.ccg.nxtcam;
|
|
|
|
|
|
|
|
|
|
import ve.ucv.ciens.ccg.nxtcam.camera.CameraPreview;
|
|
|
|
|
import ve.ucv.ciens.ccg.nxtcam.network.ImageTransferThread;
|
2013-11-28 15:48:17 -04:30
|
|
|
import ve.ucv.ciens.ccg.nxtcam.network.LCPThread;
|
2013-11-05 11:44:26 -04:30
|
|
|
import ve.ucv.ciens.ccg.nxtcam.utils.Logger;
|
|
|
|
|
import android.app.Activity;
|
2013-11-05 18:22:25 -04:30
|
|
|
import android.content.Intent;
|
2013-11-05 11:44:26 -04:30
|
|
|
import android.hardware.Camera;
|
|
|
|
|
import android.os.AsyncTask;
|
|
|
|
|
import android.os.Bundle;
|
|
|
|
|
import android.support.v4.app.NavUtils;
|
|
|
|
|
import android.view.Menu;
|
|
|
|
|
import android.view.MenuItem;
|
|
|
|
|
import android.view.WindowManager;
|
2013-12-03 15:31:59 -04:30
|
|
|
import android.widget.FrameLayout;
|
2013-11-05 11:44:26 -04:30
|
|
|
import android.widget.Toast;
|
|
|
|
|
|
|
|
|
|
public class CamActivity extends Activity{
|
|
|
|
|
private final String TAG = "NXTCAM_CAM";
|
2013-11-28 15:48:17 -04:30
|
|
|
private final String CLASS_NAME = CamActivity.class.getSimpleName();
|
|
|
|
|
|
2013-11-05 11:44:26 -04:30
|
|
|
private Camera hwCamera;
|
|
|
|
|
private CameraPreview cPreview;
|
|
|
|
|
private CameraSetupTask camSetupTask;
|
|
|
|
|
private ImageTransferThread imThread;
|
2013-11-28 15:48:17 -04:30
|
|
|
private LCPThread botThread;
|
2013-11-05 18:22:25 -04:30
|
|
|
private String serverIp;
|
2013-11-05 11:44:26 -04:30
|
|
|
|
|
|
|
|
/*******************
|
|
|
|
|
* Android methods *
|
|
|
|
|
*******************/
|
|
|
|
|
@Override
|
|
|
|
|
protected void onCreate(Bundle savedInstanceState) {
|
|
|
|
|
super.onCreate(savedInstanceState);
|
|
|
|
|
getWindow().addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);
|
2013-12-03 15:31:59 -04:30
|
|
|
setContentView(R.layout.activity_cam);
|
2013-11-28 15:48:17 -04:30
|
|
|
|
2013-11-05 18:22:25 -04:30
|
|
|
Intent intent = getIntent();
|
|
|
|
|
serverIp = intent.getStringExtra("address");
|
2013-11-28 15:48:17 -04:30
|
|
|
imThread = new ImageTransferThread(serverIp);
|
2013-11-05 11:44:26 -04:30
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public boolean onCreateOptionsMenu(Menu menu) {
|
|
|
|
|
// Inflate the menu; this adds items to the action bar if it is present.
|
|
|
|
|
getMenuInflater().inflate(R.menu.cam, menu);
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public boolean onOptionsItemSelected(MenuItem item) {
|
|
|
|
|
switch (item.getItemId()) {
|
|
|
|
|
case android.R.id.home:
|
|
|
|
|
// This ID represents the Home or Up button. In the case of this
|
|
|
|
|
// activity, the Up button is shown. Use NavUtils to allow users
|
|
|
|
|
// to navigate up one level in the application structure. For
|
|
|
|
|
// more details, see the Navigation pattern on Android Design:
|
|
|
|
|
//
|
|
|
|
|
// http://developer.android.com/design/patterns/navigation.html#up-vs-back
|
|
|
|
|
//
|
|
|
|
|
NavUtils.navigateUpFromSameTask(this);
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
return super.onOptionsItemSelected(item);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public void onResume(){
|
|
|
|
|
super.onResume();
|
|
|
|
|
|
|
|
|
|
camSetupTask = new CameraSetupTask();
|
|
|
|
|
camSetupTask.execute();
|
2013-11-28 15:48:17 -04:30
|
|
|
|
|
|
|
|
// imThread.start();
|
2013-11-05 11:44:26 -04:30
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public void onPause(){
|
|
|
|
|
super.onPause();
|
|
|
|
|
|
2013-11-28 15:48:17 -04:30
|
|
|
// TODO: pause the imThread and botThread objects.
|
|
|
|
|
|
2013-12-03 15:31:59 -04:30
|
|
|
if(cPreview != null){
|
|
|
|
|
cPreview.removePreviewCallback();
|
|
|
|
|
cPreview.setCamera(null);
|
|
|
|
|
releaseCamera();
|
|
|
|
|
}
|
2013-11-05 11:44:26 -04:30
|
|
|
}
|
2013-11-28 15:48:17 -04:30
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public void onDestroy(){
|
|
|
|
|
super.onDestroy();
|
|
|
|
|
// TODO: Destroy the network threads.
|
|
|
|
|
imThread = null;
|
|
|
|
|
}
|
2013-11-05 11:44:26 -04:30
|
|
|
|
|
|
|
|
/******************
|
|
|
|
|
* My own methods *
|
|
|
|
|
******************/
|
|
|
|
|
public void startCameraPreview(){
|
|
|
|
|
if(hwCamera != null){
|
2013-12-03 15:31:59 -04:30
|
|
|
Logger.log_d(TAG, CLASS_NAME + ".startCameraPreview() :: Setting camera.");
|
|
|
|
|
cPreview = new CameraPreview(this, hwCamera);
|
2013-11-05 11:44:26 -04:30
|
|
|
cPreview.setCamera(hwCamera);
|
2013-12-03 15:31:59 -04:30
|
|
|
((FrameLayout)findViewById(R.id.previewLayout)).addView(cPreview);
|
|
|
|
|
Logger.log_d(TAG, CLASS_NAME + ".startCameraPreview() :: Camera and content view set.");
|
2013-11-05 11:44:26 -04:30
|
|
|
}else{
|
2013-11-21 10:13:38 -04:30
|
|
|
Logger.log_wtf(TAG, CLASS_NAME + ".startCameraPreview() :: CAMERA IS NULL!");
|
2013-11-05 11:44:26 -04:30
|
|
|
System.exit(1);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void releaseCamera(){
|
|
|
|
|
if(hwCamera != null){
|
|
|
|
|
hwCamera.release();
|
|
|
|
|
hwCamera = null;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private class CameraSetupTask extends AsyncTask<Void, Void, Camera>{
|
|
|
|
|
private final String CLASS_NAME = CameraSetupTask.class.getSimpleName();
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
protected Camera doInBackground(Void... params) {
|
|
|
|
|
Camera cam = null;
|
2013-12-03 15:31:59 -04:30
|
|
|
Logger.log_d(TAG, CLASS_NAME + ".doInBackground() :: Opening the camera.");
|
2013-11-05 11:44:26 -04:30
|
|
|
try{
|
|
|
|
|
cam = Camera.open(0);
|
|
|
|
|
}catch(Exception e){
|
2013-11-21 10:13:38 -04:30
|
|
|
Logger.log_e(TAG, CLASS_NAME + ".doInBackground() :: Failed to open the camera.");
|
2013-11-05 11:44:26 -04:30
|
|
|
}
|
|
|
|
|
return cam;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
protected void onPostExecute(Camera result) {
|
2013-11-26 17:59:21 -04:30
|
|
|
super.onPostExecute(result);
|
2013-11-28 15:48:17 -04:30
|
|
|
|
2013-11-05 11:44:26 -04:30
|
|
|
hwCamera = result;
|
|
|
|
|
if(result != null){
|
2013-11-21 10:13:38 -04:30
|
|
|
Logger.log_d(TAG, CLASS_NAME + ".onPostExecute() :: Camera successfully opened");
|
2013-11-05 11:44:26 -04:30
|
|
|
}else{
|
2013-11-21 10:13:38 -04:30
|
|
|
Logger.log_d(TAG, CLASS_NAME + ".onPostExecute() :: Camera open failed on background task.");
|
2013-11-05 11:44:26 -04:30
|
|
|
Toast.makeText(getApplicationContext(), R.string.camera_failure, Toast.LENGTH_LONG).show();
|
|
|
|
|
}
|
|
|
|
|
startCameraPreview();
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
}
|