]> rtime.felk.cvut.cz Git - orte.git/blobdiff - orte/Robot_Demo/src/org/ocera/orte/demo/MainActivity.java
RoboDruid: toggle Hokuyo output and speed control/monitor by touch input
[orte.git] / orte / Robot_Demo / src / org / ocera / orte / demo / MainActivity.java
index 3b51c3673aed34ac044b88468505022badcf6069..512f58d6ee281bad07397a72f7243ee46a71b65b 100644 (file)
 package org.ocera.orte.demo;
 
-import java.io.BufferedInputStream;
-import java.io.BufferedOutputStream;
-import java.io.File;
-import java.io.FileOutputStream;
-import java.io.IOException;
-
 import org.ocera.orte.DomainApp;
-import org.ocera.orte.JOrte;
-import org.ocera.orte.Publication;
-import org.ocera.orte.R;
-import org.ocera.orte.types.DomainProp;
-import org.ocera.orte.types.NtpTime;
-import org.ocera.orte.types.ORTEConstant;
-import org.ocera.orte.types.PublProp;
+import org.ocera.orte.Manager;
 
 import android.app.Activity;
+import android.app.AlertDialog;
 import android.content.Context;
+import android.content.DialogInterface;
+import android.content.DialogInterface.OnDismissListener;
+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.GestureDetector;
+import android.view.LayoutInflater;
+import android.view.Menu;
+import android.view.MenuItem;
+import android.view.MotionEvent;
 import android.view.View;
-import android.widget.Button;
+import android.widget.EditText;
 import android.widget.TextView;
  
 public class MainActivity extends Activity {
-
-       Button start = null;
-       Button stop = null;
-       Button start_pub = null;
-       Button stop_pub = null;
-       TextView textview = null;
-       Process manager = null;
-       Thread publisher = null;
-       boolean tContinue = true;
-       
-    private SensorManager mSensorManager;
-    private PowerManager mPowerManager;
-    private WakeLock mWakeLock;
-    private Sensor mGravity;
-    
-    private AsyncTask<Void, Short, Void> accel;
-    
-    private short mLeft;
-    private short mRight;
-    
-    private Object lock = new Object();
-    
-     static 
-    {
-      System.loadLibrary("jorte");     
-    }
-    
-    private class HandleAccelerometer extends AsyncTask<Void, Short, Void> implements SensorEventListener {
-        
-       public static final int VMAX = 16000;
-       //private int count = 0;
-        
-               @Override
-               protected Void doInBackground(Void... params) {
-                       return null;
-               }
-
-               @Override
-               public void onAccuracyChanged(Sensor sensor, int accuracy) {
-               }
-
+       private AlertDialog voltageDialog = null;
+       private AlertDialog aboutDialog = null;
+       private AlertDialog managersDialog = null;
+       private EditText managersField = null;
+       private TextView ownIP = null;
+       private NetworkInfo wifiInfoTask = 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 onSensorChanged(SensorEvent event) {
-                        if (event.sensor.getType() != Sensor.TYPE_ACCELEROMETER)
-                    return;
-                        
-                        //if (count > 1) {
-                                calculateSpeed(event.values[0],event.values[1]);
-                                //count = 0;
-                        //}
-                        //else
-                                //count++;
-               }
-               
-               private void calculateSpeed(float mAccelX, float mAccelY) {
-               short right = 0;
-               short left = 0;
-               
-                       double r=0.15;
-                       double angle = 0, lenght, v, omega; 
-
-                       v = (double)mAccelY/mGravity.getMaximumRange();
-                       omega = (double)mAccelX/mGravity.getMaximumRange();
-                       lenght = Math.sqrt(Math.pow(v,2) + Math.pow(omega,2));
-                       /* if lenght si more than 1 is used unit circle */
-                       if (lenght >= 1) {
-                               /* computing new speed and omega */
-                               angle = Math.atan2(mAccelY, mAccelX);   
-                               v = Math.sin(angle);
-                               omega = Math.cos(angle);
-                       }
-                       omega *= 2;
-
-                       right = (short)(-((v + r*omega))*VMAX);
-                       left = (short)(-(v - r*omega)*VMAX);
-                       
-                       publishProgress(right, left);
-               }
-               
-               @Override
-               protected void onProgressUpdate(Short... input) {
-                       synchronized(lock) {
-                               mRight = input[0];
-                               mLeft = input[1];
-                               textview.setText("Values: left = " + input[1] + ", right = " + input[0]);
-                       }
-               }
-       }
-       
-       public void copyManager() {
-               BufferedInputStream bis = null;
-               BufferedOutputStream bos = null;
-               
-               String path = getFilesDir().getAbsolutePath() + "/ortemanager";
-               
-               if (!new File(path).exists()) {
-                       try {
-                               bis = new BufferedInputStream(getAssets().open("ortemanager"));
-                               bos = new BufferedOutputStream(new FileOutputStream(path));
-                               
-                               int delka;
-                               byte[] buffer = new byte[4096];
-                               
-                               while((delka = bis.read(buffer, 0, 4096)) > 0) {
-                                       bos.write(buffer, 0, delka);
+               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]));
                                }
-                               
-                               bos.flush();
-                               bos.close();
-                               bis.close();
-                               
-                               Runtime.getRuntime().exec("chmod 744 " + path);
-                       } catch (IOException e) {
-                               e.printStackTrace();
                        }
                }
-       }
+    };
        
-    @Override
-    protected void onResume() {
-        super.onResume();
+       private Manager manager = 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 WakeLock mDimLock = null;
+    private WifiLock mWifiLock = null;
+    private DomainApp appDomain = null;
+    private HokuyoView hokuyo_view = null;
+    private SharedPreferences prefs = null;
+    private GestureDetector gDetector = null;
 
-        accel = new HandleAccelerometer().execute();
-        mSensorManager.registerListener((SensorEventListener)accel, mGravity, SensorManager.SENSOR_DELAY_UI);
-        
-        mWakeLock.acquire();
+    static {
+       System.loadLibrary("jorte");     
     }
 
     @Override
     protected void onPause() {
         super.onPause();
         
-        mSensorManager.unregisterListener((SensorEventListener)accel);
-        accel.cancel(true);
-        accel = null;
+        if (motion_speed_publ != null && !motion_speed_publ.isCancelled()) {
+               motion_speed_publ.cancel();
+            mSensorManager.unregisterListener(accel);
+            this.setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_SENSOR);
+            mDimLock.release();
+            mWifiLock.release();
+        }
         
-        mWakeLock.release();
+        if (motion_speed_subs != null && !motion_speed_subs.isCancelled()) {
+               hokuyo_view.runMotion(false);
+               motion_speed_subs.cancel();
+               hokuyo_view.invalidate();
+            mWakeLock.release();
+            mWifiLock.release();
+        }
+
+        if (hokuyo_scan != null && !hokuyo_scan.isCancelled()) {
+                       hokuyo_view.run(false);
+                       hokuyo_scan.cancel();
+                       hokuyo_view.invalidate();
+               mWakeLock.release();
+               mWifiLock.release();
+        }
     }
-       
+    
     @Override
+    protected void onDestroy() {
+       super.onDestroy();
+
+        if (pwr_voltage != null && !pwr_voltage.isCancelled()) {
+               if (voltageDialog.isShowing())
+                       voltageDialog.dismiss();
+        }
+       
+       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;
+        }
+        
+        if (manager != null) {
+               manager.destroy();
+               manager = null;
+        }
+    }
+       
+       @Override
     public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
-        setContentView(R.layout.activity_main);
+        setContentView(R.layout.hokuyo_view);
         
-               textview = (TextView)findViewById(R.id.textView1);
-               
-               start = (Button)findViewById(R.id.button1);
-               stop = (Button)findViewById(R.id.button2);
-               stop.setEnabled(false);
-               start_pub = (Button)findViewById(R.id.button3);
-               start_pub.setEnabled(false);
-               stop_pub = (Button)findViewById(R.id.button4);
-               stop_pub.setEnabled(false);
-       
-        // Get an instance of the SensorManager
-        mSensorManager = (SensorManager) getSystemService(Context.SENSOR_SERVICE);
-
-        // Get an instance of the PowerManager
         mPowerManager = (PowerManager) getSystemService(Context.POWER_SERVICE);
+        mWakeLock = mPowerManager.newWakeLock(
+                       PowerManager.SCREEN_BRIGHT_WAKE_LOCK,
+                       getClass().getName() + " Bright");
+        mDimLock = mPowerManager.newWakeLock(
+                       PowerManager.SCREEN_DIM_WAKE_LOCK,
+                       getClass().getName() + " Dim");
+
+        mWifiManager = (WifiManager) getSystemService(Context.WIFI_SERVICE);
+        mWifiLock = mWifiManager.createWifiLock(
+                       android.os.Build.VERSION.SDK_INT >= 12
+                       ? WifiManager.WIFI_MODE_FULL_HIGH_PERF
+                       : WifiManager.WIFI_MODE_FULL, getClass().getName());
         
-        // Create a bright wake lock
-        mWakeLock = mPowerManager.newWakeLock(PowerManager.SCREEN_BRIGHT_WAKE_LOCK, getClass().getName());
-       
-        mGravity = mSensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);
+        prefs = getSharedPreferences("prefs", 0);
+        mgrs = prefs.getString("managers", "10.1.1.1");
         
-        copyManager();
-
-               start.setOnClickListener(new View.OnClickListener() {
-                   String[] orte = {getFilesDir().getAbsolutePath() + "/ortemanager","-p 192.168.1.5:192.168.1.8"};
-                       
-                   @Override
-                       public void onClick(View v) {
-                               start.setEnabled(false);
-                               stop.setEnabled(true);
-                               try {
-                                       manager = Runtime.getRuntime().exec(orte);
-                               } catch (IOException e) {
-                                       e.printStackTrace();
-                               }
-                               start_pub.setEnabled(true);
-                       }
-               });
-
-               stop.setOnClickListener(new View.OnClickListener() {
-                       
+               AlertDialog.Builder voltageBuilder = new AlertDialog.Builder(this);
+               LayoutInflater inflater = getLayoutInflater();
+               View voltageView = inflater.inflate(R.layout.status_dialog, null);
+               voltageBuilder.setView(voltageView);
+               voltageBuilder.setPositiveButton("OK",null);
+               voltageBuilder.setTitle("Voltages");
+               voltageDialog = voltageBuilder.create();
+               voltageDialog.setOnDismissListener(new OnDismissListener(){
                        @Override
-                       public void onClick(View v) {
-                               start.setEnabled(true);
-                               stop.setEnabled(false);
-                               start_pub.setEnabled(false);
-                               stop_pub.setEnabled(false);
-                               manager.destroy();
+                       public void onDismiss(DialogInterface arg0) {
+                               voltageDialog.dismiss();
+                               pwr_voltage.cancel();
+                               mDimLock.release();
                        }
                });
+               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);
                
-               start_pub.setOnClickListener(new View.OnClickListener() {
-                       
+               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);
+               
+               managersBuilder.setView(managersView);
+               managersBuilder.setPositiveButton("OK", new DialogInterface.OnClickListener() {
                        @Override
-                       public void onClick(View v) {
-                               start_pub.setEnabled(false);
-                               stop_pub.setEnabled(true);
-                               tContinue = true;
+                       public void onClick(DialogInterface dialog, int which) {
+                               SharedPreferences.Editor editor = prefs.edit();
+                               mgrs = managersField.getText().toString();
+                               editor.putString("managers", mgrs);
+                               editor.commit();
                                
-                               publisher = new Thread(new Runnable() {
-                                       
-                                       @Override
-                                       public void run() {
-                                           NtpTime persistence = new NtpTime(3);
-                                           int strength = 1;
-                                           MyEvents events = new MyEvents();
-                                           
-                                           DomainApp appDomain = new DomainApp(ORTEConstant.ORTE_DEFAULT_DOMAIN,
-                                DomainProp.defaultPropsCreate(),
-                                events,
-                                false);        
-                                           
-                                           HelloMsg hellomsg = new HelloMsg(appDomain,"motion_speed");
-                                           
-                                           PublProp publProp = new PublProp(hellomsg.getTopic(),
-                                        "motion_speed",                                
-                                persistence,
-                                                                strength);
-                                           
-                                           Publication pub = appDomain.createPublication(publProp,
-                                hellomsg);
-                                           
-                                           while(tContinue)
-                                               {
-                                             synchronized(lock) {
-                                                 hellomsg.left = mLeft;
-                                                 hellomsg.right = mRight;
-                                             }
-                                         pub.send(hellomsg); 
-                                         System.out.println("<<  data to send: " + hellomsg);
-                                         JOrte.sleepMs(100);
-                                         System.out.println(" ");
-                                               }
-                                           
-                                           pub = null;
-                                           System.gc();
-                                           appDomain = null;
-                                           System.gc();
-                                       }
-                               });
-                               publisher.start();
+                               if (manager != null)
+                                       manager.destroy();
+                               manager = new Manager(mgrs);
+                               
+                               managersDialog.dismiss();
                        }
                });
-               
-               stop_pub.setOnClickListener(new View.OnClickListener() {
-                       
+               managersBuilder.setNeutralButton("Cancel", null);
+               managersBuilder.setTitle("Set fellow managers");
+               managersDialog = managersBuilder.create();
+               managersDialog.setOnDismissListener(new OnDismissListener() {
                        @Override
-                       public void onClick(View v) {
-                               start_pub.setEnabled(true);
-                               stop_pub.setEnabled(false);
-                               tContinue = false;
+                       public void onDismiss(DialogInterface arg0) {
+                               managersField.setText(mgrs);
+                               wifiInfoTask.cancel(false);
                        }
                });
                
+        mSensorManager = (SensorManager) getSystemService(Context.SENSOR_SERVICE);
+        mGravity = mSensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);
+        
+        hokuyo_view = (HokuyoView) findViewById(R.id.hokuyo_view);
+        gDetector = new GestureDetector(hokuyo_view.getContext(), new HokuyoGestures());
+        hokuyo_view.setOnTouchListener(new View.OnTouchListener() {
+                       @Override
+                       public boolean onTouch(View v, MotionEvent event) {
+                               return gDetector.onTouchEvent(event);
+                       }
+               
+        });
+
+        manager = new Manager(mgrs);
+
+        appDomain = new DomainApp();
+        magnet_cmd = new MagnetCmdPublish(appDomain);
+        magnet_cmd.start();
+        crane_cmd = new CraneCmdPublish(appDomain);
+        crane_cmd.start();
+    }
+    
+       @Override
+       public boolean onCreateOptionsMenu(Menu menu) {
+               getMenuInflater().inflate(R.menu.activity_main, menu);
+
+               return true;
+       }
+       
+       @Override
+       public boolean onOptionsItemSelected (MenuItem item) {
+               if (item.getTitle().equals("Crane: up")) {
+                       crane_cmd.send(0x190);
+                       item.setTitle("Crane: down");
+               }
+               else if (item.getTitle().equals("Crane: down")) {
+                       crane_cmd.send(0x100);
+                       item.setTitle("Crane: up");
+               }
+               else if (item.getTitle().equals("Magnet")) {
+                       if (!item.isChecked()) {
+                               magnet_cmd.send(1);
+                               item.setChecked(true);
+                       }
+                       else {
+                               magnet_cmd.send(0);
+                               item.setChecked(false); 
+                       }
+               }
+               else if (item.getTitle().equals("Voltage monitor")) {
+                       mDimLock.acquire();
+                       if (pwr_voltage == null)
+                               pwr_voltage = new PwrVoltageSubscribe(appDomain, dialogHandler);
+                       pwr_voltage.start();
+                       voltageDialog.show();
+               }
+               else if (item.getTitle().equals("Fellow managers")) {
+                       wifiInfoTask = new NetworkInfo();
+
+                       managersDialog.show();
+                       wifiInfoTask.execute();
+               }
+               else if (item.getTitle().equals("About")) {
+                       aboutDialog.show();
+               }
+               else if (item.getTitle().equals("Exit")) {
+                       finish();
+               }
+               
+               return true;
+       }
+       
+    private class HandleAccelerometer implements SensorEventListener {
+
+       @Override
+       public void onAccuracyChanged(Sensor sensor, int accuracy) {}
+
+       @Override
+       public void onSensorChanged(SensorEvent event) {
+                if (event.sensor.getType() == Sensor.TYPE_ACCELEROMETER) {
+                        if (motion_speed_publ != null)
+                                motion_speed_publ.setSpeed(event.values[0], event.values[1]);
+                }
+       }
+    }
+    
+//    hokuyo_view.setOnTouchListener(new View.OnTouchListener() {
+    private class HokuyoGestures extends GestureDetector.SimpleOnGestureListener {
+
+               @Override
+               public boolean onSingleTapConfirmed(MotionEvent event) {
+                       // urceni orientace HokuyoView a poctu pixelu, ktere zabira hokuyo
+                       double norm = (double)hokuyo_view.getWidth()/(2*HokuyoView.COSINUS);
+                       boolean isVertical = true;
+                       if (norm > hokuyo_view.getHeight()) {
+                               norm = HokuyoView.COSINUS*hokuyo_view.getHeight()*2;
+                               norm = (hokuyo_view.getWidth() - norm)/2;
+                               isVertical = false;
+                       }
+                       else
+                               norm = hokuyo_view.getHeight() - norm;
+                       
+                       // urceni poctu pixelu, ktere zabira ctverec monitoru rychlosti
+                       double normSpeed = ((double)(isVertical ? hokuyo_view.getWidth() : hokuyo_view.getHeight())) * 0.375;
+                       
+                       if (event.getYPrecision()*event.getY() < normSpeed &&
+                                       event.getXPrecision()*event.getX() < normSpeed) {
+                               if(!hokuyo_view.isRunningMotion()) {
+                                       mWakeLock.acquire();
+                                       mWifiLock.acquire();
+                                       if (motion_speed_subs == null)
+                                               motion_speed_subs = new MotionSpeedSubscribe(appDomain, hokuyo_view);
+                                       motion_speed_subs.start();
+                                       hokuyo_view.runMotion(true);
+                                       hokuyo_view.invalidate();
+                               }
+                               else {
+                                       hokuyo_view.runMotion(false);
+                                       motion_speed_subs.cancel();
+                                       hokuyo_view.invalidate();
+                                       mWakeLock.release();
+                                       mWifiLock.release();
+                               }
+                       }
+                       
+                       if ((isVertical && event.getYPrecision()*event.getY() > norm) ||
+                                       (!isVertical && event.getXPrecision()*event.getX() > norm &&
+                                                       event.getXPrecision()*event.getX() < hokuyo_view.getWidth() - norm)) {
+                               if (!hokuyo_view.isRunning()) {
+                                       mWakeLock.acquire();
+                                       mWifiLock.acquire();
+                                       hokuyo_view.setData(new int[681]);
+                                       if (hokuyo_scan == null)
+                                               hokuyo_scan = new HokuyoScanSubscribe(appDomain, hokuyo_view);
+                                       hokuyo_scan.start();
+                                       hokuyo_view.run(true);
+                                       hokuyo_view.invalidate();
+                               }
+                               else {
+                                       hokuyo_view.run(false);
+                                       hokuyo_scan.cancel();
+                                       hokuyo_view.invalidate();
+                                       mWakeLock.release();
+                                       mWifiLock.release();
+                               }
+                       }
+                       return true;
+               }
+
+               @Override
+               public boolean onDown(MotionEvent e) {
+                       return true;
+               }
+
+               @Override
+               public void onLongPress(MotionEvent event) {
+                       // urceni poctu pixelu, ktere zabira ctverec monitoru rychlosti
+                       double normSpeed = ((double)(hokuyo_view.getHeight() < hokuyo_view.getWidth() ? hokuyo_view.getHeight() : hokuyo_view.getWidth())) * 0.375;
+                       
+                       if (event.getYPrecision()*event.getY() < normSpeed &&
+                                       event.getXPrecision()*event.getX() < normSpeed) {
+                               if (motion_speed_publ == null || motion_speed_publ.isCancelled()) {
+                                       mDimLock.acquire();
+                                       mWifiLock.acquire();
+                                       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();
+                                       setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
+                               }
+                               else {
+                                       mSensorManager.unregisterListener(accel);
+                                       motion_speed_publ.cancel();
+                                       setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_SENSOR);
+                                       mDimLock.release();
+                                       mWifiLock.release();
+                               }
+                       }
+               }
+    }
+    
+    private class NetworkInfo extends AsyncTask<Void, String, Void> {
+       @Override
+       protected Void doInBackground(Void... arg0) {
+               while (!isCancelled()) {
+                       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]);
+       }
     }
-}
\ No newline at end of file
+}