1*90c8c64dSAndroid Build Coastguard Worker /*
2*90c8c64dSAndroid Build Coastguard Worker  * Copyright (C) 2014 The Android Open Source Project
3*90c8c64dSAndroid Build Coastguard Worker  *
4*90c8c64dSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*90c8c64dSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*90c8c64dSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*90c8c64dSAndroid Build Coastguard Worker  *
8*90c8c64dSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*90c8c64dSAndroid Build Coastguard Worker  *
10*90c8c64dSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*90c8c64dSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*90c8c64dSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*90c8c64dSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*90c8c64dSAndroid Build Coastguard Worker  * limitations under the License.
15*90c8c64dSAndroid Build Coastguard Worker  */
16*90c8c64dSAndroid Build Coastguard Worker 
17*90c8c64dSAndroid Build Coastguard Worker package com.example.android.documentcentricapps;
18*90c8c64dSAndroid Build Coastguard Worker 
19*90c8c64dSAndroid Build Coastguard Worker import android.app.Activity;
20*90c8c64dSAndroid Build Coastguard Worker import android.content.Intent;
21*90c8c64dSAndroid Build Coastguard Worker import android.os.Bundle;
22*90c8c64dSAndroid Build Coastguard Worker import android.os.PersistableBundle;
23*90c8c64dSAndroid Build Coastguard Worker import android.util.Log;
24*90c8c64dSAndroid Build Coastguard Worker import android.view.View;
25*90c8c64dSAndroid Build Coastguard Worker import android.widget.CheckBox;
26*90c8c64dSAndroid Build Coastguard Worker 
27*90c8c64dSAndroid Build Coastguard Worker /**
28*90c8c64dSAndroid Build Coastguard Worker  * DocumentCentricActivity shows the basic usage of the new Document-Centric Apps API. The new
29*90c8c64dSAndroid Build Coastguard Worker  * API modifies the meaning of the {@link Intent#FLAG_ACTIVITY_CLEAR_WHEN_TASK_RESET} flag, which is
30*90c8c64dSAndroid Build Coastguard Worker  * now deprecated. In versions before L it serves to define a boundary between the main task and a
31*90c8c64dSAndroid Build Coastguard Worker  * subtask. The subtask holds a different thumbnail and all activities in it are finished when the
32*90c8c64dSAndroid Build Coastguard Worker  * task is reset. In L this flag causes a full break with the task that launched it. As such it has
33*90c8c64dSAndroid Build Coastguard Worker  * been renamed to {@link Intent#FLAG_ACTIVITY_NEW_DOCUMENT}.
34*90c8c64dSAndroid Build Coastguard Worker  *
35*90c8c64dSAndroid Build Coastguard Worker  * This sample mainly uses Intent flags in code. But Activities can also specify in their manifests
36*90c8c64dSAndroid Build Coastguard Worker  * that they shall always be launched into a new task in the above manner using the new activity
37*90c8c64dSAndroid Build Coastguard Worker  * attribute documentLaunchMode which may take on one of three values, “intoExisting” equivalent to
38*90c8c64dSAndroid Build Coastguard Worker  * NEW_DOCUMENT, “always” equivalent to NEW_DOCUMENT | MULTIPLE_TASK, “none” the default, and
39*90c8c64dSAndroid Build Coastguard Worker  * “never” which will negate the effect of any attempt to launch the activity with NEW_DOCUMENT.
40*90c8c64dSAndroid Build Coastguard Worker  */
41*90c8c64dSAndroid Build Coastguard Worker public class DocumentCentricActivity extends Activity {
42*90c8c64dSAndroid Build Coastguard Worker 
43*90c8c64dSAndroid Build Coastguard Worker     private final static String TAG = "DocumentCentricActivity";
44*90c8c64dSAndroid Build Coastguard Worker 
45*90c8c64dSAndroid Build Coastguard Worker     public final static String KEY_EXTRA_NEW_DOCUMENT_COUNTER = "KEY_EXTRA_NEW_DOCUMENT_COUNTER";
46*90c8c64dSAndroid Build Coastguard Worker 
47*90c8c64dSAndroid Build Coastguard Worker     private static int mDocumentCounter = 0;
48*90c8c64dSAndroid Build Coastguard Worker 
49*90c8c64dSAndroid Build Coastguard Worker     private CheckBox mCheckbox;
50*90c8c64dSAndroid Build Coastguard Worker 
51*90c8c64dSAndroid Build Coastguard Worker     @Override
onCreate(Bundle savedInstanceState)52*90c8c64dSAndroid Build Coastguard Worker     protected void onCreate(Bundle savedInstanceState) {
53*90c8c64dSAndroid Build Coastguard Worker         super.onCreate(savedInstanceState);
54*90c8c64dSAndroid Build Coastguard Worker         setContentView(R.layout.activity_document_centric_main);
55*90c8c64dSAndroid Build Coastguard Worker         mCheckbox = (CheckBox) findViewById(R.id.multiple_task_checkbox);
56*90c8c64dSAndroid Build Coastguard Worker     }
57*90c8c64dSAndroid Build Coastguard Worker 
58*90c8c64dSAndroid Build Coastguard Worker     @Override
onPostCreate(Bundle savedInstanceState, PersistableBundle persistentState)59*90c8c64dSAndroid Build Coastguard Worker     public void onPostCreate(Bundle savedInstanceState, PersistableBundle persistentState) {
60*90c8c64dSAndroid Build Coastguard Worker         super.onPostCreate(savedInstanceState, persistentState);
61*90c8c64dSAndroid Build Coastguard Worker         // Restore state from PersistableBundle
62*90c8c64dSAndroid Build Coastguard Worker         if (persistentState != null) {
63*90c8c64dSAndroid Build Coastguard Worker             mDocumentCounter = persistentState.getInt(KEY_EXTRA_NEW_DOCUMENT_COUNTER);
64*90c8c64dSAndroid Build Coastguard Worker         }
65*90c8c64dSAndroid Build Coastguard Worker     }
66*90c8c64dSAndroid Build Coastguard Worker 
67*90c8c64dSAndroid Build Coastguard Worker     @Override
onSaveInstanceState(Bundle outState, PersistableBundle outPersistentState)68*90c8c64dSAndroid Build Coastguard Worker     public void onSaveInstanceState(Bundle outState, PersistableBundle outPersistentState) {
69*90c8c64dSAndroid Build Coastguard Worker         /*
70*90c8c64dSAndroid Build Coastguard Worker         To maintain activity state across reboots the system saves and restore critical information for
71*90c8c64dSAndroid Build Coastguard Worker         all tasks and their activities. Information known by the system includes the activity stack order,
72*90c8c64dSAndroid Build Coastguard Worker         each task’s thumbnails and each activity’s and task's Intents. For Information that cannot be retained
73*90c8c64dSAndroid Build Coastguard Worker         because they contain Bundles which can’t be persisted a new constrained version of Bundle,
74*90c8c64dSAndroid Build Coastguard Worker         PersistableBundle is added. PersistableBundle can store only basic data types. To use it
75*90c8c64dSAndroid Build Coastguard Worker         in your Activities you must declare the new activity:persistableMode attribute in the manifest.
76*90c8c64dSAndroid Build Coastguard Worker          */
77*90c8c64dSAndroid Build Coastguard Worker         outPersistentState.putInt(KEY_EXTRA_NEW_DOCUMENT_COUNTER, mDocumentCounter);
78*90c8c64dSAndroid Build Coastguard Worker         super.onSaveInstanceState(outState, outPersistentState);
79*90c8c64dSAndroid Build Coastguard Worker     }
80*90c8c64dSAndroid Build Coastguard Worker 
createNewDocument(View view)81*90c8c64dSAndroid Build Coastguard Worker     public void createNewDocument(View view) {
82*90c8c64dSAndroid Build Coastguard Worker         boolean useMultipleTasks = mCheckbox.isChecked();
83*90c8c64dSAndroid Build Coastguard Worker         final Intent newDocumentIntent = newDocumentIntent();
84*90c8c64dSAndroid Build Coastguard Worker         if (useMultipleTasks) {
85*90c8c64dSAndroid Build Coastguard Worker             /*
86*90c8c64dSAndroid Build Coastguard Worker             When {@linkIntent#FLAG_ACTIVITY_NEW_DOCUMENT} is used with {@link Intent#FLAG_ACTIVITY_MULTIPLE_TASK}
87*90c8c64dSAndroid Build Coastguard Worker             the system will always create a new task with the target activity as the root. This allows the same
88*90c8c64dSAndroid Build Coastguard Worker             document to be opened in more than one task.
89*90c8c64dSAndroid Build Coastguard Worker              */
90*90c8c64dSAndroid Build Coastguard Worker             newDocumentIntent.addFlags(Intent.FLAG_ACTIVITY_MULTIPLE_TASK);
91*90c8c64dSAndroid Build Coastguard Worker         }
92*90c8c64dSAndroid Build Coastguard Worker         startActivity(newDocumentIntent);
93*90c8c64dSAndroid Build Coastguard Worker     }
94*90c8c64dSAndroid Build Coastguard Worker 
95*90c8c64dSAndroid Build Coastguard Worker 
96*90c8c64dSAndroid Build Coastguard Worker     /**
97*90c8c64dSAndroid Build Coastguard Worker      * Returns an new {@link Intent} to start {@link NewDocumentActivity} as a new document in
98*90c8c64dSAndroid Build Coastguard Worker      * overview menu.
99*90c8c64dSAndroid Build Coastguard Worker      *
100*90c8c64dSAndroid Build Coastguard Worker      * To start a new document task {@link Intent#FLAG_ACTIVITY_NEW_DOCUMENT} must be used. The
101*90c8c64dSAndroid Build Coastguard Worker      * system will search through existing tasks for one whose Intent matches the Intent component
102*90c8c64dSAndroid Build Coastguard Worker      * name and the Intent data. If it finds one then that task will be brought to the front and the
103*90c8c64dSAndroid Build Coastguard Worker      * new Intent will be passed to onNewIntent().
104*90c8c64dSAndroid Build Coastguard Worker      *
105*90c8c64dSAndroid Build Coastguard Worker      * Activities launched with the NEW_DOCUMENT flag must be created with launchMode="standard".
106*90c8c64dSAndroid Build Coastguard Worker      */
newDocumentIntent()107*90c8c64dSAndroid Build Coastguard Worker     private Intent newDocumentIntent() {
108*90c8c64dSAndroid Build Coastguard Worker         final Intent newDocumentIntent = new Intent(this, NewDocumentActivity.class);
109*90c8c64dSAndroid Build Coastguard Worker         newDocumentIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_DOCUMENT);
110*90c8c64dSAndroid Build Coastguard Worker         newDocumentIntent.putExtra(KEY_EXTRA_NEW_DOCUMENT_COUNTER, incrementAndGet());
111*90c8c64dSAndroid Build Coastguard Worker         return newDocumentIntent;
112*90c8c64dSAndroid Build Coastguard Worker     }
113*90c8c64dSAndroid Build Coastguard Worker 
incrementAndGet()114*90c8c64dSAndroid Build Coastguard Worker     private static int incrementAndGet() {
115*90c8c64dSAndroid Build Coastguard Worker         Log.d(TAG, "incrementAndGet(): " + mDocumentCounter);
116*90c8c64dSAndroid Build Coastguard Worker         return mDocumentCounter++;
117*90c8c64dSAndroid Build Coastguard Worker     }
118*90c8c64dSAndroid Build Coastguard Worker 
119*90c8c64dSAndroid Build Coastguard Worker }
120