All user interface elements in an Android app are built using
Viewis an object that draws something on the screen that the user can interact with. A
ViewGroupis an object that holds other
ViewGroup) objects in order to define the layout of the interface.
Android provides a collection of both
ViewGroupsubclasses that offer you common input controls (such as buttons and text fields) and various layout models (such as a linear or relative layout).
User Interface Layout
The user interface for each component of your app is defined using a hierarchy of
ViewGroupobjects, as shown in figure 1. Each view group is an invisible container that organizes child views, while the child views may be input controls or other widgets that draw some part of the UI. This hierarchy tree can be as simple or complex as you need it to be (but simplicity is best for performance).
To declare your layout, you can instantiate
Viewobjects in code and start building a tree, but the easiest and most effective way to define your layout is with an XML file. XML offers a human-readable structure for the layout, similar to HTML.
For example, a simple vertical layout with a text view and a button looks like this:
xml version="1.0" encoding="utf-8"?>
xmlns:android="https://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" > android:id="@+id/text" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="I am a TextView" />
When you load a layout resource in your app, Android initializes each node of the layout into a runtime object you can use to define additional behaviors, query the object state, or modify the layout.
For a complete guide to creating a UI layout, see XML Layouts.
User Interface Components
You don't have to build all of your UI using
ViewGroupobjects. Android provides several app components that offer a standard UI layout for which you simply need to define the content. These UI components each have a unique set of APIs that are described in their respective documents, such as Action Bar, Dialogs, and Status Notifications.