Search code examples
androidandroid-intentback-stack

Communication between Activities of the same stack


I want an Activity that accepts data at onCreate and returns data upn onDestroy; so I wrote up a small applet (are dex files still considered applets, or is literally everything named "app" now) to polish off the idea:

manifest snippet:

<application
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="app_label" >
    <activity
        android:name=".MainActivity"
        android:label="app_name" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
    <activity
        android:name=".ChildActivity"
        android:parentActivityName=".MainActivity" >
        <meta-data
            android:name="android.support.PARENT_ACTIVITY"
            android:value=".MainActivity" />
    </activity>
</application>

MainActivity.java:

package com.example.tests;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.LinearLayout;

public class MainActivity extends Activity {
    public static final String EXTRA_LABEL = "extra";
    private EditText text;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        LinearLayout layout = new LinearLayout(this);
        layout.setOrientation(LinearLayout.VERTICAL);
        text = new EditText(this);
        text.setText("initial value");
        Button button = new Button(this);
        button.setText("call");
        final MainActivity parent = this;
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Activity child = new ChildActivity();
                Intent intent = Intents.addStackActivity(parent, child);
                intent.putExtra(EXTRA_LABEL, text.getText().toString());
                startActivity(intent);
            }
        });
        layout.addView(button);
        layout.addView(text);
        this.setContentView(layout);
    }
    @Override public void onActivityResult(int requestCode, int resultCode, final Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
        if (requestCode == ChildActivity.EXTRA_LABEL_CODE) {
             if (resultCode == RESULT_OK) {
                 runOnUiThread(new Runnable() {
                     @Override public void run() {
                         text.setText(data.getStringExtra(ChildActivity.EXTRA_LABEL));
                     }
                 });
             }
        }
    }
}

Intents.java:

package com.example.tests;

import android.app.Activity;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.app.TaskStackBuilder;
import android.content.Context;
import android.content.Intent;
import android.support.v4.app.NotificationCompat;

public class Intents {
    public static Intent addStackActivity(Context parent, Activity activity) {
        int id = 1;

        Intent resultIntent = new Intent(parent, activity.getClass());
        TaskStackBuilder stackBuilder = TaskStackBuilder.create(parent);
        // Adds the back stack
        stackBuilder.addParentStack(activity.getClass());
        // Adds the Intent to the top of the stack
        stackBuilder.addNextIntent(resultIntent);
        // Gets a PendingIntent containing the entire back stack
        PendingIntent resultPendingIntent = stackBuilder.getPendingIntent(0,
                PendingIntent.FLAG_UPDATE_CURRENT);

        NotificationCompat.Builder builder = new NotificationCompat.Builder(
                parent);
        builder.setContentIntent(resultPendingIntent);
        NotificationManager mNotificationManager = (NotificationManager) parent
                .getSystemService(Context.NOTIFICATION_SERVICE);
        mNotificationManager.notify(id, builder.build());
        return resultIntent;
    }
}

ClientActivity.java:

package com.example.tests;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.LinearLayout;

public class ChildActivity extends Activity {
    public static final String EXTRA_LABEL = "mwahahaha";
    public static final int EXTRA_LABEL_CODE = 12345678;
    private EditText text;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        Intent intent = getIntent();
        String data = intent.getExtras().getString(MainActivity.EXTRA_LABEL);
        LinearLayout layout = new LinearLayout(this);
        layout.setOrientation(LinearLayout.VERTICAL);
        text = new EditText(this);
        text.setText(data);
        Button button = new Button(this);
        button.setText("return");
        button.setOnClickListener(new View.OnClickListener() {
            @Override public void onClick(View v) {
                finish();
            }
        });
        layout.addView(button);
        layout.addView(text);
        this.setContentView(layout);
        //setContentView(R.layout.activity_main);
    }
    private void setTextResult() {
        Intent intent = new Intent();
        intent.putExtra(ChildActivity.EXTRA_LABEL, text.getText().toString());
        this.setResult(ChildActivity.EXTRA_LABEL_CODE, intent);
    }
    @Override public void onDestroy() {
        setTextResult();
        super.onDestroy();
    }
}

The child activity is accepting the string just fine; but I am having difficulty obtaining a method of returning data to the parent. How is this done?


Solution

  • It's not entirely clear to me what you're trying to accomplish, but I suspect that you could replace a whole bunch of that custom code with "startActivityForResult".

    See http://developer.android.com/training/basics/intents/result.html