1 page.title=Tasks and Back Stack 2 parent.title=Activities 3 parent.link=activities.html 4 @jd:body 5 6 <div id="qv-wrapper"> 7 <div id="qv"> 8 <h2>Quickview</h2> 9 <ul> 10 <li>All activities belong to a task</li> 11 <li>A task contains a collection of activities in the order in which the user interacts with 12 them</li> 13 <li>Tasks can move to the background and retain the state of each activity in order for users 14 to perform other tasks without losing their work</li> 15 </ul> 16 17 <h2>In this document</h2> 18 <ol> 19 <li><a href="#ActivityState">Saving Activity State</a></li></li> 20 <li><a href="#ManagingTasks">Managing Tasks</a> 21 <ol> 22 <li><a href="#TaskLaunchModes">Defining launch modes</a></li> 23 <li><a href="#Affinities">Handling affinities</a></li> 24 <li><a href="#Clearing">Clearing the back stack</a></li> 25 <li><a href="#Starting">Starting a task</a></li> 26 </ol> 27 </li> 28 </ol> 29 30 <h2>Articles</h2> 31 <ol> 32 <li><a href="{@docRoot}resources/articles/multitasking-android-way.html">Multitasking the Android Way</a></li> 33 </ol> 34 35 <h2>See also</h2> 36 <ol> 37 <li><a href="{@docRoot}design/patterns/navigation.html">Android Design: 38 Navigation</a></li> 39 <li><a href="{@docRoot}videos/index.html#v=fL6gSd4ugSI">Application Lifecycle video</a></li> 40 <li><a 41 href="{@docRoot}guide/topics/manifest/activity-element.html">{@code <activity>} manifest 42 element</a></li> 43 </ol> 44 </div> 45 </div> 46 47 48 <p>An application usually contains multiple <a 49 href="{@docRoot}guide/topics/fundamentals/activities.html">activities</a>. Each activity 50 should be designed around a specific kind of action the user can perform and can start other 51 activities. For example, an email application might have one activity to show a list of new email. 52 When the user selects an email, a new activity opens to view that email.</p> 53 54 <p>An activity can even start activities that exist in other applications on the device. For 55 example, if your application wants to send an email, you can define an intent to perform a "send" 56 action and include some data, such as an email address and a message. An activity from another 57 application that declares itself to handle this kind of intent then opens. In this case, the intent 58 is to send an email, so an email application's "compose" activity starts (if multiple activities 59 support the same intent, then the system lets the user select which one to use). When the email is 60 sent, your activity resumes and it seems as if the email activity was part of your application. Even 61 though the activities may be from different applications, Android maintains this seamless user 62 experience by keeping both activities in the same <em>task</em>.</p> 63 64 <p>A task is a collection of activities that users interact with 65 when performing a certain job. The activities are arranged in a stack (the "back stack"), in the 66 order in which each activity is opened.</p> 67 68 <!-- SAVE FOR WHEN THE FRAGMENT DOC IS ADDED 69 <div class="sidebox-wrapper"> 70 <div class="sidebox"> 71 <h3>Adding fragments to a task's back stack</h3> 72 73 <p>Your activity can also include {@link android.app.Fragment}s to the back stack. For example, 74 suppose you have a two-pane layout using fragments, one of which is a list view (fragment A) and the 75 other being a layout to display an item from the list (fragment B). When the user selects an item 76 from the list, fragment B is replaced by a new fragment (fragment C). In this case, it might be 77 desireable for the user to navigate back to reveal fragment B, using the <em>Back</em> button.</p> 78 <p>In order to add fragment B to the back stack so that this is possible, you must call {@link 79 android.app.FragmentTransaction#addToBackStack addToBackStack()} before you {@link 80 android.app.FragmentTransaction#commit()} the transaction that replaces fragment B with fragment 81 C.</p> 82 <p>For more information about using fragments and adding them to the back stack, see the {@link 83 android.app.Fragment} class documentation.</p> 84 85 </div> 86 </div> 87 --> 88 89 <p>The device Home screen is the starting place for most tasks. When the user touches an icon in the 90 application 91 launcher (or a shortcut on the Home screen), that application's task comes to the foreground. If no 92 task exists for the application (the application has not been used recently), then a new task 93 is created and the "main" activity for that application opens as the root activity in the stack.</p> 94 95 <p>When the current activity starts another, the new activity is pushed on the top of the stack and 96 takes focus. The previous activity remains in the stack, but is stopped. When an activity 97 stops, the system retains the current state of its user interface. When the user presses the 98 <em>Back</em> 99 button, the current activity is popped from the top of the stack (the activity is destroyed) and the 100 previous activity resumes (the previous state of its UI is restored). Activities in the stack are 101 never rearranged, only pushed and popped from the stack—pushed onto the stack when started by 102 the current activity and popped off when the user leaves it using the <em>Back</em> button. As such, 103 the back 104 stack operates as a "last in, first out" object structure. Figure 1 visualizes 105 this behavior with a timeline showing the progress between activities along with the current back 106 stack at each point in time.</p> 107 108 <img src="{@docRoot}images/fundamentals/diagram_backstack.png" alt="" /> 109 <p class="img-caption"><strong>Figure 1.</strong> A representation of how each new activity in a 110 task adds an item to the back stack. When the user presses the <em>Back</em> button, the current 111 activity is 112 destroyed and the previous activity resumes.</p> 113 114 115 <p>If the user continues to press <em>Back</em>, then each activity in the stack is popped off to 116 reveal the 117 previous one, until the user returns to the Home screen (or to whichever activity was running when 118 the task began). When all activities are removed from the stack, the task no longer exists.</p> 119 120 <div class="figure" style="width:287px"> 121 <img src="{@docRoot}images/fundamentals/diagram_multitasking.png" alt="" /> <p 122 class="img-caption"><strong>Figure 2.</strong> Two tasks: Task B receives user interaction 123 in the foreground, while Task A is in the background, waiting to be resumed.</p> 124 </div> 125 <div class="figure" style="width:215px"> 126 <img src="{@docRoot}images/fundamentals/diagram_multiple_instances.png" alt="" /> <p 127 class="img-caption"><strong>Figure 3.</strong> A single activity is instantiated multiple times.</p> 128 </div> 129 130 <p>A task is a cohesive unit that can move to the "background" when users begin a new task or go 131 to the Home screen, via the <em>Home</em> button. While in the background, all the activities in the 132 task are 133 stopped, but the back stack for the task remains intact—the task has simply lost focus while 134 another task takes place, as shown in figure 2. A task can then return to the "foreground" so users 135 can pick up where they left off. Suppose, for example, that the current task (Task A) has three 136 activities in its stack—two under the current activity. The user presses the <em>Home</em> 137 button, then 138 starts a new application from the application launcher. When the Home screen appears, Task A goes 139 into the background. When the new application starts, the system starts a task for that application 140 (Task B) with its own stack of activities. After interacting with 141 that application, the user returns Home again and selects the application that originally 142 started Task A. Now, Task A comes to the 143 foreground—all three activities in its stack are intact and the activity at the top of the 144 stack resumes. At 145 this point, the user can also switch back to Task B by going Home and selecting the application icon 146 that started that task (or by touching and holding the <em>Home</em> button to reveal recent tasks 147 and selecting 148 one). This is an example of multitasking on Android.</p> 149 150 <p class="note"><strong>Note:</strong> Multiple tasks can be held in the background at once. 151 However, if the user is running many background tasks at the same time, the system might begin 152 destroying background activities in order to recover memory, causing the activity states to be lost. 153 See the following section about <a href="#ActivityState">Activity state</a>.</p> 154 155 <p>Because the activities in the back stack are never rearranged, if your application allows 156 users to start a particular activity from more than one activity, a new instance of 157 that activity is created and pushed onto the stack (rather than bringing any previous instance of 158 the activity to the top). As such, one activity in your application might be instantiated multiple 159 times (even from different tasks), as shown in figure 3. As such, if the user navigates backward 160 using the <em>Back</em> button, each instance of the activity is revealed in the order they were 161 opened (each 162 with their own UI state). However, you can modify this behavior if you do not want an activity to be 163 instantiated more than once. How to do so is discussed in the later section about <a 164 href="#ManagingTasks">Managing Tasks</a>.</p> 165 166 167 <p>To summarize the default behavior for activities and tasks:</p> 168 169 <ul> 170 <li>When Activity A starts Activity B, Activity A is stopped, but the system retains its state 171 (such as scroll position and text entered into forms). 172 If the user presses the <em>Back</em> button while in Activity B, Activity A resumes with its state 173 restored.</li> 174 <li>When the user leaves a task by pressing the <em>Home</em> button, the current activity is 175 stopped and 176 its task goes into the background. The system retains the state of every activity in the task. If 177 the user later resumes the task by selecting the launcher icon that began the task, the task comes 178 to the foreground and resumes the activity at the top of the stack.</li> 179 <li>If the user presses the <em>Back</em> button, the current activity is popped from the stack 180 and 181 destroyed. The previous activity in the stack is resumed. When an activity is destroyed, the system 182 <em>does not</em> retain the activity's state.</li> 183 <li>Activities can be instantiated multiple times, even from other tasks.</li> 184 </ul> 185 186 187 <div class="design-announce"> 188 <p><strong>Navigation Design</strong></p> 189 <p>For more about how app navigation works on Android, read Android Design's <a 190 href="{@docRoot}design/patterns/navigation.html">Navigation</a> guide.</p> 191 </div> 192 193 194 <h2 id="ActivityState">Saving Activity State</h2> 195 196 <p>As discussed above, the system's default behavior preserves the state of an activity when it is 197 stopped. This way, when users navigate back to a previous activity, its user interface appears 198 the way they left it. However, you can—and <strong>should</strong>—proactively retain 199 the state of your activities using callback methods, in case the activity is destroyed and must 200 be recreated.</p> 201 202 <p>When the system stops one of your activities (such as when a new activity starts or the task 203 moves to the background), the system might destroy that activity completely if it needs to recover 204 system memory. When this happens, information about the activity state is lost. If this happens, the 205 system still 206 knows that the activity has a place in the back stack, but when the activity is brought to the 207 top of the stack the system must recreate it (rather than resume it). In order to 208 avoid losing the user's work, you should proactively retain it by implementing the {@link 209 android.app.Activity#onSaveInstanceState onSaveInstanceState()} callback 210 methods in your activity.</p> 211 212 <p>For more information about how to save your activity state, see the <a 213 href="{@docRoot}guide/topics/fundamentals/activities.html#SavingActivityState">Activities</a> 214 document.</p> 215 216 217 218 <h2 id="ManagingTasks">Managing Tasks</h2> 219 220 <p>The way Android manages tasks and the back stack, as described above—by placing all 221 activities started in succession in the same task and in a "last in, first out" stack—works 222 great for most applications and you shouldn't have to worry about how your activities are associated 223 with tasks or how they exist in the back stack. However, you might decide that you want to interrupt 224 the normal behavior. Perhaps you want an activity in your application to begin a new task when it is 225 started (instead of being placed within the current task); or, when you start an activity, you want 226 to bring forward an existing instance of it (instead of creating a new 227 instance on top of the back stack); or, you want your back stack to be cleared of all 228 activities except for the root activity when the user leaves the task.</p> 229 230 <p>You can do these things and more, with attributes in the 231 <a href="{@docRoot}guide/topics/manifest/activity-element.html">{@code 232 <activity>}</a> manifest element and with flags in the intent that you pass to {@link 233 android.app.Activity#startActivity startActivity()}.</p> 234 235 <p>In this regard, the the principal <a 236 href="{@docRoot}guide/topics/manifest/activity-element.html">{@code <activity>}</a> 237 attributes you can use are:</p> 238 239 <ul class="nolist"> 240 <li><a href="{@docRoot}guide/topics/manifest/activity-element.html#aff">{@code 241 taskAffinity}</a></li> 242 <li><a href="{@docRoot}guide/topics/manifest/activity-element.html#lmode">{@code 243 launchMode}</a></li> 244 <li><a href="{@docRoot}guide/topics/manifest/activity-element.html#reparent">{@code 245 allowTaskReparenting}</a></li> 246 <li><a href="{@docRoot}guide/topics/manifest/activity-element.html#clear">{@code 247 clearTaskOnLaunch}</a></li> 248 <li><a href="{@docRoot}guide/topics/manifest/activity-element.html#always">{@code 249 alwaysRetainTaskState}</a></li> 250 <li><a href="{@docRoot}guide/topics/manifest/activity-element.html#finish">{@code 251 finishOnTaskLaunch}</a></li> 252 </ul> 253 254 <p>And the principal intent flags you can use are:</p> 255 256 <ul class="nolist"> 257 <li>{@link android.content.Intent#FLAG_ACTIVITY_NEW_TASK}</li> 258 <li>{@link android.content.Intent#FLAG_ACTIVITY_CLEAR_TOP}</li> 259 <li>{@link android.content.Intent#FLAG_ACTIVITY_SINGLE_TOP}</li> 260 </ul> 261 262 <p>In the following sections, you'll see how you can use these manifest attributes and intent 263 flags to define how activities are associated with tasks and how the behave in the back stack.</p> 264 265 266 <p class="caution"><strong>Caution:</strong> Most applications should not interrupt the default 267 behavior for activities and tasks. If you determine that it's necessary for your activity to modify 268 the default behaviors, use caution and be sure to test the usability of the activity during 269 launch and when navigating back to it from other activities and tasks with the <em>Back</em> button. 270 Be sure 271 to test for navigation behaviors that might conflict with the user's expected behavior.</p> 272 273 274 <h3 id="TaskLaunchModes">Defining launch modes</h3> 275 276 <p>Launch modes allow you to define how a new instance of an activity is associated with the 277 current task. You can define different launch modes in two ways:</p> 278 <ul class="nolist"> 279 <li><a href="#ManifestForTasks">Using the manifest file</a> 280 <p>When you declare an activity in your manifest file, you can specify how the activity 281 should associate with tasks when it starts.</li> 282 <li><a href="#IntentFlagsForTasks">Using Intent flags</a> 283 <p>When you call {@link android.app.Activity#startActivity startActivity()}, 284 you can include a flag in the {@link android.content.Intent} that declares how (or 285 whether) the new activity should associate with the current task.</p></li> 286 </ul> 287 288 <p>As such, if Activity A starts Activity B, Activity B can define in its manifest how it 289 should associate with the current task (if at all) and Activity A can also request how Activity 290 B should associate with current task. If both activities define how Activity B 291 should associate with a task, then Activity A's request (as defined in the intent) is honored 292 over Activity B's request (as defined in its manifest).</p> 293 294 <p class="note"><strong>Note:</strong> Some launch modes available for the manifest file 295 are not available as flags for an intent and, likewise, some launch modes available as flags 296 for an intent cannot be defined in the manifest.</p> 297 298 299 <h4 id="ManifestForTasks">Using the manifest file</h4> 300 301 <p>When declaring an activity in your manifest file, you can specify how the activity should 302 associate with a task using the <a 303 href="{@docRoot}guide/topics/manifest/activity-element.html">{@code <activity>}</a> 304 element's <a href="{@docRoot}guide/topics/manifest/activity-element.html#lmode">{@code 305 launchMode}</a> attribute.</p> 306 307 <p>The <a href="{@docRoot}guide/topics/manifest/activity-element.html#lmode">{@code 308 launchMode}</a> attribute specifies an instruction on how the activity should be launched into a 309 task. There are four different launch modes you can assign to the 310 <code><a href="{@docRoot}guide/topics/manifest/activity-element.html#lmode">launchMode</a></code> 311 attribute:</p> 312 313 <dl> 314 <dt>{@code "standard"} (the default mode)</dt> 315 <dd>Default. The system creates a new instance of the activity in the task from 316 which it was started and routes the intent to it. The activity can be instantiated multiple times, 317 each instance can belong to different tasks, and one task can have multiple instances.</dd> 318 <dt>{@code "singleTop"}</dt> 319 <dd>If an instance of the activity already exists at the top of the current task, the system 320 routes the intent to that instance through a call to its {@link 321 android.app.Activity#onNewIntent onNewIntent()} method, rather than creating a new instance of the 322 activity. The activity can be instantiated multiple times, each instance can 323 belong to different tasks, and one task can have multiple instances (but only if the the 324 activity at the top of the back stack is <em>not</em> an existing instance of the activity). 325 <p>For example, suppose a task's back stack consists of root activity A with activities B, C, 326 and D on top (the stack is A-B-C-D; D is on top). An intent arrives for an activity of type D. 327 If D has the default {@code "standard"} launch mode, a new instance of the class is launched and the 328 stack becomes A-B-C-D-D. However, if D's launch mode is {@code "singleTop"}, the existing instance 329 of D receives the intent through {@link 330 android.app.Activity#onNewIntent onNewIntent()}, because it's at the top of the stack—the 331 stack remains A-B-C-D. However, if an intent arrives for an activity of type B, then a new 332 instance of B is added to the stack, even if its launch mode is {@code "singleTop"}.</p> 333 <p class="note"><strong>Note:</strong> When a new instance of an activity is created, 334 the user can press the <em>Back</em> button to return to the previous activity. But when an existing 335 instance of 336 an activity handles a new intent, the user cannot press the <em>Back</em> button to return to the 337 state of 338 the activity before the new intent arrived in {@link android.app.Activity#onNewIntent 339 onNewIntent()}.</p> 340 </dd> 341 342 <dt>{@code "singleTask"}</dt> 343 <dd>The system creates a new task and instantiates the activity at the root of the new task. 344 However, if an instance of the activity already exists in a separate task, the system routes the 345 intent to the existing instance through a call to its {@link 346 android.app.Activity#onNewIntent onNewIntent()} method, rather than creating a new instance. Only 347 one instance of the activity can exist at a time. 348 <p class="note"><strong>Note:</strong> Although the activity starts in a new task, the 349 <em>Back</em> button still returns the user to the previous activity.</p></dd> 350 <dt>{@code "singleInstance"}.</dt> 351 <dd>Same as {@code "singleTask"}, except that the system doesn't launch any other activities into 352 the task holding the instance. The activity is always the single and only member of its task; 353 any activities started by this one open in a separate task.</dd> 354 </dl> 355 356 357 <p>As another example, the Android Browser application declares that the web browser activity should 358 always open in its own task—by specifying the {@code singleTask} launch mode in the <a 359 href="{@docRoot}guide/topics/manifest/activity-element.html">{@code <activity>}</a> element. 360 This means that if your application issues an 361 intent to open the Android Browser, its activity is <em>not</em> placed in the same 362 task as your application. Instead, either a new task starts for the Browser or, if the Browser 363 already has a task running in the background, that task is brought forward to handle the new 364 intent.</p> 365 366 <p>Regardless of whether an activity starts in a new task or in the same task as the activity that 367 started it, the <em>Back</em> button always takes the user to the previous activity. However, if you 368 start an activity that specifies the {@code singleTask} launch mode, then if an instance of 369 that activity exists in a background task, that whole task is brought to the foreground. At this 370 point, the back stack now includes all activities from the task brought forward, at the top of the 371 stack. Figure 4 illustrates this type of scenario.</p> 372 373 <img src="{@docRoot}images/fundamentals/diagram_backstack_singletask_multiactivity.png" alt="" /> 374 <p class="img-caption"><strong>Figure 4.</strong> A representation of how an activity with 375 launch mode "singleTask" is added to the back stack. If the activity is already a part of a 376 background task with its own back stack, then the entire back stack also comes 377 forward, on top of the current task.</p> 378 379 <p>For more information about using launch modes in the manifest file, see the 380 <code><a href="{@docRoot}guide/topics/manifest/activity-element.html"><activity></a></code> 381 element documentation, where the {@code launchMode} attribute and the accepted values are 382 discussed more.</p> 383 384 <p class="note"><strong>Note:</strong> The behaviors that you specify for your activity with the <a 385 href="{@docRoot}guide/topics/manifest/activity-element.html#lmode">{@code launchMode}</a> attribute 386 can be overridden by flags included with the intent that start your activity, as discussed in the 387 next section.</p> 388 389 390 391 <h4 id="#IntentFlagsForTasks">Using Intent flags</h4> 392 393 <p>When starting an activity, you can modify the default association of an activity to its task 394 by including flags in the intent that you deliver to {@link 395 android.app.Activity#startActivity startActivity()}. The flags you can use to modify the 396 default behavior are:</p> 397 398 <p> 399 <dt>{@link android.content.Intent#FLAG_ACTIVITY_NEW_TASK}</dt> 400 <dd>Start the activity in a new task. If a task is already running for the activity you are now 401 starting, that task is brought to the foreground with its last state restored and the activity 402 receives the new intent in {@link android.app.Activity#onNewIntent onNewIntent()}. 403 <p>This produces the same behavior as the {@code "singleTask"} <a 404 href="{@docRoot}guide/topics/manifest/activity-element.html#lmode">{@code launchMode}</a> value, 405 discussed in the previous section.</p></dd> 406 <dt>{@link android.content.Intent#FLAG_ACTIVITY_SINGLE_TOP}</dt> 407 <dd>If the activity being started is the current activity (at the top of the back stack), then 408 the existing instance receives a call to {@link android.app.Activity#onNewIntent onNewIntent()}, 409 instead of creating a new instance of the activity. 410 <p>This produces the same behavior as the {@code "singleTop"} <a 411 href="{@docRoot}guide/topics/manifest/activity-element.html#lmode">{@code launchMode}</a> value, 412 discussed in the previous section.</p></dd> 413 <dt>{@link android.content.Intent#FLAG_ACTIVITY_CLEAR_TOP}</dt> 414 <dd>If the activity being started is already running in the current task, then instead 415 of launching a new instance of that activity, all of the other activities on top of it are 416 destroyed and this intent is delivered to the resumed instance of the activity (now on top), 417 through {@link android.app.Activity#onNewIntent onNewIntent()}). 418 <p>There is no value for the <a 419 href="{@docRoot}guide/topics/manifest/activity-element.html#lmode">{@code launchMode}</a> 420 attribute that produces this behavior.</p> 421 <p>{@code FLAG_ACTIVITY_CLEAR_TOP} is most often used in conjunction with {@code 422 FLAG_ACTIVITY_NEW_TASK}. When used together, these flags are a way of locating an existing activity 423 in another task and putting it in a position where it can respond to the intent. </p> 424 <p class="note"><strong>Note:</strong> If the launch mode of the designated activity is {@code 425 "standard"}, it too is removed from the stack and a new instance is launched in its place to handle 426 the incoming intent. That's because a new instance is always created for a new intent when the 427 launch mode is {@code "standard"}. </p> 428 </dd> 429 </dl> 430 431 432 433 434 435 <h3 id="Affinities">Handling affinities</h3> 436 437 <p>The <em>affinity</em> indicates which task an activity prefers to belong to. By default, all the 438 activities from the same application have an affinity for each other. So, by default, all 439 activities in the same application prefer to be in the same task. However, you can modify 440 the default affinity for an activity. Activities defined in 441 different applications can share an affinity, or activities defined in the same application can be 442 assigned different task affinities.</p> 443 444 <p>You can modify the affinity for any given activity with the <a 445 href="{@docRoot}guide/topics/manifest/activity-element.html#aff">{@code taskAffinity}</a> attribute 446 of the <a href="{@docRoot}guide/topics/manifest/activity-element.html">{@code <activity>}</a> 447 element.</p> 448 449 <p>The <a 450 href="{@docRoot}guide/topics/manifest/activity-element.html#aff">{@code taskAffinity}</a> 451 attribute takes a string value, which must be unique from the default package name 452 declared in the <a href="{@docRoot}guide/topics/manifest/manifest-element.html">{@code 453 <manifest>}</a> element, because the system uses that name to identify the default task 454 affinity for the application.</p> 455 456 <p>The affinity comes into play in two circumstances:</p> 457 <ul> 458 <li>When the intent that launches an activity contains the {@link 459 android.content.Intent#FLAG_ACTIVITY_NEW_TASK} flag. 460 461 <p>A new activity is, by default, launched into the task of the activity 462 that called {@link android.app.Activity#startActivity startActivity()}. It's pushed onto the same 463 back stack as the caller. However, if the intent passed to {@link 464 android.app.Activity#startActivity startActivity()} contains the {@link 465 android.content.Intent#FLAG_ACTIVITY_NEW_TASK} 466 flag, the system looks for a different task to house the new activity. Often, it's a new task. 467 However, it doesn't have to be. If there's already an existing task with the same affinity as the 468 new activity, the activity is launched into that task. If not, it begins a new task.</p> 469 470 <p>If this flag causes an activity to begin a new task and the user presses the <em>Home</em> button 471 to leave 472 it, there must be some way for the user to navigate back to the task. Some entities (such as the 473 notification manager) always start activities in an external task, never as part of their own, so 474 they always put {@code FLAG_ACTIVITY_NEW_TASK} in the intents they pass to {@link 475 android.app.Activity#startActivity startActivity()}. If you have an activity that can be invoked by 476 an external entity that might use this flag, take care that the user has a independent way to get 477 back to the task that's started, such as with a launcher icon (the root activity of the task 478 has a {@link android.content.Intent#CATEGORY_LAUNCHER} intent filter; see the <a 479 href="#Starting">Starting a task</a> section below).</p> 480 </li> 481 482 <li>When an activity has its <a 483 href="{@docRoot}guide/topics/manifest/activity-element.html#reparent">{@code 484 allowTaskReparenting}</a> attribute set to {@code "true"}. 485 <p>In this case, the activity can move from the task it starts to the task it has an affinity 486 for, when that task comes to the foreground.</p> 487 <p>For example, suppose that an activity that reports weather conditions in selected cities is 488 defined as part of a travel application. It has the same affinity as other activities in the same 489 application (the default application affinity) and it allows re-parenting with this attribute. 490 When one of your activities starts the weather reporter activity, it initially belongs to the same 491 task as your activity. However, when the travel application's task comes to the foreground, the 492 weather reporter activity is reassigned to that task and displayed within it.</p> 493 </li> 494 </ul> 495 496 <p class="note"><strong>Tip:</strong> If an {@code .apk} file contains more than one "application" 497 from the user's point of view, you probably want to use the <a 498 href="{@docRoot}guide/topics/manifest/activity-element.html#aff">{@code taskAffinity}</a> 499 attribute to assign different affinities to the activities associated with each "application".</p> 500 501 502 503 <h3 id="Clearing">Clearing the back stack</h3> 504 505 <p>If the user leaves a task for a long time, the system clears the task of all activities except 506 the root activity. When the user returns to the task again, only the root activity is restored. 507 The system behaves this way, because, after an extended amount of time, users likely have abandoned 508 what they were doing before and are returning to the task to begin something new. </p> 509 510 <p>There are some activity attributes that you can use to modify this behavior: </p> 511 512 <dl> 513 <dt><code><a 514 href="{@docRoot}guide/topics/manifest/activity-element.html#always">alwaysRetainTaskState</a></code> 515 </dt> 516 <dd>If this attribute is set to {@code "true"} in the root activity of a task, 517 the default behavior just described does not happen. 518 The task retains all activities in its stack even after a long period.</dd> 519 520 <dt><code><a 521 href="{@docRoot}guide/topics/manifest/activity-element.html#clear">clearTaskOnLaunch</a></code></dt> 522 <dd>If this attribute is set to {@code "true"} in the root activity of a task, 523 the stack is cleared down to the root activity whenever the user leaves the task 524 and returns to it. In other words, it's the opposite of <a 525 href="{@docRoot}guide/topics/manifest/activity-element.html#always">{@code 526 alwaysRetainTaskState}</a>. The user always returns to the task in its 527 initial state, even after a leaving the task for only a moment.</dd> 528 529 <dt><code><a 530 href="{@docRoot}guide/topics/manifest/activity-element.html#finish">finishOnTaskLaunch</a></code> 531 </dt> 532 <dd>This attribute is like <a 533 href="{@docRoot}guide/topics/manifest/activity-element.html#clear">{@code clearTaskOnLaunch}</a>, 534 but it operates on a 535 single activity, not an entire task. It can also cause any activity to go 536 away, including the root activity. When it's set to {@code "true"}, the 537 activity remains part of the task only for the current session. If the user 538 leaves and then returns to the task, it is no longer present.</dd> 539 </dl> 540 541 542 543 544 <h3 id="Starting">Starting a task</h3> 545 546 <p>You can set up an activity as the entry point for a task by giving it an intent filter with 547 {@code "android.intent.action.MAIN"} as the specified action and {@code 548 "android.intent.category.LAUNCHER"} as the specified category. For example:</p> 549 550 <pre> 551 <activity ... > 552 <intent-filter ... > 553 <action android:name="android.intent.action.MAIN" /> 554 <category android:name="android.intent.category.LAUNCHER" /> 555 </intent-filter> 556 ... 557 </activity> 558 </pre> 559 560 <p>An intent filter of this kind causes an icon and label for the 561 activity to be displayed in the application launcher, giving users a way to launch the activity and 562 to return to the task that it creates any time after it has been launched. 563 </p> 564 565 <p>This second ability is important: Users must be able to leave a task and then come back to it 566 later using this activity launcher. For this reason, the two <a href="#LaunchModes">launch 567 modes</a> that mark activities as always initiating a task, {@code "singleTask"} and "{@code 568 "singleInstance"}, should be used only when the activity has an {@link 569 android.content.Intent#ACTION_MAIN} 570 and a {@link android.content.Intent#CATEGORY_LAUNCHER} 571 filter. Imagine, for example, what could happen if the filter is missing: An intent launches a 572 {@code "singleTask"} activity, initiating a new task, and the user spends some time working in 573 that task. The user then presses the <em>Home</em> button. The task is now sent to the background 574 and is 575 not visible. Now the user has no way to return to the task, because it is not represented in the 576 application launcher. 577 </p> 578 579 <p>For those cases where you don't want the user to be able to return to an activity, set the 580 <code><a 581 href="{@docRoot}guide/topics/manifest/activity-element.html"><activity></a></code> element's 582 <a href="{@docRoot}guide/topics/manifest/activity-element.html#finish">{@code 583 finishOnTaskLaunch}</a> to {@code "true"} (see <a 584 href="#Clearing">Clearing the stack</a>).</p> 585 586 587 588 <!-- 589 <h2>Beginner's Path</h2> 590 591 <p>For more information about how to use intents to 592 activate other application components and publish the intents to which your components 593 respond, continue with the <b><a 594 href="{@docRoot}guide/topics/intents/intents-filters.html">Intents and Intent 595 Filters</a></b> document.</p> 596 --> 597