如何将数据从 Activity 传递到 DialogFragment
How to pass data from Activity to DialogFragment
我知道有一些关于如何将数据从 activity 传递到对话框(即 Bundle 或 Intent)的示例。但是,我尝试过的一切都不起作用。我不断收到 NPE 和 "Unable to find explicit activity class"
错误。即使我用对话框构建一个 superbasic activity 它也不起作用。我必须在代码中输入什么才能使其工作?
主要活动:
public class MainActivity extends AppCompatActivity {
Button button;
String textIWantToSee;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
button = (Button) findViewById(R.id.button);
textIWantToSee = "If this is the text I want to pass form this activity to the Fragment";
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
}
});
}
}
对话:
public class Dialog extends DialogFragment {
TextView textView;
@Override
public android.app.Dialog onCreateDialog(Bundle savedInstanceState) {
LayoutInflater inflater = getActivity().getLayoutInflater();
View v = inflater.inflate(R.layout.dialog_layout, null);
textView = (TextView) v.findViewById(R.id.textView);
AlertDialog.Builder builder = new AlertDialog.Builder(getActivity());
builder.setView(v);
return builder.create();
}
}
更新
主要活动:
public class MainActivity extends AppCompatActivity {
TextView tvIntent;
Button button;
String textIWantToSee;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
tvIntent = (TextView) findViewById(R.id.tvIntent);
button = (Button) findViewById(R.id.button);
textIWantToSee = "If this is the text I want to pass form this activity to the Fragment";
tvIntent.setText(textIWantToSee);
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
String intent = String.valueOf(tvIntent);
Intent intentToDialog = new Intent(MainActivity.this, Dialog.class);
intentToDialog.putExtra("keyForIntent", intent);
startActivity(intentToDialog); //Here is the exception
}
});
}
}
对话:
public class Dialog extends DialogFragment {
TextView textView;
String intent;
@Override
public android.app.Dialog onCreateDialog(Bundle savedInstanceState) {
LayoutInflater inflater = getActivity().getLayoutInflater();
View v = inflater.inflate(R.layout.dialog_layout, null);
textView = (TextView) v.findViewById(R.id.textView);
Intent intentFromDialog = new Intent(getActivity().getApplicationContext(),MainActivity.class);
intent = intentFromDialog.getStringExtra("keyForIntent");
textView.setText(intent);
AlertDialog.Builder builder = new AlertDialog.Builder(getActivity());
builder.setView(v);
return builder.create();
}
}
E/AndroidRuntime: FATAL EXCEPTION: main
Process: nl.blogvandetoekomst.passdatafromactivitytodialog, PID: 2947
android.content.ActivityNotFoundException: Unable to find explicit activity class {nl.blogvandetoekomst.passdatafromactivitytodialog/nl.blogvandetoekomst.passdatafromactivitytodialog.Dialog}; have you declared this activity in your AndroidManifest.xml?
at android.app.Instrumentation.checkStartActivityResult(Instrumentation.java:1794)
at android.app.Instrumentation.execStartActivity(Instrumentation.java:1512)
at android.app.Activity.startActivityForResult(Activity.java:3917)
at android.app.Activity.startActivityForResult(Activity.java:3877)
at android.support.v4.app.FragmentActivity.startActivityForResult(FragmentActivity.java:842)
at android.app.Activity.startActivity(Activity.java:4200)
at android.app.Activity.startActivity(Activity.java:4168)
at nl.blogvandetoekomst.passdatafromactivitytodialog.MainActivity.onClick(MainActivity.java:36)
at android.view.View.performClick(View.java:5198)
at android.view.View$PerformClick.run(View.java:21147)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5417)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
清单:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="nl.blogvandetoekomst.passdatafromactivitytodialog">
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
您可以直接在 Activity 中创建对话框:
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
LayoutInflater inflater = MainActivity.this.getLayoutInflater();
View v = inflater.inflate(R.layout.dialog_layout, null);
TextView textView = (TextView) v.findViewById(R.id.textView);
textView.setText(textIWantToSee);
AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this);
builder.setView(v);
builder.show();
}
});
如果您使用的是支持库,则应使用 android.support。v4.app.DialogFragment 而不是 android.app.Dialog。另外,您能否 post 您用来显示对话框的代码部分?
那么你一定是在使用DialogFragment的框架版本,正如OBX指出的那样:
MainActivity.java
public class MainActivity extends AppCompatActivity {
Button button;
String textIWantToSee;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
button = (Button) findViewById(R.id.button);
textIWantToSee = "If this is the text I want to pass form this activity to the Fragment";
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Dialog dialogFragment = new Dialog();
Bundle bundle = new Bundle();
bundle.putString("TEXT",textIWantToSee);
dialogFragment.setArguments(bundle);
dialogFragment.show(getFragmentManager(),"Image Dialog");
}
});
}
}
Dialog.java
public class Dialog extends DialogFragment {
TextView textView;
@Override
public android.app.Dialog onCreateDialog(Bundle savedInstanceState) {
LayoutInflater inflater = getActivity().getLayoutInflater();
View v = inflater.inflate(R.layout.dialog_layout, null);
Bundle bundle = getArguments();
String imageLink = bundle.getString("TEXT","");
textView = (TextView) v.findViewById(R.id.textView);
AlertDialog.Builder builder = new AlertDialog.Builder(getActivity());
builder.setView(v);
return builder.create();
}
}
这种方式非常适合我。
已编辑:
当您在 onClick 中执行此操作时:
Intent intentToDialog = new Intent(MainActivity.this, Dialog.class);
intentToDialog.putExtra("keyForIntent", intent);
startActivity(intentToDialog); //Here is the exception
您没有启动 activity,Dialog.class 是一个扩展的 DialogFragment,您无法显示启动 Activity 的对话框。尝试我 post 编辑的最后一个代码。
这是将数据从 Activity
传递到 DialogFragment
的方式:
MainActivity.java
public class MainActivity extends AppCompatActivity {
Button button;
String textIWantToSee;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
button = (Button) findViewById(R.id.button);
textIWantToSee = "If this is the text I want to pass form this activity to the Fragment";
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Dialog dialogFragment = new Dialog();
Bundle bundle = new Bundle();
bundle.putString("TEXT",textIWantToSee);
dialogFragment.setArguments(bundle);
dialogFragment.show((MainActivity.this).getSupportFragmentManager(),"Image Dialog");
}
});
}
}
Dialog.java
public class Dialog extends DialogFragment {
TextView textView;
@Override
public android.app.Dialog onCreateDialog(Bundle savedInstanceState) {
LayoutInflater inflater = getActivity().getLayoutInflater();
View v = inflater.inflate(R.layout.dialog_layout, null);
Bundle bundle = getArguments();
String imageLink = bundle.getString("TEXT","");
textView = (TextView) v.findViewById(R.id.textView);
AlertDialog.Builder builder = new AlertDialog.Builder(getActivity());
builder.setView(v);
return builder.create();
}
}
您的对话片段需要托管 activity,它需要在 Activity 内膨胀。
要inflate/show MainActivity 中的 DialogFragment 使用:
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Bundle bundle = new Bundle(); //Bundle containing data you are passing to the dialog
bundle.putString("text", textIWantToSee);
Dialog dialog = new Dialog(); //Create a new Dialog
dialog.setArguments(bundle);
dialog.show(getSupportFragmentManager(), "MY_DIALOG_TAG"); //Inflate the dialog
}
});
使用对话框片段的新实例。
参考:https://developer.android.com/reference/android/app/DialogFragment.html
static MyDialogFragment newInstance(int num) {
MyDialogFragment f = new MyDialogFragment();
// Supply num input as an argument.
Bundle args = new Bundle();
args.putInt("num", num);
f.setArguments(args);
return f;
}
如果您使用的是 kotlin,请尝试在伴随对象中定义 newInstance
companion object {
fun newInstance(num: Int): MyDialogFragment{
val f = DimensionDialogFragment()
val args = Bundle()
args.putInt("num", num)
f.setArguments(args)
return f
}
}
我知道有一些关于如何将数据从 activity 传递到对话框(即 Bundle 或 Intent)的示例。但是,我尝试过的一切都不起作用。我不断收到 NPE 和 "Unable to find explicit activity class"
错误。即使我用对话框构建一个 superbasic activity 它也不起作用。我必须在代码中输入什么才能使其工作?
主要活动:
public class MainActivity extends AppCompatActivity {
Button button;
String textIWantToSee;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
button = (Button) findViewById(R.id.button);
textIWantToSee = "If this is the text I want to pass form this activity to the Fragment";
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
}
});
}
}
对话:
public class Dialog extends DialogFragment {
TextView textView;
@Override
public android.app.Dialog onCreateDialog(Bundle savedInstanceState) {
LayoutInflater inflater = getActivity().getLayoutInflater();
View v = inflater.inflate(R.layout.dialog_layout, null);
textView = (TextView) v.findViewById(R.id.textView);
AlertDialog.Builder builder = new AlertDialog.Builder(getActivity());
builder.setView(v);
return builder.create();
}
}
更新
主要活动:
public class MainActivity extends AppCompatActivity {
TextView tvIntent;
Button button;
String textIWantToSee;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
tvIntent = (TextView) findViewById(R.id.tvIntent);
button = (Button) findViewById(R.id.button);
textIWantToSee = "If this is the text I want to pass form this activity to the Fragment";
tvIntent.setText(textIWantToSee);
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
String intent = String.valueOf(tvIntent);
Intent intentToDialog = new Intent(MainActivity.this, Dialog.class);
intentToDialog.putExtra("keyForIntent", intent);
startActivity(intentToDialog); //Here is the exception
}
});
}
} 对话:
public class Dialog extends DialogFragment {
TextView textView;
String intent;
@Override
public android.app.Dialog onCreateDialog(Bundle savedInstanceState) {
LayoutInflater inflater = getActivity().getLayoutInflater();
View v = inflater.inflate(R.layout.dialog_layout, null);
textView = (TextView) v.findViewById(R.id.textView);
Intent intentFromDialog = new Intent(getActivity().getApplicationContext(),MainActivity.class);
intent = intentFromDialog.getStringExtra("keyForIntent");
textView.setText(intent);
AlertDialog.Builder builder = new AlertDialog.Builder(getActivity());
builder.setView(v);
return builder.create();
}
}
E/AndroidRuntime: FATAL EXCEPTION: main
Process: nl.blogvandetoekomst.passdatafromactivitytodialog, PID: 2947
android.content.ActivityNotFoundException: Unable to find explicit activity class {nl.blogvandetoekomst.passdatafromactivitytodialog/nl.blogvandetoekomst.passdatafromactivitytodialog.Dialog}; have you declared this activity in your AndroidManifest.xml?
at android.app.Instrumentation.checkStartActivityResult(Instrumentation.java:1794)
at android.app.Instrumentation.execStartActivity(Instrumentation.java:1512)
at android.app.Activity.startActivityForResult(Activity.java:3917)
at android.app.Activity.startActivityForResult(Activity.java:3877)
at android.support.v4.app.FragmentActivity.startActivityForResult(FragmentActivity.java:842)
at android.app.Activity.startActivity(Activity.java:4200)
at android.app.Activity.startActivity(Activity.java:4168)
at nl.blogvandetoekomst.passdatafromactivitytodialog.MainActivity.onClick(MainActivity.java:36)
at android.view.View.performClick(View.java:5198)
at android.view.View$PerformClick.run(View.java:21147)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5417)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
清单:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="nl.blogvandetoekomst.passdatafromactivitytodialog">
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
您可以直接在 Activity 中创建对话框:
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
LayoutInflater inflater = MainActivity.this.getLayoutInflater();
View v = inflater.inflate(R.layout.dialog_layout, null);
TextView textView = (TextView) v.findViewById(R.id.textView);
textView.setText(textIWantToSee);
AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this);
builder.setView(v);
builder.show();
}
});
如果您使用的是支持库,则应使用 android.support。v4.app.DialogFragment 而不是 android.app.Dialog。另外,您能否 post 您用来显示对话框的代码部分?
那么你一定是在使用DialogFragment的框架版本,正如OBX指出的那样:
MainActivity.java
public class MainActivity extends AppCompatActivity {
Button button;
String textIWantToSee;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
button = (Button) findViewById(R.id.button);
textIWantToSee = "If this is the text I want to pass form this activity to the Fragment";
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Dialog dialogFragment = new Dialog();
Bundle bundle = new Bundle();
bundle.putString("TEXT",textIWantToSee);
dialogFragment.setArguments(bundle);
dialogFragment.show(getFragmentManager(),"Image Dialog");
}
});
}
}
Dialog.java
public class Dialog extends DialogFragment {
TextView textView;
@Override
public android.app.Dialog onCreateDialog(Bundle savedInstanceState) {
LayoutInflater inflater = getActivity().getLayoutInflater();
View v = inflater.inflate(R.layout.dialog_layout, null);
Bundle bundle = getArguments();
String imageLink = bundle.getString("TEXT","");
textView = (TextView) v.findViewById(R.id.textView);
AlertDialog.Builder builder = new AlertDialog.Builder(getActivity());
builder.setView(v);
return builder.create();
}
}
这种方式非常适合我。
已编辑:
当您在 onClick 中执行此操作时:
Intent intentToDialog = new Intent(MainActivity.this, Dialog.class);
intentToDialog.putExtra("keyForIntent", intent);
startActivity(intentToDialog); //Here is the exception
您没有启动 activity,Dialog.class 是一个扩展的 DialogFragment,您无法显示启动 Activity 的对话框。尝试我 post 编辑的最后一个代码。
这是将数据从 Activity
传递到 DialogFragment
的方式:
MainActivity.java
public class MainActivity extends AppCompatActivity {
Button button;
String textIWantToSee;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
button = (Button) findViewById(R.id.button);
textIWantToSee = "If this is the text I want to pass form this activity to the Fragment";
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Dialog dialogFragment = new Dialog();
Bundle bundle = new Bundle();
bundle.putString("TEXT",textIWantToSee);
dialogFragment.setArguments(bundle);
dialogFragment.show((MainActivity.this).getSupportFragmentManager(),"Image Dialog");
}
});
}
}
Dialog.java
public class Dialog extends DialogFragment {
TextView textView;
@Override
public android.app.Dialog onCreateDialog(Bundle savedInstanceState) {
LayoutInflater inflater = getActivity().getLayoutInflater();
View v = inflater.inflate(R.layout.dialog_layout, null);
Bundle bundle = getArguments();
String imageLink = bundle.getString("TEXT","");
textView = (TextView) v.findViewById(R.id.textView);
AlertDialog.Builder builder = new AlertDialog.Builder(getActivity());
builder.setView(v);
return builder.create();
}
}
您的对话片段需要托管 activity,它需要在 Activity 内膨胀。
要inflate/show MainActivity 中的 DialogFragment 使用:
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Bundle bundle = new Bundle(); //Bundle containing data you are passing to the dialog
bundle.putString("text", textIWantToSee);
Dialog dialog = new Dialog(); //Create a new Dialog
dialog.setArguments(bundle);
dialog.show(getSupportFragmentManager(), "MY_DIALOG_TAG"); //Inflate the dialog
}
});
使用对话框片段的新实例。 参考:https://developer.android.com/reference/android/app/DialogFragment.html
static MyDialogFragment newInstance(int num) {
MyDialogFragment f = new MyDialogFragment();
// Supply num input as an argument.
Bundle args = new Bundle();
args.putInt("num", num);
f.setArguments(args);
return f;
}
如果您使用的是 kotlin,请尝试在伴随对象中定义 newInstance
companion object {
fun newInstance(num: Int): MyDialogFragment{
val f = DimensionDialogFragment()
val args = Bundle()
args.putInt("num", num)
f.setArguments(args)
return f
}
}