3

AlarmManager を使用して、PendingIntent を介してアクティビティを開始します。

        Intent smon = new Intent(ctxt, VideoActivty.class);
        final Bundle extra = new Bundle();
        extra.putString("extrastring","monday");
        smon.putExtras(extra);
        //smon.putExtra("extrastring","monday");
        smon.setFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP);
        PendingIntent psmon = PendingIntent.getActivity(ctxt, 0, smon, 0);

        Calendar calSet1 = Calendar.getInstance();
        calSet1.set(Calendar.MONTH, c.get(Calendar.MONTH));
        calSet1.set(Calendar.YEAR, c.get(Calendar.YEAR));
        calSet1.set(Calendar.DAY_OF_WEEK, 2);
        calSet1.set(Calendar.HOUR_OF_DAY, hsmon);
        calSet1.set(Calendar.MINUTE, msmon);
        calSet1.set(Calendar.SECOND, 0);
        calSet1.set(Calendar.MILLISECOND, 0);
        int delay1=0;
        if(today.get(Calendar.DAY_OF_WEEK)>2)delay1=7 * 24 * 60 * 60 * 1000;
        if((today.get(Calendar.DAY_OF_WEEK)==2)&&(today.get(Calendar.HOUR_OF_DAY)>hsmon))delay1=7 * 24 * 60 * 60 * 1000;
        if((today.get(Calendar.DAY_OF_WEEK)==2)&&(today.get(Calendar.HOUR_OF_DAY)==hsmon)&&(today.get(Calendar.MINUTE)>msmon))delay1=7 * 24 * 60 * 60 * 1000;
        Log.e("delay 1",Integer.toString(delay1));
        //calSet.setTimeZone(TimeZone.getTimeZone("UTC"));
        mgr.setRepeating(AlarmManager.RTC_WAKEUP, calSet1.getTimeInMillis()+delay1,
                7 * 24 * 60 * 60 * 1000, psmon);

ご覧のとおり、私のインテントには "extrastring" という Extra があります。

ここで、開始したアクティビティから Extra を読み取ろうとすると、次のようになります。

    protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    //
    final Bundle extra = getIntent().getExtras();
    String message="cazzo";
    if (extra != null) {

        message=extra.getString("extrastring");
    }
    Log.e("intent che è partito",message);

NullPointerException が発生します。

助けてくれてありがとう

07-19 13:34:18.336: E/AndroidRuntime(14109): FATAL EXCEPTION: main
07-19 13:34:18.336: E/AndroidRuntime(14109): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.videdrome/com.example.videdrome.VideoActivty}: java.lang.NullPointerException: println needs a message
07-19 13:34:18.336: E/AndroidRuntime(14109):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180)
07-19 13:34:18.336: E/AndroidRuntime(14109):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
07-19 13:34:18.336: E/AndroidRuntime(14109):    at android.app.ActivityThread.access$600(ActivityThread.java:141)
07-19 13:34:18.336: E/AndroidRuntime(14109):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
07-19 13:34:18.336: E/AndroidRuntime(14109):    at android.os.Handler.dispatchMessage(Handler.java:99)
07-19 13:34:18.336: E/AndroidRuntime(14109):    at android.os.Looper.loop(Looper.java:137)
07-19 13:34:18.336: E/AndroidRuntime(14109):    at android.app.ActivityThread.main(ActivityThread.java:5041)
07-19 13:34:18.336: E/AndroidRuntime(14109):    at java.lang.reflect.Method.invokeNative(Native Method)
07-19 13:34:18.336: E/AndroidRuntime(14109):    at java.lang.reflect.Method.invoke(Method.java:511)
07-19 13:34:18.336: E/AndroidRuntime(14109):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
07-19 13:34:18.336: E/AndroidRuntime(14109):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
07-19 13:34:18.336: E/AndroidRuntime(14109):    at dalvik.system.NativeStart.main(Native Method)
07-19 13:34:18.336: E/AndroidRuntime(14109): Caused by: java.lang.NullPointerException: println needs a message
07-19 13:34:18.336: E/AndroidRuntime(14109):    at android.util.Log.println_native(Native Method)
07-19 13:34:18.336: E/AndroidRuntime(14109):    at android.util.Log.e(Log.java:231)
07-19 13:34:18.336: E/AndroidRuntime(14109):    at com.example.videdrome.VideoActivty.onCreate(VideoActivty.java:41)
07-19 13:34:18.336: E/AndroidRuntime(14109):    at android.app.Activity.performCreate(Activity.java:5104)
07-19 13:34:18.336: E/AndroidRuntime(14109):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
07-19 13:34:18.336: E/AndroidRuntime(14109):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)
07-19 13:34:18.336: E/AndroidRuntime(14109):    ... 11 more
4

5 に答える 5

4

Bundle を使用して同様のことを行っています

final Intent notificationIntent = new Intent(context, A.class);
notificationIntent.putExtras(extra);
final PendingIntent intent = PendingIntent.getActivity(context, 0,
        notificationIntent, PendingIntent.FLAG_UPDATE_CURRENT);

extra は Bundle です:

final Bundle extra = new Bundle();
extra.putString("Message", "hello");

開始されたアクティビティの onCreate で Bundle の値を取得できます。

final Bundle extra = getIntent().getExtras();
if (extra != null) {
    String message=extra.getString("Message");
}

さらに、フラグを使用できますPendingIntent.FLAG_UPDATE_CURRENT

このフラグは次のように機能します。

記述された PendingIntent が既に存在する場合は、それを保持しますが、余分なデータをこの新しい Intent にあるものに置き換えます。これは、エクストラのみが変更されるインテントを作成している場合に使用できます。以前の PendingIntent を受け取ったエンティティが、明示的に与えられていなくても、新しいエクストラでそれを起動できることを気にしません。

于 2013-07-19T10:34:05.063 に答える
1

これを試して:

     Bundle extras = getIntent().getExtras();
     String message = extras.getString("extrastring");
于 2013-07-19T10:31:38.457 に答える
1

おそらくやりたいことは、その文字列を に入れ、Bundleそれをインテントに追加することです( putExtras()を使用します。

次に、インテントでgetExtras()を呼び出してバンドルを取得し、そこから文字列を取得できます。

于 2013-07-19T10:29:31.740 に答える
1

この方法を試してください

String result = getIntent().getExtras().getString("extrastring");
于 2013-07-19T10:32:45.180 に答える
1

あなたの説明から、メソッドが を返すNullPointerExceptionために が発生したと思われます。これには、次の 2 つの理由が考えられます。getIntent()null

  1. getIntent()呼び出されたアクティビティのonCreate()メソッドが起動される前に呼び出していないことを確認してください。
  2. インテントを送信するときに呼び出されたアクティビティが既に開いている場合、送信した新しいインテントは受信されず、最初に開始したインテントが使用されることに注意してください。これを回避する方法については、このSOの回答を確認してください。

それが役立つことを願っています!

于 2013-07-19T10:48:34.587 に答える