1. 程式人生 > >activity--常見屬性總結

activity--常見屬性總結

系統 category edi pub task 配置 問題 tor text

15.Activit的幾個重要屬性總結?

12.onNewIntent()使用Tips?
11.launchMode的屬性介紹?及其常用的Intent Flag?

====

15.Activit的幾個重要屬性總結?
1.Activity的affinity(親和力)
2.Intent幾種常見的flags
3.<activity>與task相關屬性

launchMode:
taskAffinity:
Activity的task相關屬性?
allowTaskReparenting:
alwaysRetainTaskState:
clearTaskOnLaunch:
finishOnTaskLaunch:
documentLaunchMode:


12.onNewIntent()使用Tips?

1. 方法體中需手動調用setIntent(intent),否則之後的getIntent()獲取的都是舊的intent對象;
2. 被onNewIntent方式打開的activity,對生命周期的影響.
1. 之前activity是resume狀態,onNewIntent()後只會調用onResume()方法
2. 否則按照 `onNewIntent->onRestart->onStart->onResume->.


在IntentActivity中重寫下列方法:onCreate onStart onRestart onResume onPause onStop onDestroy onNewIntent
1、其他應用發Intent,執行下列方法:
onCreate
onStart
onResume

2、接收Intent聲明:

<activity android:name=".IntentActivity" android:launchMode="singleTask"
  android:label="@string/testname">
  <intent-filter>
  <action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
<data android:scheme="philn"/>
  </intent-filter>
</activity>

3、如果IntentActivity處於任務棧的頂端,也就是說之前打開過的Activity,現在處於onPause、onStop狀態的話,其他應用再發送Intent的話,執行順序為:
onNewIntent,onRestart,onStart,onResume。

在Android應用程序開發的時候,從一個Activity啟動另一個Activity並傳遞一些數據到新的Activity上非常簡單,但是當您需要讓後臺運行的Activity回到前臺並傳遞一些數據可能就會存在一點點小問題。

首先,在默認情況下,當您通過Intent啟到一個Activity的時候,就算已經存在一個相同的正在運行的Activity,系統都會創建一個新的Activity實例並顯示出來。為了不讓Activity實例化多次,我們需要通過在AndroidManifest.xml配置activity的加載方式(launchMode)以實現單任務模式,如下所示:

<activity android:label="@string/app_name" android:launchmode="singleTask"android:name="Activity1"></activity>
launchMode為singleTask的時候,通過Intent啟到一個Activity,如果系統已經存在一個實例,系統就會將請求發送到這個實例上,但這個時候,系統就不會再調用通常情況下我們處理請求數據的onCreate方法,而是調用onNewIntent方法,如下所示:

protected void onNewIntent(Intent intent) {
super.onNewIntent(intent);
setIntent(intent);//must store the new intent unless getIntent() will return the old one
processExtraData();
}

不要忘記,系統可能會隨時殺掉後臺運行的 Activity ,如果這一切發生,那麽系統就會調用 onCreate 方法,而不調用 onNewIntent 方法,一個好的解決方法就是在 onCreate 和 onNewIntent 方法中調用同一個處理數據的方法,如下所示:

public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
processExtraData();
}
protected void onNewIntent(Intent intent) {
super.onNewIntent(intent);
setIntent(intent);
processExtraData()
}
private void processExtraData(){
Intent intent = getIntent();
//use the data received here
}

二、onNewIntent()的setIntent()和getIntent()
@Override
protected void onNewIntent(Intent intent) {
super.onNewIntent(intent);
// setIntent(intent);
int data = getIntent().getIntExtra("HAHA", 0);
// int data = intent.getIntExtra("HAHA", 0);
}

如果沒有調用setIntent(intent),則getIntent()獲取的數據將不是你所期望的。但是使用intent.getInXxx,貌似可以獲得正確的結果。

註意這句話:
Note that getIntent() still returns the original Intent. You can use setIntent(Intent) to update it to this new Intent.
所以最好是調用setIntent(intent),這樣在使用getIntent()的時候就不會有問題了。


11.launchMode的屬性介紹?及其常用的Intent Flag?


什麽是Activity的啟動模式(LaunchMode)
啟動模式簡單地說就是Activity啟動時的策略,在AndroidManifest.xml中的標簽的android:launchMode屬性設置
啟動模式有4種,分別為standard、singleTop、singleTask、singleInstance;這四種模式影響了Activity所在的任務棧.

 Intent.setFlag(int flags)方法傳遞的一個整形的數據,被Android系統設置為了常量:
FLAG_ACTIVITY_NEW_TASK:這個標識會使新啟動的Activity獨立創建一個Task。
FLAG_ACTIVITY_CLEAR_TOP:這個標識會使新啟動的Activity檢查是否存在於Task中,如果存在則清除其之上的Activity,使它獲得焦點,並不重新實例化一個Activity,一般結合FLAG_ACTIVITY_NEW_TASK一起使用。
FLAG_ACTIVITY_SINGLE_TOP:等同於在LauncherMode屬性設置為singleTop。

activity--常見屬性總結