您的位置:首页 > 移动开发 > Android开发

onNewIntent调用时机 (ANDROID)

2014-02-27 13:58 405 查看
在IntentActivity中重写下列方法:onCreate onStart onRestart onResume onPause onStop onDestroy onNewIntent

一、其他应用发Intent,执行下列方法:

I/@@@philn(12410):
onCreate

I/@@@philn(12410):
onStart

I/@@@philn(12410):
onResume

发Intent的方法:

Uri uri = Uri.parse("philn://blog.163.com");

Intent it = new Intent(Intent.ACTION_VIEW, uri);

startActivity(it);


二、接收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>


三、如果IntentActivity处于任务栈的顶端,也就是说之前打开过的Activity,现在处于

I/@@@philn(12410):
onPause

I/@@@philn(12410):
onStop 状态的话

其他应用再发送Intent的话,执行顺序为:

I/@@@philn(12410):
onNewIntent

I/@@@philn(12410):
onRestart

I/@@@philn(12410):
onStart

I/@@@philn(12410):
onResume


在Android应用程序开发的时候,从一个Activity启动另一个Activity并传递一些数据到新的Activity上非常简单,但是当您需要让后台运行的Activity回到前台并传递一些数据可能就会存在一点点小问题。

首先,在默认情况下,当您通过Intent启到一个Activity的时候,就算已经存在一个相同的正在运行的Activity,系统都会创建一个新的Activity实例并显示出来。为了不让Activity实例化多次,我们需要通过在AndroidManifest.xml配置activity的加载方式(launchMode)以实现单任务模式,如下所示:

1 <activity android:label="@string/app_name" android:launchmode="singleTask"android:name="Activity1">


2 </activity>


launchMode为singleTask的时候,通过Intent启到一个Activity,如果系统已经存在一个实例,系统就会将请求发送到这个实例上,但这个时候,系统就不会再调用通常情况下我们处理请求数据的onCreate方法,而是调用onNewIntent方法,如下所示:

1 protected void onNewIntent(Intent intent) {


2 super.onNewIntent(intent);


3 setIntent(intent);//must store the new intent unless getIntent() will return the old one


4 processExtraData();


5 }


不要忘记,系统可能会随时杀掉后台运行的Activity,如果这一切发生,那么系统就会调用onCreate方法,而不调用onNewIntent方法,一个好的解决方法就是在onCreate和onNewIntent方法中调用同一个处理数据的方法,如下所示:

01 public void onCreate(Bundle savedInstanceState) {


02 super.onCreate(savedInstanceState);


03 setContentView(R.layout.main);


04 processExtraData();


05 }


06


07 protected void onNewIntent(Intent intent) {


08 super.onNewIntent(intent);


09 setIntent(intent);//must store the new intent unless getIntent() will return the old one


10 processExtraData()


11 }


12


13 private void processExtraData(){


14 Intent intent = getIntent();


15 //use the data received here


16 }


一、onNewIntent(Intent intent)方法

该方法是activity的一个保护类型的方法,利用已有的Acivity去处理别的Intent时,你就可以利用onNewIntent来处理,通常被用在有搜索请求的activity,而其该activity有好几个intent-filter,该方法被调用的前提

a、该activity设置如下属性 android:launchMode="singleTop"。

b、该activity已经处在栈的顶端,通过其他的方法又重新启动该acitvity时被调用,如搜索,这时oncreate()方法不调用。

在这个例子中onNewIntent(Intent intent) 用来处理所有的Intent,在oncreate()方法中也认为调用了onNewIntent(getIntent());

[java] view
plaincopy

public void onNewIntent(Intent intent) {

final String action = intent.getAction();

if (Intent.ACTION_SEARCH.equals(action)) {

// Start query for incoming search request

String query = intent.getStringExtra(SearchManager.QUERY);

startNavigating(query, true);

} else if (Intent.ACTION_VIEW.equals(action)) {

// Treat as internal link only if valid Uri and host matches

Uri data = intent.getData();

if (data != null && ExtendedWikiHelper.WIKI_LOOKUP_HOST

.equals(data.getHost())) {

String query = data.getPathSegments().get(0);

startNavigating(query, true);

}

} else {

// If not recognized, then start showing random word

startNavigating(null, true);

}

}

二、URI数据匹配

一个 Intent 可以通过 URI 携带外部数据给目标组件。在 <intent-filter >节点中,通过 <data/>节点匹配外部数据。

mimeType 属性指定携带外部数据的数据类型,scheme 指定协议,host、port、path 指定数据的位置、端口、和路径。如下:

[java] view
plaincopy

<data android:mimeType="mimeType" android:scheme="scheme"

android:host="host" android:port="port" android:path="path"/>

如果在 Intent Filter 中指定了这些属性,那么只有所有的属性都匹配成功时 URI 数据匹配才会成功。

该例子中通过String.format("<a href=/"%s://%s/$1/">$1</a>", WIKI_AUTHORITY, WIKI_LOOKUP_HOST)));把链接格式化成<a href="wiktionary://lookup/ah">ah</a>形式的,这样就可以和配置文件中的data相匹配。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: