No puedo explicar lo que está sucediendo en su código, pero tengo una muestra de proyectos para hacer esto ..
a FooActivity con solo un botón 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);
}
});
}
y un BarActivity añadido en el AndroidManifest.xml así:
<activity
android:name = "BarActivity">
<intent-filter>
<action
android:name = "xper.activity.ACTIVITY_BAR_INTENT"/>
<category
android:name = "android.intent.category.DEFAULT"/>
</intent-filter>
</activity>
El código respectivo para recuperar la intención dentro de la barra está en la onClicEvent de la btnBar (botón):
@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();
}
});
}
Ahora, si no maneja bien el evento onActivityResult(), cuando presiona el botón "ATRÁS" de Android, puede obtener errores.
Si la intención (intención) en la actividad B es dar información a la actividad A, si presiona el botón hacia atrás, no sé si la actividad B estará en la pila, pero la intención no es hecho. Así que hice lo siguiente:
@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();
}
Manejo de la información que hice lo siguiente en el evento onActivityResult() para ver la información recuperada en la Barra de Actividad:
@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);
}
}
si tiene más actividades para volver infomación a la actividad de los padres es buena pratices haga lo siguiente:
//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;
}
}
Si no se puede hacer este código de ejemplo .. por favor, dame tu e-mail para mí envía el proyecto FooBarActivity
Duplicado de http://stackoverflow.com/questions/2679250/setresult-does-not-work-when-back-button-pressed – pjv