]> rtime.felk.cvut.cz Git - orte.git/blobdiff - orte/Robot_Demo/src/org/ocera/orte/demo/MainActivity.java
ROBOT_DEMO: add check boxes to menu items and make the managers dialog alive
[orte.git] / orte / Robot_Demo / src / org / ocera / orte / demo / MainActivity.java
index f4d299ad60d018fa388df8830e285555d37e362a..1bc400a80f44df1493229eb73c356f8837456840 100644 (file)
@@ -4,32 +4,84 @@ import org.ocera.orte.DomainApp;
 import org.ocera.orte.Manager;
 
 import android.app.Activity;
+import android.app.AlertDialog;
 import android.content.Context;
+import android.content.DialogInterface;
+import android.content.SharedPreferences;
+import android.content.pm.ActivityInfo;
 import android.hardware.Sensor;
 import android.hardware.SensorEvent;
 import android.hardware.SensorEventListener;
 import android.hardware.SensorManager;
+import android.net.wifi.WifiInfo;
+import android.net.wifi.WifiManager;
+import android.net.wifi.WifiManager.WifiLock;
+import android.os.AsyncTask;
 import android.os.Bundle;
+import android.os.Handler;
+import android.os.Message;
 import android.os.PowerManager;
 import android.os.PowerManager.WakeLock;
+import android.text.format.Formatter;
+import android.view.LayoutInflater;
 import android.view.Menu;
 import android.view.MenuItem;
+import android.view.View;
+import android.widget.EditText;
+import android.widget.TextView;
  
 public class MainActivity extends Activity {
+       private AlertDialog voltageDialog = null;
+       private AlertDialog aboutDialog = null;
+       private AlertDialog managersDialog = null;
+       private EditText managersField = null;
+       private TextView ownIP = null;
+       static EditText voltage33 = null;
+       static EditText voltage50 = null;
+       static EditText voltage80 = null;
+       static EditText voltageBAT = null;
+       static Handler dialogHandler = new Handler() {
+               @Override
+               public void handleMessage(Message msg) {
+                       double[] values = msg.getData().getDoubleArray("voltages");
+                       if (values != null) {
+                               if (voltage33 != null) {
+                                       voltage33.setText(Double.toString(values[0]));
+                               }
+                               if (voltage50 != null) {
+                                       voltage50.setText(Double.toString(values[1]));
+                               }
+                               if (voltage80 != null) {
+                                       voltage80.setText(Double.toString(values[2]));
+                               }
+                               if (voltageBAT != null) {
+                                       voltageBAT.setText(Double.toString(values[3]));
+                               }
+                       }
+               }
+    };
        
        private Manager manager = null;
-    private String[] mgrs = {"192.168.1.5","192.168.1.8"};
-       private MotionSpeedPublish motion_speed = null;
+    private String mgrs = null;
+       private MotionSpeedPublish motion_speed_publ = null;
+       private MotionSpeedSubscribe motion_speed_subs = null;
        private HokuyoScanSubscribe hokuyo_scan = null;
+       private PwrVoltageSubscribe pwr_voltage = null;
+       private MagnetCmdPublish magnet_cmd = null;
+       private CraneCmdPublish crane_cmd = null;
     private SensorManager mSensorManager = null;
     private Sensor mGravity = null;
     private SensorEventListener accel = null;
     private PowerManager mPowerManager = null;
+    private WifiManager mWifiManager = null;
     private WakeLock mWakeLock = null;
+    private WifiLock mWifiLock = null;
     private DomainApp appDomain = null;
     private HokuyoView hokuyo_view = null;
-    private MenuItem speed_item = null;
+    private MenuItem speed_publ_item = null;
+    private MenuItem speed_subs_item = null;
     private MenuItem hokuyo_item = null;
+    private SharedPreferences prefs = null;
 
     static {
        System.loadLibrary("jorte");     
@@ -40,31 +92,56 @@ public class MainActivity extends Activity {
         super.onResume();
 
         mWakeLock.acquire();
+        mWifiLock.acquire();
     }
 
     @Override
     protected void onPause() {
         super.onPause();
         
-        if (motion_speed != null && !motion_speed.isCancelled()) {
-               motion_speed.cancel();
+        if (motion_speed_publ != null && !motion_speed_publ.isCancelled()) {
+               motion_speed_publ.cancel();
             mSensorManager.unregisterListener(accel);
-               speed_item.setTitle("Start speed");
+            this.setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_SENSOR);
+               speed_publ_item.setChecked(false);
+        }
+        
+        if (motion_speed_subs != null && !motion_speed_subs.isCancelled()) {
+               hokuyo_view.runMotion(false);
+               motion_speed_subs.cancel();
+               hokuyo_view.invalidate();
+               speed_subs_item.setChecked(false);
         }
 
         if (hokuyo_scan != null && !hokuyo_scan.isCancelled()) {
                        hokuyo_view.run(false);
                        hokuyo_scan.cancel();
-                       hokuyo_item.setTitle("Start hokuyo");
+                       hokuyo_view.invalidate();
+                       hokuyo_item.setChecked(false);
+        }
+
+        if (pwr_voltage != null && !pwr_voltage.isCancelled()) {
+               if (voltageDialog.isShowing())
+                       voltageDialog.dismiss();
+                       pwr_voltage.cancel();
         }
         
         mWakeLock.release();
+        mWifiLock.release();
     }
     
     @Override
     protected void onDestroy() {
        super.onDestroy();
        
+       if (crane_cmd != null && !crane_cmd.isCancelled()) {
+               crane_cmd.cancel();
+       }
+       
+       if (magnet_cmd != null && !crane_cmd.isCancelled()) {
+               magnet_cmd.cancel();
+       }
+       
         if (appDomain != null) {
                appDomain.destroy();
                appDomain = null;
@@ -76,22 +153,88 @@ public class MainActivity extends Activity {
         }
     }
        
-    @Override
+       @SuppressWarnings("deprecation")
+       @Override
     public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
         setContentView(R.layout.hokuyo_view);
         
+        mPowerManager = (PowerManager) getSystemService(Context.POWER_SERVICE);
+        mWakeLock = mPowerManager.newWakeLock(
+                       PowerManager.SCREEN_BRIGHT_WAKE_LOCK
+                       | PowerManager.ACQUIRE_CAUSES_WAKEUP
+                       | PowerManager.ON_AFTER_RELEASE,
+                       getClass().getName());
+
+        mWifiManager = (WifiManager) getSystemService(Context.WIFI_SERVICE);
+        mWifiLock = mWifiManager.createWifiLock(WifiManager.WIFI_MODE_FULL_HIGH_PERF, getClass().getName());
+        
+        prefs = getSharedPreferences("prefs", 0);
+        mgrs = prefs.getString("managers", "10.1.1.1");
+        
+               AlertDialog.Builder voltageBuilder = new AlertDialog.Builder(this);
+               LayoutInflater inflater = getLayoutInflater();
+               View voltageView = inflater.inflate(R.layout.status_dialog, null);
+               voltageBuilder.setCancelable(false);
+               voltageBuilder.setView(voltageView);
+               voltageBuilder.setPositiveButton("OK", new DialogInterface.OnClickListener() {
+                       @Override
+                       public void onClick(DialogInterface dialog, int which) {
+                               voltageDialog.dismiss();
+                               pwr_voltage.cancel();
+                       }
+               });
+               voltageBuilder.setTitle("Voltages");
+               voltageDialog = voltageBuilder.create();
+               voltage33 = (EditText)voltageView.findViewById(R.id.editText1);
+               voltage50 = (EditText)voltageView.findViewById(R.id.editText2);
+               voltage80 = (EditText)voltageView.findViewById(R.id.editText3);
+               voltageBAT = (EditText)voltageView.findViewById(R.id.editText4);
+               
+               AlertDialog.Builder builder = new AlertDialog.Builder(this);
+               View aboutView = inflater.inflate(R.layout.about_dialog, null);
+               builder.setView(aboutView);
+               builder.setPositiveButton("OK", null);
+               aboutDialog = builder.create();
+               
+               AlertDialog.Builder managersBuilder = new AlertDialog.Builder(this);
+               View managersView = inflater.inflate(R.layout.managers_view, null);
+               ownIP = (TextView)managersView.findViewById(R.id.ownIP);
+               managersField = (EditText)managersView.findViewById(R.id.managers);
+               managersField.setText(mgrs);
+               
+               NetworkInfo wifiInfoTask = new NetworkInfo();
+               managersBuilder.setCancelable(false);
+               managersBuilder.setView(managersView);
+               managersBuilder.setPositiveButton("OK", new DialogInterface.OnClickListener() {
+                       @Override
+                       public void onClick(DialogInterface dialog, int which) {
+                               SharedPreferences.Editor editor = prefs.edit();
+                               mgrs = managersField.getText().toString();
+                               System.out.println(mgrs);
+                               editor.putString("managers", mgrs);
+                               editor.commit();
+                               
+                       manager = new Manager(mgrs);
+
+                       appDomain = new DomainApp();
+                       magnet_cmd = new MagnetCmdPublish(appDomain);
+                       magnet_cmd.start();
+                       crane_cmd = new CraneCmdPublish(appDomain);
+                       crane_cmd.start();
+                               managersDialog.dismiss();
+                       }
+               });
+               managersBuilder.setTitle("Set fellow managers");
+               managersDialog = managersBuilder.create();
+               
         mSensorManager = (SensorManager) getSystemService(Context.SENSOR_SERVICE);
         mGravity = mSensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);
         
-        mPowerManager = (PowerManager) getSystemService(Context.POWER_SERVICE);
-        mWakeLock = mPowerManager.newWakeLock(PowerManager.SCREEN_BRIGHT_WAKE_LOCK, getClass().getName());
-        
         hokuyo_view = (HokuyoView) findViewById(R.id.hokuyo_view);
         
-        manager = new Manager(mgrs);
-
-        appDomain = new DomainApp();
+        managersDialog.show();
+               wifiInfoTask.execute();
     }
     
        @Override
@@ -103,46 +246,82 @@ public class MainActivity extends Activity {
        
        @Override
        public boolean onOptionsItemSelected (MenuItem item) {
-               System.out.println(item.getTitle());
-               
-               if(item.getTitle().equals("Start speed")) {
-                       accel = new HandleAccelerometer();
-                       mSensorManager.registerListener(accel, mGravity, SensorManager.SENSOR_DELAY_UI);
-                       if (motion_speed == null)
-                               motion_speed = new MotionSpeedPublish(mGravity.getMaximumRange(),appDomain);
-                       motion_speed.start();
-                       speed_item = item;
-                       item.setTitle("Stop speed");
+               if(item.getTitle().equals("Motion control")) {
+                       if (!item.isChecked()) {
+                               accel = new HandleAccelerometer();
+                               mSensorManager.registerListener(accel, mGravity, SensorManager.SENSOR_DELAY_GAME);
+                               if (motion_speed_publ == null)
+                                       motion_speed_publ = new MotionSpeedPublish(appDomain);
+                               motion_speed_publ.start();
+                               speed_publ_item = item;
+                               this.setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
+                               item.setChecked(true);
+                       }
+                       else {
+                               mSensorManager.unregisterListener(accel);
+                               motion_speed_publ.cancel();
+                               this.setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_SENSOR);
+                               item.setChecked(false);
+                       }
                }
-               else if (item.getTitle().equals("Stop speed")) {
-                       mSensorManager.unregisterListener(accel);
-                       motion_speed.cancel();
-                       item.setTitle("Start speed");
+               else if (item.getTitle().equals("Speed monitor")) {
+                       if(!item.isChecked()) {
+                               if (motion_speed_subs == null)
+                                       motion_speed_subs = new MotionSpeedSubscribe(appDomain, hokuyo_view);
+                               motion_speed_subs.start();
+                               hokuyo_view.runMotion(true);
+                               hokuyo_view.invalidate();
+                               speed_subs_item = item;
+                               item.setChecked(true);
+                       }
+                       else {
+                               hokuyo_view.runMotion(false);
+                               motion_speed_subs.cancel();
+                               hokuyo_view.invalidate();
+                               item.setChecked(false);                         
+                       }
                }
-               else if (item.getTitle().equals("Start hokuyo")) {
-                       if (hokuyo_scan == null)
-                               hokuyo_scan = new HokuyoScanSubscribe(appDomain, hokuyo_view);
-                       hokuyo_scan.start();
-                       hokuyo_view.run(true);
-                       hokuyo_item = item;
-                       item.setTitle("Stop hokuyo");
+               else if (item.getTitle().equals("Hokuyo")) {
+                       if (!item.isChecked()) {
+                               if (hokuyo_scan == null)
+                                       hokuyo_scan = new HokuyoScanSubscribe(appDomain, hokuyo_view);
+                               hokuyo_scan.start();
+                               hokuyo_view.run(true);
+                               hokuyo_view.invalidate();
+                               hokuyo_item = item;
+                               item.setChecked(true);
+                       }
+                       else {
+                               hokuyo_view.run(false);
+                               hokuyo_scan.cancel();
+                               hokuyo_view.invalidate();
+                               item.setChecked(false);
+                       }
                }
-               else if (item.getTitle().equals("Stop hokuyo")) {
-                       hokuyo_view.run(false);
-                       hokuyo_scan.cancel();
-                       item.setTitle("Start hokuyo");
+               else if (item.getTitle().equals("Crane up")) {
+                       crane_cmd.send(0x100);
+                       item.setTitle("Crane down");
                }
-               else if (item.getTitle().equals("Lift up")) {
-                       
-               }
-               else if (item.getTitle().equals("Lift down")) {
-                       
+               else if (item.getTitle().equals("Crane down")) {
+                       crane_cmd.send(0x190);
+                       item.setTitle("Crane up");
                }
                else if (item.getTitle().equals("Magnet on")) {
-                       
+                       magnet_cmd.send(1);
+                       item.setTitle("Magnet off");                    
                }
                else if (item.getTitle().equals("Magnet off")) {
-                       
+                       magnet_cmd.send(0);
+                       item.setTitle("Magnet on");                     
+               }
+               else if (item.getTitle().equals("Voltage monitor")) {
+                       if (pwr_voltage == null)
+                               pwr_voltage = new PwrVoltageSubscribe(appDomain, dialogHandler);
+                       pwr_voltage.start();
+                       voltageDialog.show();
+               }
+               else if (item.getTitle().equals("About")) {
+                       aboutDialog.show();
                }
                else if (item.getTitle().equals("Exit")) {
                        finish();
@@ -159,9 +338,38 @@ public class MainActivity extends Activity {
        @Override
        public void onSensorChanged(SensorEvent event) {
                 if (event.sensor.getType() == Sensor.TYPE_ACCELEROMETER) {
-                        if (motion_speed != null)
-                                motion_speed.setSpeed(event.values[0], event.values[1]);
+                        if (motion_speed_publ != null)
+                                motion_speed_publ.setSpeed(event.values[0], event.values[1]);
                 }
        }
     }
-}
\ No newline at end of file
+    
+    private class NetworkInfo extends AsyncTask<Void, String, Void> {
+       @Override
+       protected Void doInBackground(Void... arg0) {
+               while (managersDialog.isShowing()) {
+                       WifiInfo wifiInfo = mWifiManager.getConnectionInfo();
+                       int ip = wifiInfo.getIpAddress();
+                       String ipAddress = Formatter.formatIpAddress(ip);
+                       String ssid = wifiInfo.getSSID();
+       
+                       publishProgress("\nOwn IP Address: " + ipAddress + "\nNetwork SSID: " + ssid);
+                       
+                       try {
+                                       Thread.sleep(1000);
+                               } catch (InterruptedException e) {
+                                       e.printStackTrace();
+                               }
+               }
+               
+               return null;
+       }
+
+       @Override
+       protected void onProgressUpdate(String... values) {
+               super.onProgressUpdate(values);
+               
+               ownIP.setText(values[0]);
+       }
+    }
+}