![](/pic/1/4/8/2/9/5//i_005.jpg)
Figure 5-1.
CHAPTER 6
Employing Basic Widgets
Every GUI toolkit has some basic widgets: fields, labels, buttons, etc. Android’s toolkit is no different in scope, and the basic widgets will provide a good introduction as to how widgets work in Android activities.
Assigning Labels
The simplest widget is the label, referred to in Android as a TextView
. Like in most GUI toolkits, labels are bits of text not editable directly by users. Typically, they are used to identify adjacent widgets (e.g., a “Name:” label before a field where one fills in a name).
In Java, you can create a label by creating a TextView
instance. More commonly, though, you will create labels in XML layout files by adding a TextView
element to the layout, with an android:text
property to set the value of the label itself. If you need to swap labels based on certain criteria, such as internationalization, you may wish to use a resource reference in the XML instead, as will be described in Chapter 9. TextView
has numerous other properties of relevance for labels, such as:
• android:typeface
to set the typeface to use for the label (e.g., monospace
)
• android:textStyle
to indicate that the typeface should be made bold (bold
), italic (italic
), or bold and italic (bold_italic
)
• android:textColor
to set the color of the label’s text, in RGB hex format (e.g., #FF0000
for red)
For example, in the Basic/Label project, you will find the following layout file:
<?xml version='1.0' encoding='utf-8'?>
<TextView xmlns:android='http://schemas.android.com/apk/res/android'
android:layout_width='fill_parent'
android:layout_height='wrap_content'
android:text='You were expecting something profound?'
/>
As you can see in Figure 6-1, just that layout alone, with the stub Java source provided by Android’s project builder (e.g., activityCreator
), gives you the application.
![](/pic/1/4/8/2/9/5//i_006.jpg)
Figure 6-1.
Button, Button, Who’s Got the Button?
We’ve already seen the use of the Button widget in Chapters 4 and 5. As it turns out, Button
is a subclass of TextView
, so everything discussed in the preceding section in terms of formatting the face of the button still holds.
Fleeting Images
Android has two widgets to help you embed images in your activities: ImageView
and ImageButton
. As the names suggest, they are image-based analogues to TextView
and Button
, respectively.
Each widget takes an android:src
attribute (in an XML layout) to specify what picture to use. These usually reference a drawable resource, described in greater detail in the chapter on resources. You can also set the image content based on a Uri
from a content provider via setImageURI()
.
ImageButton
, a subclass of ImageView
, mixes in the standard
Button behaviors, for responding to clicks and whatnot.
For example, take a peek at the main.xml
layout from the Basic/ImageView
sample project which is found along with all other code samples at http://apress.com:
<?xml version='1.0' encoding='utf-8'?>
<ImageView xmlns:android='http://schemas.android.com/apk/res/android'
android:id='@+id/icon'
android:layout_width='fill_parent'
android:layout_height='fill_parent'
android:adjustViewBounds='true'
android:src='@drawable/molecule'
/>
The result, just using the code-generated activity, is shown in Figure 6-2.
![](/pic/1/4/8/2/9/5//i_007.jpg)
Figure 6-2.
Fields of Green. Or Other Colors.
Along with buttons and labels, fields are the third “anchor” of most GUI toolkits. In Android, they are implemented via the EditText
widget, which is a subclass of the TextView
used for labels.
Along with the standard TextView
properties (e.g., android:textStyle
), EditText
has many others that will be useful for you in constructing fields, including:
• android:autoText
, to control if the field should provide automatic spelling assistance
• android:capitalize
, to control if the field should automatically capitalize the first letter of entered text (e.g., first name, city)
• android:digits
, to configure the field to accept only certain digits
• android:singleLine
, to control if the field is for single-line input or multiple-line input (e.g., does Enter move you to the next widget or add a newline?)
Beyond those, you can configure fields to use specialized input methods, such as android:numeric
for numeric-only input, android:password
for shrouded password input, and android:phoneNumber
for entering in phone numbers. If you want to create your own input method scheme (e.g., postal codes, Social Security numbers), you need to create your own implementation of