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