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?
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