Getting started with PhoneGap in Eclipse for Android
Eclipse
is an open source integrated development environment (IDE) that
supports many technologies, but this article is focused on its support
of Java, the native language for Android applications. Android is
Google’s open source mobile operating system. Android is the operating
system for many smartphone and tablet devices, including the Samsung
Galaxy line of phones and tablets, the Amazon Kindle Fire tablet, and
the Barnes and Noble Nook tablet, as well as many other devices from
numerous manufacturers. PhoneGap is an open source application platform
that enables you to create natively-installed mobile applications using
HTML and JavaScript.
Setting up Eclipse
The
first step in setting up your development environment for PhoneGap
applications on Android is to download and install the Eclipse IDE.
Android
development with PhoneGap can be done in Windows, OS X, or Linux. There
are many different installation packages for Eclipse. While PhoneGap
may work with other package configurations, the Eclipse Classic package
is recommended and already includes tools that you need to get started
and be productive with PhoneGap application development.
- Visit the Eclipse downloads page to download the Eclipse Classic package for your operating system. The Eclipse download will be an archive containing the development environment.
- Extract the archive to your local hard disk and remember its location.
- Once extracted, you can launch Eclipse by double-clicking the Eclipse application, without any additional setup steps.
Setting up Android Tools
After
you have downloaded and set up Eclipse, you will need to configure your
environment to use Google’s Android development tools. There are two
steps to this process. First, you download and install the Android SDK.
Second, you install the ADT plugin for Eclipse.
Download and configure the Android SDK
The first step in configuring Android tools on your system is to download the Android SDK.
- Visit the Android SDK site to download the appropriate build for your operating system.
- Extract the downloaded archive to your local hard drive and remember its location.
Configure the ADT Plugin for Eclipse
Next,
you need to set up the ADT (Android Development Tools) plugin for
Eclipse. The ADT plugin must be installed through the Eclipse Install
New Software wizard.
- Start Eclipse.
- Follow the download instructions for the ADT plugin, available at the Android developer SDK page for Eclipse. These steps will guide you through the installation of the ADT plugin.
- Restart Eclipse.
Once
you’ve installed the ADT plugin and restarted Eclipse, you need to
configure it to use reference the Android SDK that you have already
downloaded to your local file system.
- Follow the instructions on the Android developer SDK page for configuring Eclipse to set the appropriate Android SDK location in the ADT plugin.
Downloading and installing PhoneGap
The next step is to download and set up PhoneGap.
- Visit the PhoneGap download page and click the orange Download link to begin the download process.
- Extract the archive to your local file system for use later.
You are now ready to create your first PhoneGap project for Android within Eclipse.
Note: The steps that follow are for PhoneGap 1.5, but the process should be applicable or similar for all versions of PhoneGap.
Creating the project in Eclipse
Follow these steps to create a new Android project in Eclipse:
- Choose New > Android Project (see Figure 1).
Figure 1. Creating a new Android project.
After you create a new, standard Android project you will update that project to use PhoneGap.
- In the New Android Project dialog box, type a project name and select Create New Project In Workspace (see Figure 2).
- Click Next.
Figure 2. The New Android Project dialog box.
- Select the Android 2.2 build target, and click Next (see Figure 3).
Note: Choosing
the Android 2.2 build target will configure the compiler to target the
Android 2.2 SDK, and will ensure that your PhoneGap application will
work on devices running Android 2.2 and newer versions of the operating
system.
Figure 3. Selecting a build target
- On the Application Info screen, type a package name for your main Android application (see Figure 4). This should be a namespace that logically represents your package structure; for example, com.yourcompany.yourproject.
- Click Finish.
Figure 4. Specifying a package name.
Configure the project to use PhoneGap
At
this point, Eclipse has created an empty Android project. However, it
has not yet been configured to use PhoneGap. You’ll do that next.
- Create an assets/www directory and a libs directory inside of the new Android project. All of the HTML and JavaScript for your PhoneGap application interface will reside within the assets/wwwfolder (see Figure 5).
Figure 5. New project directories.
- To copy the required files for PhoneGap into the project, first locate the directory where you downloaded PhoneGap, and navigate to the lib/android subdirectory (see Figure 6).
Figure 6. The PhoneGap lib/android directory.
- Copy cordova-1.5.0.js to the assets/www directory within your Android project.
- Copy cordova-1.5.0.jar to the libs directory within your Android project.
- Copy the xml directory into the res directory within your Android project (see Figure 7).
Figure 7. Copied resources.
- Next, create a file named index.html in the assets/www folder. This file will be used as the main entry point for your PhoneGap application’s interface.
- In index.html, add the following HTML code to act as a starting point for your user interface development:
<!DOCTYPE
HTML> <html> <head> <title>PhoneGap</title>
<script type="text/javascript" charset="utf-8"
src="cordova-1.5.0.js"></script> </head> <body>
<h1>Hello PhoneGap</h1> </body> </html>
- You will need to add the cordova-1.5.0.jar library to the build path for the Android project. Right-click cordova-1.5.0.jar and select Build Path > Add To Build Path (see Figure 8).
Figure 8. Adding cordova-1.5.0.jar to the build path.
Update the Activity class
Now you are ready to update the Android project to start using PhoneGap.
- Open your main application Activity file. This file will have the same name as your project, followed by the word “Activity”. It will be located under the src folder in the project package that you specified earlier in this process.
For
my project, which I named HelloGap, the main Android Activity file is
named HelloGapActivity.java, and is located in the package
com.tricedesigns.hello, which I specified in the New Android Project
dialog box.
- In the main Activity class, add an import statement for
org.apache.cordova.DroidGap
:
import org.apache.cordova.DroidGap;
- Change the base class from
Activity
toDroidGap
; this is in the class definition following the wordextends
:
public class HelloGapActivity extends DroidGap {
- Replace the call to
setContentView()
with a reference to load the PhoneGap interface from the local assets/www/index.html file, which you created earlier (see Figure 9).
super.loadUrl("file:///android_asset/www/index.html");
Note: In PhoneGap projects, you can reference files located in the assets directory with a URL reference file:///android_asset, followed by the path name to the file. The file:///android_assetURI maps to the assets directory.
Figure 9. Updates to the main Activity class.
Configure the project metadata
You
have now configured the files within your Android project to use
PhoneGap. The last step is to configure the project metadata to enable
PhoneGap to run.
- Begin by opening the AndroidManifest.xml file in your project root. Use the Eclipse text editor by right-clicking the AndroidManifest.xml file and selecting Open With > Text Editor (see Figure 10).
Figure 10. Opening AndroidManifest.xml.
- In AndroidManifest.xml, add the following
supports-screen
XML node as a child of the rootmanifest
node:
<supports-screens
android:largeScreens="true" android:normalScreens="true"
android:smallScreens="true" android:resizeable="true"
android:anyDensity="true" />
The
supports-screen
XML
node identifies the screen sizes that are supported by your
application. You can change screen and form factor support by altering
the contents of this entry. To read more about<supports-screens>,
visit the Android developer topic on the supports-screen element.
Next, you need to configure permissions for the PhoneGap application.
- Copy the following
<uses-permission>
XML nodes and paste them as children of the root<manifest>
node in the AndroidManifest.xml file:
<uses-permission
android:name="android.permission.CAMERA" /> <uses-permission
android:name="android.permission.VIBRATE" /> <uses-permission
android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission
android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission
android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS" />
<uses-permission android:name="android.permission.READ_PHONE_STATE"
/> <uses-permission android:name="android.permission.INTERNET"
/> <uses-permission android:name="android.permission.RECEIVE_SMS"
/> <uses-permission android:name="android.permission.RECORD_AUDIO"
/> <uses-permission
android:name="android.permission.MODIFY_AUDIO_SETTINGS" />
<uses-permission android:name="android.permission.READ_CONTACTS"
/> <uses-permission
android:name="android.permission.WRITE_CONTACTS" />
<uses-permission
android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission
android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.GET_ACCOUNTS" />
<uses-permission android:name="android.permission.BROADCAST_STICKY"
/>
The
<uses-permission>
XML
values identify the features that you want to be enabled for your
application. The lines above enable all permissions required for all
features of PhoneGap to function. After you have built your application,
you may want to remove any permissions that you are not actually using;
this will remove security warnings during application installation. To
read more about Android permissions and the <uses-permission>
element, visit the Android developer topic on the uses-permission element..
After you have configured application permissions, you need to modify the existing
<activity>
node.- Locate the
<activity>
node, which is a child of the<application>
XML node. Add the following attribute to the<activity>
node:
configChanges="orientation|keyboardHidden"
- Next, you need to create a second
<activity>
node for the com.phonegap.DroidGap class. Add the following<activity>
node as a sibling of the existing<activity>
XML node:
<activity
android:name="com.phonegap.DroidGap" android:label="@string/app_name"
android:configChanges="orientation|keyboardHidden">
<intent-filter></intent-filter> </activity>
At
this point, your project is configured to run as a PhoneGap project for
Android. If you run into any issues, verify your configuration against
the example provided at the PhoneGap getting started site for Android.
Running the application
To
launch your PhoneGap application in the Android emulator, right-click
the project root, and select Run As > Android Application (see Figure
11).
Figure 11. Launching the Android application.
If
you don’t have any Android virtual devices set up, you will be prompted
to configure one. To learn more about configuring Android emulator
virtual devices, visit the Android developer guide for devices.
Eclipse
will automatically start an Android emulator instance (if one is not
already running), deploy your application to the emulator, and launch
the application (see Figure 12).
Figure 12. The application in the Android emulator.
After
you get your application running in the Android emulator, you’ll want
to test it out on a physical device. I strongly recommend that you
always test your applications on a physical device before deploying the
application into production environments. Physical devices always have
different computing abilities and form factors than emulators, and
device testing can uncover issues that may not have been detected in the
emulator environment.
Follow these steps to launch your application on a physical Android device:
- Make sure the device is connected to your computer via USB.
- Choose Run > Run Configurations (see Figure 13).
Figure 13. Updating run configurations.
- Select your application under Android Application on the left side of the Run Configurations dialog box.
- Click the Target tab, and then select Manual as the Deployment Target Selection Mode.
- When you are ready to launch your application, click Run (see Figure 14).
Figure 14. Preparing to run the application on a device.
In
the Android Device Chooser dialog box, you can select either an
emulator or a connected Android device. All connected Android devices
will be displayed in this list.
Figure 15. Choosing an Android device.
- Select the device that you want to use (see Figure 15), and click OK.
Your PhoneGap application will be installed and launched on the device.
No comments:
Post a Comment