我用对话框制作了 DatePicker。当我从对话框中设置日期时,我的程序崩溃并说“不幸的是 prgram 已停止”。这是我的代码:
package com.example.reminder;
import java.util.Calendar;
import android.app.DatePickerDialog;
import android.app.Dialog;
import android.app.DialogFragment;
import android.os.Bundle;
import android.widget.DatePicker;
import android.widget.EditText;
import android.widget.TabHost;
import android.widget.TextView;
public class DatePickerFragment extends DialogFragment
implements DatePickerDialog.OnDateSetListener {
public EditText editText;
DatePicker dpResult;
public Dialog onCreateDialog(Bundle savedInstanceState) {
// Use the current date as the default date in the picker
final Calendar c = Calendar.getInstance();
int year = c.get(Calendar.YEAR);
int month = c.get(Calendar.MONTH);
int day = c.get(Calendar.DAY_OF_MONTH);
//return new DatePickerDialog(getActivity(), (EditSessionActivity)getActivity(), year, month, day);
// Create a new instance of DatePickerDialog and return it
return new DatePickerDialog(getActivity(), this, year, month, day);
}
public void onDateSet(DatePicker view, int year, int month, int day) {
editText.setText(String.valueOf(day) + "/"
+ String.valueOf(month + 1) + "/" + String.valueOf(year));
// set selected date into datepicker also
}
}
我知道问题出在onDateSet
方法上。有人可以帮忙吗?
我的日志猫:
06-05 12:19:40.702: E/AndroidRuntime(2876): FATAL EXCEPTION: main
06-05 12:19:40.702: E/AndroidRuntime(2876): java.lang.NullPointerException
06-05 12:19:40.702: E/AndroidRuntime(2876): at com.example.reminder.DatePickerFragment.onDateSet(DatePickerFragment.java:38)
06-05 12:19:40.702: E/AndroidRuntime(2876): at android.app.DatePickerDialog.tryNotifyDateSet(DatePickerDialog.java:148)
06-05 12:19:40.702: E/AndroidRuntime(2876): at android.app.DatePickerDialog.onClick(DatePickerDialog.java:116)
06-05 12:19:40.702: E/AndroidRuntime(2876): at com.android.internal.app.AlertController$ButtonHandler.handleMessage(AlertController.java:166)
06-05 12:19:40.702: E/AndroidRuntime(2876): at android.os.Handler.dispatchMessage(Handler.java:99)
06-05 12:19:40.702: E/AndroidRuntime(2876): at android.os.Looper.loop(Looper.java:137)
06-05 12:19:40.702: E/AndroidRuntime(2876): at android.app.ActivityThread.main(ActivityThread.java:5039)
06-05 12:19:40.702: E/AndroidRuntime(2876): at java.lang.reflect.Method.invokeNative(Native Method)
06-05 12:19:40.702: E/AndroidRuntime(2876): at java.lang.reflect.Method.invoke(Method.java:511)
06-05 12:19:40.702: E/AndroidRuntime(2876): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
06-05 12:19:40.702: E/AndroidRuntime(2876): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
06-05 12:19:40.702: E/AndroidRuntime(2876): at dalvik.system.NativeStart.main(Native Method)
06-05 12:19:44.152: E/Trace(2899): error opening trace file: No such file or directory (2)