diff --git a/AndroidManifest.xml b/AndroidManifest.xml
index 7fe6b8c..a169371 100644
--- a/AndroidManifest.xml
+++ b/AndroidManifest.xml
@@ -36,6 +36,7 @@
android:name="protect.babymonitor.DiscoverActivity"
android:label="@string/app_name"
android:configChanges="orientation|screenSize"
+ android:windowSoftInputMode="adjustPan"
android:parentActivityName="protect.babymonitor.StartActivity"
/>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
Port:
Address and port that parent must pair to
Not connected to a Wi-Fi network
+ Enter the IP Address and port of a child and click Connect, or choose a child from the list below
+ Connect
+ 192.168.1.2
+ 10000
+ Either no port was entered or it is invalid
diff --git a/src/protect/babymonitor/DiscoverActivity.java b/src/protect/babymonitor/DiscoverActivity.java
index f75565c..e443823 100644
--- a/src/protect/babymonitor/DiscoverActivity.java
+++ b/src/protect/babymonitor/DiscoverActivity.java
@@ -27,7 +27,10 @@ import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ArrayAdapter;
+import android.widget.Button;
+import android.widget.EditText;
import android.widget.ListView;
+import android.widget.Toast;
public class DiscoverActivity extends Activity
{
@@ -47,6 +50,32 @@ public class DiscoverActivity extends Activity
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_discover);
+ final Button connectButton = (Button) findViewById(R.id.connectViaAddressButton);
+ connectButton.setOnClickListener(new View.OnClickListener()
+ {
+ @Override
+ public void onClick(View v)
+ {
+ Log.i(TAG, "Connecting to child device via address");
+
+ final EditText addressField = (EditText) findViewById(R.id.ipAddressField);
+ final EditText portField = (EditText) findViewById(R.id.portField);
+
+ final String addressString = addressField.getText().toString();
+ final String portString = portField.getText().toString();
+
+ try
+ {
+ final int port = Integer.parseInt(portString);
+ connectToChild(addressString, port, addressString);
+ }
+ catch(NumberFormatException e)
+ {
+ Toast.makeText(DiscoverActivity.this, R.string.invalidPort, Toast.LENGTH_LONG).show();
+ }
+ }
+ });
+
startServiceDiscovery("_babymonitor._tcp.");
}
@@ -83,13 +112,7 @@ public class DiscoverActivity extends Activity
int position, long id)
{
final ServiceInfoWrapper info = (ServiceInfoWrapper) parent.getItemAtPosition(position);
- final Intent i = new Intent(getApplicationContext(), ListenActivity.class);
- final Bundle b = new Bundle();
- b.putString("address", info.getAddress());
- b.putInt("port", info.getPort());
- b.putString("name", info.getName());
- i.putExtras(b);
- startActivity(i);
+ connectToChild(info.getAddress(), info.getPort(), info.getName());
}
});
@@ -181,6 +204,24 @@ public class DiscoverActivity extends Activity
nsdManager.discoverServices(
serviceType, NsdManager.PROTOCOL_DNS_SD, _discoveryListener);
}
+
+ /**
+ * Launch the ListenActivity to connect to the given child device
+ *
+ * @param address
+ * @param port
+ * @param name
+ */
+ private void connectToChild(final String address, final int port, final String name)
+ {
+ final Intent i = new Intent(getApplicationContext(), ListenActivity.class);
+ final Bundle b = new Bundle();
+ b.putString("address", address);
+ b.putInt("port", port);
+ b.putString("name", name);
+ i.putExtras(b);
+ startActivity(i);
+ }
}
class ServiceInfoWrapper