index.jd revision 9066cfe9886ac131c34d59ed0e2d287b0e3c0087
19066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpage.title=User Interface
29066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project@jd:body
39066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
49066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<div id="qv-wrapper">
59066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<div id="qv">
69066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
79066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project  <h2>Key classes</h2>
89066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project  <ol>
99066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    <li>{@link android.view.View}</li>
109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    <li>{@link android.view.ViewGroup}</li>
119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    <li>{@link android.widget Widget classes}</li>
129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project  </ol>
139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project  <h2>In this document</h2>
159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project  <ol>
169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    <li><a href="#ViewHierarchy">View Hierarchy</a></li>
179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    <li><a href="#Layout">Layout</a></li>
189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    <li><a href="#Widgets">Widgets</a></li>
199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    <li><a href="#Events">UI Events</a></li>
209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    <li><a href="#Menus">Menus</a></li>
219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    <li><a href="#Advanced">Advanced Topics</a>
229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project      <ol>
239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        <li><a href="#Adapters">Adapters</a></li>
249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        <li><a href="#StylesAndThemes">Styles and Themes</a></li>
259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project      </ol>
269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    </li>
279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project  </ol>
289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project</div>
299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project</div>
309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>In an Android application, the user interface is built using {@link android.view.View} and 
329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{@link android.view.ViewGroup} objects. There are many types of views and view groups, each of which 
339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectis a descendant of the {@link android.view.View} class.</p>
349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>View objects are the basic units of user interface expression on the Android platform. 
369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source ProjectThe View class serves as the base for subclasses called "widgets," which offer fully implemented
379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source ProjectUI objects, like text fields and buttons. The ViewGroup class serves as the base for subclasses called "layouts,"
389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectwhich offer different kinds of layout architecture, like linear, tabular and relative.</p>
399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>A View object is a data structure whose properties store the layout parameters and content for a specific 
419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectrectangular area of the screen. A View object handles its own measurement, layout, drawing, focus change, 
429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectscrolling, and key/gesture interactions for the rectangular area of the screen in which it resides. As an
439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectobject in the user interface, a View is also a point of interaction for the user and the receiver
449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectof the interaction events.</p>
459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<h2 id="ViewHierarchy">View Hierarchy</h2>
489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>On the Android platform, you define an Activity's UI using a hierarchy of View and ViewGroup nodes, 
509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectas shown in the diagram below. This hierarchy tree can be as simple or complex as you need it to be, and you 
519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectcan build it up using Android's set of predefined widgets and layouts, or with custom Views that you 
529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectcreate yourself.</p>
539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<img src="{@docRoot}images/viewgroup.png" alt="" width="312" height="211" align="center"/>
559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>
579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source ProjectIn order to attach the view hierarchy tree to the screen for rendering, your Activity must call the
589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<code>{@link android.app.Activity#setContentView(int) setContentView()}</code> 
599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectmethod and pass a reference to the root node object. The Android system
609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectreceives this reference and uses it to invalidate, measure, and draw the tree. The root node of the hierarchy requests 
619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectthat its child nodes draw themselves &mdash; in turn, each view group node is responsible for calling 
629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectupon each of its own child views to draw themselves.
639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source ProjectThe children may request a size and location within the parent, but the parent object has the final 
649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectdecision on where how big each child can be.  Android parses 
659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectthe elements of your layout in-order (from the top of the hierarchy tree), instantiating the Views and 
669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectadding them to their parent(s). Because these are drawn in-order, if there are elements that
679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectoverlap positions, the last one to be drawn will lie on top of others previously drawn to that space.</p>
689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>For a more detailed discussion on how view hierarchies are measured
709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectand drawn, read <a href="how-android-draws.html">How Android Draws Views</a>.</p>
719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<h2 id="Layout">Layout</h2>
749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>The most common way to define your layout and express the view hierarchy is with an XML layout file.
769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source ProjectXML offers a human-readable structure for the layout, much like HTML. Each element in XML is 
779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projecteither a View or ViewGroup object (or descendent thereof). View objects are leaves in the tree, 
789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source ProjectViewGroup objects are branches in the tree (see the View Hierarchy figure above).</p>
799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>The name of an XML element
809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectis respective to the Java class that it represents. So a <code>&lt;TextView></code> element creates
819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projecta {@link android.widget.TextView} in your UI, and a <code>&lt;LinearLayout></code> element creates
829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projecta {@link android.widget.LinearLayout} view group. When you load a layout resource, 
839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectthe Android system initializes these run-time objects, corresponding to the elements in your layout.</p>
849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>For example, a simple vertical layout with a text view and a button looks like this:</p>
869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<pre>
879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project&lt;?xml version="1.0" encoding="utf-8"?>
889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project&lt;LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              android:layout_width="fill_parent" 
909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              android:layout_height="fill_parent"
919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              android:orientation="vertical" >
929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    &lt;TextView android:id="@+id/text"
939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              android:layout_width="wrap_content"
949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              android:layout_height="wrap_content"
959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project              android:text="Hello, I am a TextView" />
969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    &lt;Button android:id="@+id/button"
979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            android:layout_width="wrap_content"
989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            android:layout_height="wrap_content"
999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            android:text="Hello, I am a Button" />
1009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project&lt;/LinearLayout>
1019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project</pre>
1029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>Notice that the LinearLayout element contains both the TextView and the Button. You can nest
1049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectanother LinearLayout (or other type of view group) inside here, to lengthen the view hierarchy and create a more
1059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectcomplex layout.</p>
1069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>For more on building a UI layout, read <a href="declaring-layout.html">Declaring Layout</a>.
1089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<div class="sidebox-wrapper">
1109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<div class="sidebox-inner">
1119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project  <p><b>Tip:</b> You can also draw View and ViewGroups objects in Java code, 
1129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project  using the <code>{@link android.view.ViewGroup#addView(View)}</code> methods 
1139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project  to dynamically insert new View and ViewGroup objects.</p>
1149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project</div>
1159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project</div>
1169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>There are a variety of ways in which you can layout your views. Using more and different kinds of view groups,
1189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectyou can structure child views and view groups in an infinite number of ways.
1199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source ProjectSome pre-defined view groups offered by Android (called layouts) include LinearLayout, RelativeLayout, AbsoluteLayout,
1209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source ProjectTableLayout, GridLayout and others. Each offers a unique set of layout parameters that are used to define the
1219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpositions of child views and layout structure.</p>
1229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>To learn about some of the different kinds of view groups used for a layout, 
1239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectread <a href="layout-objects.html">Common Layout Objects</a>.</p>
1249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<h2 id="Widgets">Widgets</h2>
1279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>A widget is a View object that serves as an interface for interaction with the user. 
1299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source ProjectAndroid provides a set of fully implemented 
1309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectwidgets, like buttons, checkboxes, and text-entry fields, so you can quickly build your UI. 
1319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source ProjectSome widgets provided by Android are more complex, like a date picker, a clock, and zoom controls.
1329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source ProjectBut you're not limited to the kinds of widgets provided by the Android platform. If you'd
1339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectlike to do something more customized and create your own actionable elements, you can, by defining your own 
1349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source ProjectView object or by extending and combining existing widgets.</p>
1359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>Read more in <a href="custom-components.html">Building Custom Components</a>.</p>
1369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>For a list of the widgets provided by Android, see the {@link android.widget} package.</p>
1389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<h2 id="Events">UI Events</h2>
1419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>Once you've added some Views/widgets to the UI, you probably want to know about the 
1439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectuser's interaction with them, so you can perform actions. To be informed of UI events, you need to 
1449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectdo one of two things:</p>
1459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<ul>
1469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project  <li><strong>Define an event listener and register it with the View.</strong> More often than not,
1479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectthis is how you'll listen for events. The View class contains a collection of nested interfaces named
1489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source ProjectOn<em>&lt;something></em>Listener, each with a callback method called <code>On<em>&lt;something></em>()</code>.
1499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source ProjectFor example, {@link android.view.View.OnClickListener} (for handling "clicks" on a View),
1509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{@link android.view.View.OnTouchListener} (for handling touch screen events in a View), and
1519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{@link android.view.View.OnKeyListener} (for handling device key presses within a View). So if you want your View
1529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectto be notified when it is "clicked" (such as when a button is selected), implement OnClickListener and define
1539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectits <code>onClick()</code> callback method (where you perform the action upon click), and register it
1549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectto the View with <code>{@link android.view.View#setOnClickListener(View.OnClickListener) setOnClickListener()}</code>.
1559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project</li>
1569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project  <li><strong>Override an existing callback method for the View.</strong> This is
1579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectwhat you should do when you've implemented your own View class and want to listen for specific events 
1589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectthat occur within it. Example events you can handle include when the
1599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectscreen is touched (<code>{@link android.view.View#onTouchEvent(MotionEvent) onTouchEvent()}</code>), when
1609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectthe trackball is moved (<code>{@link android.view.View#onTrackballEvent(MotionEvent) onTrackballEvent()}</code>), 
1619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projector when a key on the device is pressed (<code>{@link android.view.View#onKeyDown(int, KeyEvent)
1629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source ProjectonKeyDown()}</code>). This allows you to define the default behavior for each event inside your custom View and determine
1639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectwhether the event should be passed on to some other child View. Again, these are callbacks to the View class,
1649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectso your only chance to define them is when you 
1659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<a href="{@docRoot}guide/topics/ui/custom-components.html">build a custom component</a>.
1669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project</li>
1679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project</ul>
1689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>Continue reading about handling user interaction with Views in the <a href="ui-events.html">Handling UI Events</a>
1709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectdocument.</p>
1719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<h2 id="Menus">Menus</h2>
1749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>Application menus are another important part of an application's UI. Menus offers a reliable interface that reveals
1769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectapplication functions and settings. The most common application menu is revealed by pressing
1779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectthe MENU key on the device. However, you can also add Context Menus, which may be revealed when the user presses
1789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectand holds down on an item.</p>
1799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>Menus are also structured using a View hierarchy, but you don't define this structure yourself. Instead,
1819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectyou define the <code>{@link android.app.Activity#onCreateOptionsMenu(Menu) onCreateOptionsMenu()}</code> or 
1829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<code>{@link android.app.Activity#onCreateContextMenu(ContextMenu,View,ContextMenu.ContextMenuInfo) onCreateContextMenu()}</code> 
1839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectcallback methods for your Activity and declare the items that you want to include in your menu. 
1849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source ProjectAt the appropriate time, Android will automatically create the necessary View hierarchy for the menu and 
1859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectdraw each of your menu items in it.</p>
1869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>Menus also handle their own events, so there's no need to register event listeners on the items in your menu.
1889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source ProjectWhen an item in your menu is selected, the <code>{@link android.app.Activity#onOptionsItemSelected(MenuItem) 
1899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source ProjectonOptionsItemSelected()}</code> or 
1909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<code>{@link android.app.Activity#onContextItemSelected(MenuItem) onContextItemSelected()}</code>
1919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectmethod will be called by the framework.</p>
1929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>And just like your application layout, you have the option to declare the items for you menu in an XML file.</p>
1949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>Read <a href="{@docRoot}guide/topics/ui/menus.html">Creating Menus</a> to learn more.</p>
1969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<h2 id="Advanced">Advanced Topics</h2>
1999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>Once you've grappled the fundamentals of creating a user interface, you can explore
2019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectsome advanced features for creating a more complex application interface.</p>
2029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<h3 id="Adapters">Adapters</h3>
2049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>Sometimes you'll want to populate a view group with some information that can't be hard-coded, instead, 
2069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectyou want to bind your view to an external source of data. To do this, you use an AdapterView as
2079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectyour view group and each child View is initialized and populated with data from the Adapter.</p>
2089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>The AdapterView object is an implementation of ViewGroup that determines its child views
2099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectbased on a given Adapter object. The Adapter acts like a courier between your data source (perhaps an
2109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectarray of external strings) and the AdapterView, which displays it. There are several implementations
2119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectof the Adapter class, for specific tasks, such as the CursorAdapter for reading database data from a Cursor,
2129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projector an ArrayAdapter for reading from an arbitrary array.</p>
2139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>To learn more about using an Adapter to populate your views, read 
2149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<a href="binding.html">Binding to Data with AdapterView</a>.</p>
2159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<h3 id="StylesAndThemes">Styles and Themes</h3>
2189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>Perhaps you're not satisfied with the look of the standard widgets. To revise them, you can create some 
2209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectof your own styles and themes.</p>
2219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<ul>
2239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project  <li>A style is a set of one or more formatting attributes that you can apply as a unit to individual elements 
2249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectin your layout. For example, you could define a style that specifies a certain text size and color, then 
2259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectapply it to only specific View elements.</li>
2269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project  <li>A theme is a set of one or more formatting attributes that you can apply as a unit to all activities in 
2279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectan application, or just a single activity. For example, you could define a theme that sets specific colors for 
2289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectthe window frame and the panel background, and sets text sizes and colors for menus. This theme can then be 
2299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectapplied to specific activities or the entire application.</li>
2309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project</ul>
2319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
2329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>Styles and themes are resources. Android provides some default style and theme resources that you can use, 
2339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projector you can declare your own custom style and theme resources.</p>
2349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<p>Learn more about using styles and themes in the
2359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project<a href="themes.html">Applying Styles and Themes</a> document.</p>
236