Android provides a number of ready-made views that you can use to design and organize your layout. "Widgets" are views that provide a visual (and interactive) elements for the screen, such as a button, text field, checkbox, or just an image. "Layouts" are views derived from ViewGroup
that provide a unique layout model for its child views, such as a linear layout, a grid layout, or relative layout. You can also subclass the View
and ViewGroup
classes (or existing subclasses) to create your own widgets and layouts and apply them to your activity layout.html
There are several other attributes that you can include in this element, to define properties such as the label for the activity, an icon for the activity, or a theme to style the activity's UI. The android:name
attribute is the only required attribute—it specifies the class name of the activity. java
An <activity>
element can also specify various intent filters—using the <intent-filter>
element—in order to declare how other application components may activate it. android
If you intend for your application to be self-contained and not allow other applications to activate its activities, then you don't need any other intent filters.app
Activities that you don't want to make available to other applications should have no intent filters and you can start them yourself using explicit intents (as discussed in the following section). ide
Explicityly start a service(using className)ui
Intent intent = new Intent(this, SignInActivity.class); startActivity(intent);
Implicitly start a service(using a intent, this is powerful, the system will find the activity for you)this
For example, if you want to allow the user to send an email message, you can create the following intent: spa
Intent intent = new Intent(Intent.ACTION_SEND); intent.putExtra(Intent.EXTRA_EMAIL, recipientArray); startActivity(intent);
if we wan to receive a result from the activity that we start, we should use startActivityForResult(). then we should override the callback method onActivityResult() to read the results.rest
You can shut down an activity by calling its finish()
method. You can also shut down a separate activity that you previously started by calling finishActivity()
. code
An activity can exist in essentially three states:
Activity
object is retained in memory, it maintains all state and member information, and remains attached to the window manager), but can be killed by the system in extremely low memory situations.
The activity is completely obscured by another activity (the activity is now in the "background"). A stopped activity is also still alive (the Activity
object is retained in memory, it maintains all state and member information, but is not attached to the window manager). However, it is no longer visible to the user and it can be killed by the system when memory is needed elsewhere.
onCreate()
and the call to onDestroy()
. Your activity should perform setup of "global" state (such as defining layout) in onCreate()
, and release all remaining resources in onDestroy()
. For example, if your activity has a thread running in the background to download data from the network, it might create that thread in onCreate()
and then stop the thread inonDestroy()
.The visible lifetime of an activity happens between the call to onStart()
and the call to onStop()
. During this time, the user can see the activity on-screen and interact with it. For example, onStop()
is called when a new activity starts and this one is no longer visible. Between these two methods, you can maintain resources that are needed to show the activity to the user. For example, you can register aBroadcastReceiver
in onStart()
to monitor changes that impact your UI, and unregister it inonStop()
when the user can no longer see what you are displaying. The system might call onStart()
and onStop()
multiple times during the entire lifetime of the activity, as the activity alternates between being visible and hidden to the user.
The foreground lifetime of an activity happens between the call to onResume()
and the call toonPause()
. During this time, the activity is in front of all other activities on screen and has user input focus. An activity can frequently transition in and out of the foreground—for example, onPause()
is called when the device goes to sleep or when a dialog appears. Because this state can transition often, the code in these two methods should be fairly lightweight in order to avoid slow transitions that make the user wait.
(onPause()
, onStop()
, and onDestroy()
). Because onPause()
is the first of the three, once the activity is created, onPause()
is the last method that's guaranteed to be called before the processcan be killed—if the system must recover memory in an emergency, then onStop()
and onDestroy()
might not be called. Therefore, you should use onPause()
to write crucial persistent data (such as user edits) to storage. However, you should be selective about what information must be retained during onPause()
, because any blocking procedures in this method block the transition to the next activity and slow the user experience.
In this situation, you can ensure that important information about the activity state is preserved by implementing an additional callback method that allows you to save information about the state of your activity: onSaveInstanceState()
.
The system calls onSaveInstanceState()
before making the activity vulnerable to destruction. The system passes this method a Bundle
in which you can save state information about the activity as name-value pairs, using methods such as putString()
and putInt()
. Then, if the system kills your application process and the user navigates back to your activity, the system recreates the activity and passes the Bundle
to bothonCreate()
and onRestoreInstanceState()
. Using either of these methods, you can extract your saved state from the Bundle
and restore the activity state. If there is no state information to restore, then the Bundle
passed to you is null (which is the case when the activity is created for the first time).
Some device configurations can change during runtime (such as screen orientation, keyboard availability, and language). When such a change occurs, Android recreates the running activity (the system calls onDestroy()
, then immediately calls onCreate()
).
The best way to handle such a restart is to save and restore the state of your activity usingonSaveInstanceState()
and onRestoreInstanceState()
(or onCreate()
), as discussed in the previous section.
The order of lifecycle callbacks is well defined, particularly when the two activities are in the same process and one is starting the other. Here's the order of operations that occur when Activity A starts Acivity B:
onPause()
method executes.onCreate()
, onStart()
, and onResume()
methods execute in sequence. (Activity B now has user focus.)onStop()
method executes.This predictable sequence of lifecycle callbacks allows you to manage the transition of information from one activity to another. For example, if you must write to a database when the first activity stops so that the following activity can read it, then you should write to the database during onPause()
instead of during onStop()
.
That's the activity B's creation is between the onPause and onStop of activity of A.
Note: Because onSaveInstanceState()
is not guaranteed to be called, you should use it only to record the transient state of the activity (the state of the UI)—you should never use it to store persistent data. Instead, you should use onPause()
to store persistent data (such as data that should be saved to a database) when the user leaves the activity.