startActivityForResult與startActivity的不同之處
startActivity( )
僅僅是跳轉到目標頁面,若是想跳回當前頁面,則必須再使用一次startActivity( )。
startActivityForResult( )
可以一次性完成這項任務,當程序執行到這段代碼的時候,假若從T1Activity跳轉到下一個Text2Activity,而當這個Text2Activity調用了finish()方法以後,程序會自動跳轉回T1Activity,並調用前一個T1Activity中的onActivityResult( )方法。
Code
跳轉的時候不是采用startActivity(intent) 這個方法,而是startActivityForResult(intent, 0)
Intent intent=new Intent();
intent.setClass(A.this, B.class);
Bundle bundle=new Bundle();
String str1="aaaaaa";
bundle.putString("str1", str1);
intent.putExtras(bundle);
startActivityForResult(intent, 0);//這裡采用startActivityForResult來做跳轉,此處的0為一個依據,可以寫其他的值,但一定要>=0
重寫onActivityResult方法,用來接收B回傳的數據。
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
switch (resultCode) { //resultCode為回傳的標記,我在B中回傳的是RESULT_OK
case RESULT_OK:
Bundle b=data.getExtras(); //data為B中回傳的Intent
String str=b.getString("str1");//str即為回傳的值
break;
default:
break;
}
}
在B中回傳數據時采用setResult方法,並且之後要調用finish方法。
setResult(RESULT_OK, intent); //intent為A傳來的帶有Bundle的intent,當然也可以自己定義新的Bundle
finish();//此處一定要調用finish()方法
setResult()
如果在startActivityForResult起來的Activity裡面設置setResult,結果並不會馬上返回給parent的Activity,只有當前Activity被finish,結果才會被發送給parent的onActivityResult去處理!
public final void setResult(int resultCode, Intent data) {
synchronized (this) {
mResultCode = resultCode;
mResultData = data;
}
}
public void finish() {
if (mParent == null) {
int resultCode;
Intent resultData;
synchronized (this) {
resultCode = mResultCode;
resultData = mResultData;
}
if (Config.LOGV) Log.v(TAG, "Finishing self: token=" + mToken);
try {
if (ActivityManagerNative.getDefault()
.finishActivity(mToken, resultCode, resultData)) {
mFinished = true;
}
} catch (RemoteException e) {
// Empty
}
} else {
mParent.finishFromChild(this);
}
}
這段代碼可以看出activity返回result是在被finish的時候,也就是說調用setResult()方法必須在finish()之前。那麼如果在如下方法中調用setResult()也有可能不會返回成功: onPause(), onStop(), onDestroy(),
因為這些方法調用不一定是在finish之前的,當然在onCreate()就調用setResult肯定是在finish之前的
按BACK鍵從一個Activity退出來的,一按BACK,android就會自動調用Activity的finish()方法,然後設置resultCode為RESULT_CANCELED,也就不會返回任何數據了 .
解決方法就是在Activity裡面捕獲按BACK的事件,捕獲到之後先setResult,然後自己來調用finish,就搞定了……把BACK事件直接自己給吞了
@Override
public void onBackPressed() {
Log.i(TAG, "onBackPressed");
setResult(Const.LIVE_OK);
super.onBackPressed();
}
我是天王蓋地虎的分割線