From 9911202d5b2a5f07ba2050176f72c3642a34a8c6 Mon Sep 17 00:00:00 2001 From: Joe Bowser Date: Wed, 15 Oct 2008 14:24:39 -0700 Subject: [PATCH] Initial commit of the Android PhoneGap Code --- .classpath | 6 +++ .project | 33 ++++++++++++ AndroidManifest.xml | 15 ++++++ res/drawable/icon.png | Bin 0 -> 3180 bytes res/layout/main.xml | 11 ++++ res/values/strings.xml | 5 ++ src/com/android/droidgap/AccelTuple.java | 7 +++ src/com/android/droidgap/DroidGap.java | 65 +++++++++++++++++++++++ src/com/android/droidgap/GeoTuple.java | 7 +++ src/com/android/droidgap/PhoneGap.java | 52 ++++++++++++++++++ src/com/android/droidgap/R.java | 26 +++++++++ 11 files changed, 227 insertions(+) create mode 100644 .classpath create mode 100644 .project create mode 100644 AndroidManifest.xml create mode 100644 res/drawable/icon.png create mode 100644 res/layout/main.xml create mode 100644 res/values/strings.xml create mode 100644 src/com/android/droidgap/AccelTuple.java create mode 100644 src/com/android/droidgap/DroidGap.java create mode 100644 src/com/android/droidgap/GeoTuple.java create mode 100644 src/com/android/droidgap/PhoneGap.java create mode 100644 src/com/android/droidgap/R.java diff --git a/.classpath b/.classpath new file mode 100644 index 00000000..ef7c361c --- /dev/null +++ b/.classpath @@ -0,0 +1,6 @@ + + + + + + diff --git a/.project b/.project new file mode 100644 index 00000000..37920991 --- /dev/null +++ b/.project @@ -0,0 +1,33 @@ + + + DroidGap + + + + + + com.android.ide.eclipse.adt.ResourceManagerBuilder + + + + + com.android.ide.eclipse.adt.PreCompilerBuilder + + + + + org.eclipse.jdt.core.javabuilder + + + + + com.android.ide.eclipse.adt.ApkBuilder + + + + + + com.android.ide.eclipse.adt.AndroidNature + org.eclipse.jdt.core.javanature + + diff --git a/AndroidManifest.xml b/AndroidManifest.xml new file mode 100644 index 00000000..326dab12 --- /dev/null +++ b/AndroidManifest.xml @@ -0,0 +1,15 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/res/drawable/icon.png b/res/drawable/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..75024841d327c4fbaefef7c8e9c8d0e892895f93 GIT binary patch literal 3180 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 S`hb-H0000 + + + diff --git a/res/values/strings.xml b/res/values/strings.xml new file mode 100644 index 00000000..1c8e1e8f --- /dev/null +++ b/res/values/strings.xml @@ -0,0 +1,5 @@ + + + Hello World, DroidGap + Droid Gap + diff --git a/src/com/android/droidgap/AccelTuple.java b/src/com/android/droidgap/AccelTuple.java new file mode 100644 index 00000000..5073a236 --- /dev/null +++ b/src/com/android/droidgap/AccelTuple.java @@ -0,0 +1,7 @@ +package com.android.droidgap; + +public class AccelTuple { + public long accelX; + public long accelY; + public long accelZ; +} diff --git a/src/com/android/droidgap/DroidGap.java b/src/com/android/droidgap/DroidGap.java new file mode 100644 index 00000000..9ce4d3e9 --- /dev/null +++ b/src/com/android/droidgap/DroidGap.java @@ -0,0 +1,65 @@ +package com.android.droidgap; + +import java.io.IOException; +import java.io.InputStream; + +import android.app.Activity; +import android.os.Bundle; +import android.webkit.WebView; + +public class DroidGap extends Activity { + + private WebView appView; + + /** Called when the activity is first created. */ + @Override + public void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setContentView(R.layout.main); + + appView = (WebView) findViewById(R.id.appView); + appView.getSettings().setJavaScriptEnabled(true); + appView.getSettings().setJavaScriptCanOpenWindowsAutomatically(true); + + /* Bind the appView object to the gap class methods */ + bindBrowser(appView); + + /* + * We need to decide whether this is a local or a remote app. For the sake of clarity + * we can use HTML with both local and remote applications, but it means that we have to open the local file + */ + + appView.loadUrl("http://infil00p.org/gap/"); + + } + + private void loadFile(WebView appView){ + try { + InputStream is = getAssets().open("index.html"); + + int size = is.available(); + + // Read the entire asset into a local byte buffer. + byte[] buffer = new byte[size]; + is.read(buffer); + is.close(); + + // Convert the buffer into a Java string. + String text = new String(buffer); + + // Load the local file into the webview + appView.loadData(text, "text/html", "UTF-8"); + + } catch (IOException e) { + // Should never happen! + throw new RuntimeException(e); + } + } + + private void bindBrowser(WebView appView) + { + PhoneGap gap = new PhoneGap(this); + appView.addJavascriptInterface(gap, "DroidGap"); + } + +} \ No newline at end of file diff --git a/src/com/android/droidgap/GeoTuple.java b/src/com/android/droidgap/GeoTuple.java new file mode 100644 index 00000000..350ea5f6 --- /dev/null +++ b/src/com/android/droidgap/GeoTuple.java @@ -0,0 +1,7 @@ +package com.android.droidgap; + +public class GeoTuple { + public double lat; + public double lng; + public double ele; +} diff --git a/src/com/android/droidgap/PhoneGap.java b/src/com/android/droidgap/PhoneGap.java new file mode 100644 index 00000000..5cca01a0 --- /dev/null +++ b/src/com/android/droidgap/PhoneGap.java @@ -0,0 +1,52 @@ +package com.android.droidgap; + +import android.content.Context; +import android.hardware.SensorManager; +import android.location.Location; +import android.location.LocationManager; +import android.os.Vibrator; + +public class PhoneGap { + + public GeoTuple location; + public AccelTuple accel; + + private Context mCtx; + + public PhoneGap(Context ctx) { + this.mCtx = ctx; + } + + public void updateAccel(AccelTuple accel){ + accel.accelX = SensorManager.DATA_X; + accel.accelY = SensorManager.DATA_Y; + accel.accelZ = SensorManager.DATA_Z; + } + + public void takePhoto(){ + + } + + public void playSound(){ + + } + + public void vibrate(long pattern){ + // Start the vibration + Vibrator vibrator = (Vibrator) mCtx.getSystemService(Context.VIBRATOR_SERVICE); + vibrator.vibrate(pattern); + } + + public void getLocation(String provider){ + LocationManager locMan = (LocationManager) mCtx.getSystemService(Context.LOCATION_SERVICE); + Location myLoc = (Location) locMan.getLastKnownLocation(provider); + location.lat = myLoc.getLatitude(); + location.lng = myLoc.getLongitude(); + location.ele = myLoc.getAltitude(); + } + + public String outputText(){ + String test = "

Test

"; + return test; + } +} diff --git a/src/com/android/droidgap/R.java b/src/com/android/droidgap/R.java new file mode 100644 index 00000000..61d94116 --- /dev/null +++ b/src/com/android/droidgap/R.java @@ -0,0 +1,26 @@ +/* AUTO-GENERATED FILE. DO NOT MODIFY. + * + * This class was automatically generated by the + * aapt tool from the resource data it found. It + * should not be modified by hand. + */ + +package com.android.droidgap; + +public final class R { + public static final class attr { + } + public static final class drawable { + public static final int icon=0x7f020000; + } + public static final class id { + public static final int appView=0x7f050000; + } + public static final class layout { + public static final int main=0x7f030000; + } + public static final class string { + public static final int app_name=0x7f040001; + public static final int hello=0x7f040000; + } +}