| page.title=Developing In Eclipse, with ADT |
| @jd:body |
| |
| <div id="qv-wrapper"> |
| <div id="qv"> |
| <h2>In this document</h2> |
| <ol> |
| <li><a href="#CreatingAProject">Creating an Android Project</a></li> |
| <li><a href="#Running">Running Your Application</a> |
| <ol> |
| <li><a href="#CreatingAnAvd">Creating an AVD</a></li> |
| <li><a href="#RunningAnApplication">Running an application</a></li> |
| </ol> |
| </li> |
| <li><a href="#RunConfig">Creating a Custom Run Configuration</a></li> |
| <li><a href="#Signing">Setting Up Application Signing</a></li> |
| <li><a href="#Tips">Eclipse Tips</a></li> |
| </div> |
| </div> |
| |
| |
| <p>The Android Development Tools (ADT) plugin for Eclipse adds powerful extensions to the Eclipse |
| integrated development environment. It allows you to create and debug Android applications easier |
| and faster. If you use Eclipse, the ADT plugin gives you an incredible boost in developing Android |
| applications:</p> |
| |
| <ul> |
| <li>It gives you access to other Android development tools from inside the Eclipse IDE. For |
| example, ADT lets you access the many capabilities of the DDMS tool: take screenshots, manage |
| port-forwarding, set breakpoints, and view thread and process information directly from Eclipse.</li> |
| <li>It provides a New Project Wizard, which helps you quickly create and set up all of the |
| basic files you'll need for a new Android application.</li> |
| <li>It automates and simplifies the process of building your Android application.</li> |
| <li>It provides an Android code editor that helps you write valid XML for your Android |
| manifest and resource files.</li> |
| <li>It will even export your project into a signed APK, which can be distributed to users.</li> |
| </ul> |
| |
| <p>To begin developing Android applications in the Eclipse IDE with ADT, you first need to |
| download the Eclipse IDE and then download and install the ADT plugin. To do so, follow the |
| steps given in <a href="{@docRoot}sdk/eclipse-adt.html#installing">Installing |
| the ADT Plugin</a>.</p> |
| |
| <p>If you are already developing applications using a version of ADT earlier than 0.9, make |
| sure to upgrade to the latest version before continuing. See the guide to |
| <a href="{@docRoot}sdk/eclipse-adt.html#updating">Updating Your ADT Plugin</a>.</p> |
| |
| <p class="note"><strong>Note:</strong> This guide assumes you are using the latest version of |
| the ADT plugin. While most of the information covered also applies to previous |
| versions, if you are using an older version, you may want to consult this document from |
| the set of documentation included in your SDK package (instead of the online version).</p> |
| |
| |
| <h2 id="CreatingAProject">Creating an Android Project</h2> |
| |
| <p>The ADT plugin provides a New Project Wizard that you can use to quickly create a new |
| Android project (or a project from existing code). To create a new project:</p> |
| |
| <ol> |
| <li>Select <strong>File</strong> > <strong>New</strong> > <strong>Project</strong>.</li> |
| <li>Select <strong>Android</strong> > <strong>Android Project</strong>, and click |
| <strong>Next</strong>.</li> |
| <li>Select the contents for the project: |
| <ul> |
| <li>Enter a <em>Project Name</em>. This will be the name of the folder where your |
| project is created.</li> |
| <li>Under Contents, select <strong>Create new project in workspace</strong>. |
| Select your project workspace location.</li> |
| <li>Under Target, select an Android target to be used as the project's Build Target. |
| The Build Target |
| specifies which Android platform you'd like your application built against. |
| <p>Unless you know that you'll be using new APIs introduced in the latest SDK, you should |
| select a target with the lowest platform version possible, such as Android 1.1.</p> |
| <p class="note"><strong>Note:</strong> You can change your the Build Target for your |
| project at any time: Right-click the project in the Package Explorer, select |
| <strong>Properties</strong>, select <strong>Android</strong> and then check |
| the desired Project Target.</p> |
| </li> |
| <li>Under Properties, fill in all necessary fields. |
| <ul> |
| <li>Enter an <em>Application name</em>. This is the human-readable title for your |
| application — the name that will appear on the Android device.</li> |
| <li>Enter a <em>Package name</em>. This is the package namespace (following the same rules |
| as for packages in the Java programming language) where all your source code |
| will reside.</li> |
| <li>Select <em>Create Activity</em> (optional, of course, but common) and enter a name |
| for your main Activity class.</li> |
| <li>Enter a <em>Min SDK Version</em>. This is an integer that indicates |
| the minimum API Level required to properly run your application. |
| Entering this here automatically sets the <code>minSdkVersion</code> attribute in the |
| <a href="{@docRoot}guide/topics/manifest/uses-sdk-element.html"><uses-sdk></a> |
| of your Android Manifest file. If you're unsure of the appropriate API Level to use, |
| copy the API Level listed for the Build Target you selected in the Target tab.</li> |
| </ul> |
| </li> |
| </ul> |
| </li> |
| <li>Click <strong>Finish</strong>.</li> |
| </ol> |
| |
| <p class="note"><strong>Tip:</strong> |
| You can also start the New Project Wizard from the <em>New</em> icon in the toolbar.</p> |
| |
| <p>Once you complete the New Project Wizard, ADT creates the following |
| folders and files in your new project:</p> |
| <dl> |
| <dt><code>src/</code></dt> |
| <dd>Includes your stub Activity Java file. All other Java files for your application |
| go here.</dd> |
| <dt><code><em><Android Version></em>/</code> (e.g., <code>Android 1.1/</code>)</dt> |
| <dd>Includes the <code>android.jar</code> file that your application will build against. |
| This is determined by the build target that you have chosen in the <em>New Project |
| Wizard</em>.</dd> |
| <dt><code>gen/</code></dt> |
| <dd>This contains the Java files generated by ADT, such as your <code>R.java</code> file |
| and interfaces created from AIDL files.</dd> |
| <dt><code>assets/</code></dt> |
| <dd>This is empty. You can use it to store raw asset files. See |
| <a href="{@docRoot}guide/topics/resources/index.html">Resources and Assets</a>.</dd> |
| <dt><code>res/</code></dt> |
| <dd>A folder for your application resources, such as drawable files, layout files, string |
| values, etc. See |
| <a href="{@docRoot}guide/topics/resources/index.html">Resources and Assets</a>.</dd> |
| <dt><code>AndroidManifest.xml</code></dt> |
| <dd>The Android Manifest for your project. See |
| <a href="{@docRoot}guide/topics/manifest/manifest-intro.html">The AndroidManifest.xml |
| File</a>.</dd> |
| <dt><code>default.properties</code></dt> |
| <dd>This file contains project settings, such as the build target. This files is integral |
| to the project, as such, it should be maintained in a Source Revision Control system. |
| It should never be edited manually — to edit project properties, |
| right-click the project folder and select "Properties".</dd> |
| </dl> |
| |
| |
| <h2 id="Running">Running Your Application</h2> |
| |
| <p>Before you can run your application on the Android Emulator, |
| you <strong>must</strong> create an Android Virtual Device (AVD). |
| An AVD is a configuration that specifies the Android platform to be used on the emulator. |
| You can read more in the <a href="{@docRoot}guide/developing/tools/avd.html">Android Virtual |
| Devices</a> document, but if you just want to get started, follow the simple guide below to |
| create an AVD.</p> |
| |
| <p>If you will be running your applications only on actual device hardware, you do not |
| need an AVD — see |
| <a href="{@docRoot}guide/developing/device.html">Developing On a Device</a> for information |
| on running your application.</p> |
| |
| <h3 id="CreatingAnAvd">Creating an AVD</h3> |
| |
| <p>With ADT 0.9.3 and above, the Android SDK and AVD Manager provides a simple graphical interface |
| for creating and managing AVDs. (If you're using ADT version 0.9.1 or older, you must |
| use the <code>android</code> tool to create your AVDs—read the AVD guide to |
| <a href="{@docRoot}guide/developing/tools/avd.html#creating">Creating an AVD</a>.) |
| |
| <p>To create an AVD with the AVD Manager:</p> |
| |
| <ol> |
| <li>Select <strong>Window > Android SDK and AVD Manager</strong>, or click the Android SDK and AVD Manager icon (a black device) |
| in the Eclipse toolbar.</p> |
| </li> |
| <li>In the Virtual Devices panel, you'll see a list of existing AVDs. Click <strong>New</strong> |
| to create a new AVD.</li> |
| <li>Fill in the details for the AVD. |
| <p>Give it a name, a platform target, an SD card image (optional), and |
| a skin (HVGA is default).</p> |
| </li> |
| <li>Click <strong>Create AVD</strong>.</li> |
| </ol> |
| |
| <p>Your AVD is now ready and you can close the AVD Manager. |
| In the next section, you'll see how the AVD is used |
| when launching your application on an emulator.</p> |
| |
| <p>For more information about AVDs, read the |
| <a href="{@docRoot}guide/developing/tools/avd.html">Android Virtual Devices</a> |
| documentation.</p> |
| |
| |
| <h3 id="RunningYourApplication">Running your application</h3> |
| |
| <p class="note"><strong>Note:</strong> Before you can run your application, be sure that |
| you have created an AVD with a target that satisfies your application's Build Target. |
| If an AVD cannot be found that meets the requirements of your Build Target, you will see |
| a console error telling you so and the launch will be aborted.</p> |
| |
| <p>To run (or debug) your application, select <strong>Run</strong> > <strong>Run</strong> (or |
| <strong>Run</strong> > <strong>Debug</strong>) from the Eclipse main menu. The ADT plugin |
| will automatically create a default launch configuration for the project.</p> |
| |
| <p>When you choose to run or debug your application, Eclipse will perform the following:</p> |
| |
| <ol> |
| <li>Compile the project (if there have been changes since the last build).</li> |
| <li>Create a default launch configuration (if one does not already exist for the project).</li> |
| <li>Install and start the application on an emulator or device (based on the Deployment Target |
| defined by the run configuration). |
| <p>By default, Android application run configurations use an "automatic target" mode for |
| selecting a device target. For information on how automatic target mode selects a |
| deployment target, see <a href="#AutoAndManualTargetModes">Automatic and manual |
| target modes</a> below.</p> |
| </li> |
| </ol> |
| |
| <p>If debugging, the application will start in the "Waiting For Debugger" mode. Once the |
| debugger is attached, Eclipse will open the Debug perspective.</p> |
| |
| <p>To set or change the launch configuration used for your project, use the launch configuration manager. |
| See <a href="#launchconfig">Creating a Launch Configuration</a> for information.</p> |
| |
| |
| <h2 id="RunConfig">Creating a Run Configuration</h2> |
| |
| <p>The run configuration specifies the project to run, the Activity |
| to start, the emulator options to use, and so on. When you first run a project |
| as an <em>Android Application</em>, ADT will automatically create a run configuration. |
| The default run configuration will |
| launch the default project Activity and use automatic target mode for device selection |
| (with no preferred AVD). If the default settings don't suit your project, you can |
| customize the launch configuration or even create a new.</p> |
| |
| <p>To create or modify a launch configuration, follow these steps as appropriate |
| for your Eclipse version:</p> |
| |
| <ol> |
| <li>Open the run configuration manager. |
| <ul> |
| <li>In Eclipse 3.3 (Europa), select <strong>Run</strong> > |
| <strong>Open Run Dialog</strong> (or <strong>Open Debug Dialog</strong>) |
| </li> |
| <li>In Eclipse 3.4 (Ganymede), select <strong>Run </strong>> |
| <strong>Run Configurations</strong> (or |
| <strong>Debug Configurations</strong>) |
| </li> |
| </ul> |
| </li> |
| <li>Expand the <strong>Android Application</strong> item and create a new |
| configuration or open an existing one. |
| <ul> |
| <li>To create a new configuration: |
| <ol> |
| <li>Select <strong>Android Application</strong> and click the <em>New launch configuration</em> |
| icon above the list (or, right-click <strong>Android Application</strong> and click |
| <strong>New</strong>).</li> |
| <li>Enter a Name for your configuration.</li> |
| <li>In the Android tab, browse and select the project you'd like to run with the |
| configuration.</li> |
| </ol> |
| <li>To open an existing configuration, select the configuration name from the list |
| nested below <strong>Android Application</strong>.</li> |
| </ul> |
| </li> |
| <li>Adjust your desired launch configuration settings. |
| <p>In the Target tab, consider whether you'd like to use Manual or Automatic mode |
| when selecting an AVD to run your application. |
| See the following section on <a href=#AutoAndManualModes">Automatic and manual target |
| modes</a>).</p> |
| <p>You can specify any emulator options to the Additional Emulator Command |
| Line Options field. For example, you could add <code>-scale 96dpi</code> to |
| scale the AVD's screen to an accurate size, based on the dpi of your |
| computer monitor. For a full list of emulator options, see the <a |
| href="{@docRoot}guide/developing/tools/emulator.html">Android Emulator</a> |
| document.</p> |
| </li> |
| </ol> |
| |
| |
| <h3 id="AutoAndManualTargetModes">Automatic and manual target modes</h3> |
| |
| <p>By default, a run configuration uses the <strong>automatic</strong> target mode in order to select |
| an AVD. In this mode, ADT will select an AVD for the application in the following manner:</p> |
| |
| <ol> |
| <li>If there's a device or emulator already running and its AVD configuration |
| meets the requirements of the application's build target, the application is installed |
| and run upon it.</li> |
| <li>If there's more than one device or emulator running, each of which meets the requirements |
| of the build target, a "device chooser" is shown to let you select which device to use.</li> |
| <li>If there are no devices or emulators running that meet the requirements of the build target, |
| ADT looks at the available AVDs. If one meets the requirements of the build target, |
| the AVD is used to launch a new emulator, upon which the application is installed and run.</li> |
| <li>If all else fails, the application will not be run and you will see a console error warning |
| you that there is no existing AVD that meets the build target requirements.</li> |
| </ol> |
| |
| <p>However, if a "preferred AVD" is selected in the run configuration, then the application |
| will <em>always</em> be deployed to that AVD. If it's not already running, then a new emulator |
| will be launched.</p> |
| |
| <p>If your run configuration uses <strong>manual</strong> mode, then the "device chooser" |
| is presented every time that your application is run, so that you can select which AVD to use.</p> |
| |
| |
| <h2 id="Signing">Signing your Applications</h2> |
| |
| <p>As you begin developing Android applications, understand that all |
| Android applications must be digitally signed before the system will install |
| them on an emulator or an actual device. There are two ways to do this: |
| with a debug key (for immediate testing on an emulator or development device) |
| or with a private key (for application distribution).</p> |
| |
| <p>The ADT plugin helps you get started quickly by signing your .apk files with |
| a debug key, prior to installing them on an emulator or development device. This means that you can |
| quickly run your application from Eclipse without having to |
| generate your own private key. No specific action on your part is needed, |
| provided ADT has access to Keytool.However, please note that if you intend |
| to publish your application, you <strong>must</strong> sign the application with your |
| own private key, rather than the debug key generated by the SDK tools.</p> |
| |
| <p>Please read <a href="{@docRoot}guide/publishing/app-signing.html">Signing Your |
| Applications</a>, which provides a thorough guide to application signing on Android |
| and what it means to you as an Android application developer. The document also includes |
| a guide to exporting and signing your application with the ADT's Export Wizard.</p> |
| |
| |
| <h2 id="Tips">Eclipse Tips </h2> |
| |
| <h3 id="arbitraryexpressions">Executing arbitrary Java expressions in Eclipse</h3> |
| |
| <p>You can execute arbitrary code when paused at a breakpoint in Eclipse. For example, |
| when in a function with a String argument called "zip", you can get |
| information about packages and call class methods. You can also invoke arbitrary |
| static methods: for example, entering <code>android.os.Debug.startMethodTracing()</code> will |
| start dmTrace. </p> |
| <p>Open a code execution window, select <strong>Window</strong>><strong>Show |
| View</strong>><strong>Display</strong> from the main menu to open the |
| Display window, a simple text editor. Type your expression, highlight the |
| text, and click the 'J' icon (or CTRL + SHIFT + D) to run your |
| code. The code runs in the context of the selected thread, which must be |
| stopped at a breakpoint or single-step point. (If you suspend the thread |
| manually, you have to single-step once; this doesn't work if the thread is |
| in Object.wait().)</p> |
| <p>If you are currently paused on a breakpoint, you can simply highlight and execute |
| a piece of source code by pressing CTRL + SHIFT + D. </p> |
| <p>You can highlight a block of text within the same scope by pressing ALT +SHIFT |
| + UP ARROW to select larger and larger enclosing blocks, or DOWN ARROW to select |
| smaller blocks. </p> |
| <p>Here are a few sample inputs and responses in Eclipse using the Display window.</p> |
| |
| <table width="100%" border="1"> |
| <tr> |
| <th scope="col">Input</th> |
| <th scope="col">Response</th> |
| </tr> |
| <tr> |
| <td><code>zip</code></td> |
| <td><code>(java.lang.String) |
| /work/device/out/linux-x86-debug/android/app/android_sdk.zip</code></td> |
| </tr> |
| <tr> |
| <td><code>zip.endsWith(".zip")</code></td> |
| <td><code>(boolean) true</code></td> |
| </tr> |
| <tr> |
| <td><code>zip.endsWith(".jar")</code></td> |
| <td><code>(boolean) false</code></td> |
| </tr> |
| </table> |
| <p>You can also execute arbitrary code when not debugging by using a scrapbook page. |
| Search the Eclipse documentation for "scrapbook".</p> |
| |
| |
| <h3>Running DDMS Manually</h3> |
| |
| <p>Although the recommended way to debug is to use the ADT plugin, you can manually run |
| DDMS and configure Eclipse to debug on port 8700. (<strong>Note: </strong>Be sure that you |
| have first started <a href="{@docRoot}guide/developing/tools/ddms.html">DDMS</a>). </p> |
| |
| |
| <!-- TODO: clean this up and expand it to cover more wizards and features |
| <h3>ADT Wizards</h3> |
| |
| <p>Notice that the "New Android Project" wizard has been expanded to use the multi-platform |
| capabilities of the new SDK.</p> |
| |
| <p>There is now a "New XML File" wizard that lets you create skeleton XML resource |
| files for your Android projects. This makes it easier to create a new layout, a new menu, a |
| new strings file, etc.</p> |
| |
| <p>Both wizards are available via <strong>File > New</strong> and new icons in the main |
| Eclipse toolbar (located to the left of the Debug and Run icons). |
| If you do not see the new icons, you may need to select <strong>Window > Reset |
| Perspective</strong> from the Java perspective.</p> |
| --> |