nie mogę wyjaśnić, co dzieje się w kodzie, ale mam próbkę projektu to zrobić ..
a FooActivity za pomocą przycisku btnFoo:
@Override
protected void onStart() {
super.onStart();
btnFoo.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
startActivityForResult(new Intent("xper.activity.ACTIVITY_BAR_INTENT"),1);
}
});
}
i BarActivity dodany w AndroidManifest.xml tak:
<activity
android:name = "BarActivity">
<intent-filter>
<action
android:name = "xper.activity.ACTIVITY_BAR_INTENT"/>
<category
android:name = "android.intent.category.DEFAULT"/>
</intent-filter>
</activity>
odpowiedni kod, aby pobrać intencję wewnątrz bar jest w onClicEvent z btnBar (przycisk):
@Override
protected void onStart() {
super.onStart();
btnBar.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent intent = new Intent("xper.activity.ACTIVITY_BAR_RESULT_INTENT");
intent.putExtra("codBar", "bar");
setResult(Activity.RESULT_OK, intent);
finish();
}
});
}
Teraz, jeśli nie radzisz sobie dobrze z zdarzeniem onActivityResult(), po naciśnięciu przycisku "WSTECZ" w systemie Android możesz uzyskać błędy.
Jeśli intencją (intencją) w działaniu B jest przekazanie pewnych informacji do działania A, to po naciśnięciu przycisku nie wiem, czy aktywność B będzie w stosie, ale intencja nie jest nie gotowe. Więc zrobiłem następujące:
@Override
public void onBackPressed() {
// TODO Auto-generated method stub
super.onBackPressed();
//Intent intent = new Intent("xper.activity.ACTIVITY_BAR_RESULT_INTENT");
//intent.putExtra("codBar", "bar");
//setResult(Activity.RESULT_CANCELED, intent);
setResult(Activity.RESULT_CANCELED);
finish();
}
Obchodzenie się z informacjami zrobiłem następujące w przypadku onActivityResult(), aby zobaczyć pobrane informacje w działalności bar:
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if(data != null) {
Toast.makeText(this, "BAR\trequestCode == " + requestCode + "\tresultCode == " + resultCode + "\tdata == " + data, 10000).show();
btnFoo.setText("BAR\trequestCode == " + requestCode + "\tresultCode == " + resultCode + "\tdata == " + data /*+ "extras == " + data.getExtras().getString("codBar")*/);
} else {
Toast.makeText(this, "BAR\trequestCode == " + requestCode + "\tresultCode == " + resultCode, 10000).show();
btnFoo.setText("BAR\trequestCode == " + requestCode + "\tresultCode == " + resultCode);
}
}
jeśli masz więcej działań, aby powrócić Informacje na temat aktywności rodzica są dobre:
//put private static final int globals atributes with the respective name of the
//activity to represent the requestCode for each activity you have like:
private static final int ACTIVITY1 = 117;
private static final int ACTIVITY2 = 118;
...
private static final int ACTIVITYN = 215;
//In the event onActivityResult() is better use the switch statement to handle each
//specific activity to catch information
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if(resultCode == Activity.RESULT_CANCELED) return; // breaks
//if you decide to handle some information of Activity.RESULT_CANCELED
//ignore the above condition that returns and handle it inside the switch statement
switch(requestCode) {
case ACTIVITY1:
{
//Dosomething
} break;
case ACTIVITY2:
{
//Dosomething
} break;
...
case ACTIVITYN:
{
//Dosomething
} break;
}
}
Jeśli nie możesz wykonać tego przykładowego kodu .. proszę dać mi swój e-mail do mnie wysłać projekt FooBarActivity
Duplikat http://stackoverflow.com/questions/2679250/setresult-does-not-work-when-back-button-pressed – pjv