如何在Android中为以后的应用程序安排意图?
我刚刚开始Android开发,遇到了这个问题。我试图在一段特定的时间后开始一个意图如何在Android中为以后的应用程序安排意图?,android,broadcastreceiver,scheduled-tasks,android-broadcast,Android,Broadcastreceiver,Scheduled Tasks,Android Broadcast,我刚刚开始Android开发,遇到了这个问题。我试图在一段特定的时间后开始一个意图 我尝试使用runnable和handler.posttime方法,将意图放在runnable中。当您销毁应用程序或重新启动手机时,此方法不起任何作用 我试着设置一个广播接收器,但它不允许我使用startActivity(意图)来实现这个意图。我试着使用Context.startActivity(Intent),但如果在Intent完成之前应用程序被破坏,它会使应用程序停止工作 有人能帮我解决这个问题吗?谢谢 编辑
package com.mallock.sch_email2;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.net.Uri;
import android.widget.Toast;
public class Broadcast extends BroadcastReceiver{
@Override
public void onReceive(Context arg0, Intent arg1) {
Intent intent = new Intent(Intent.ACTION_SENDTO);
intent.setType("text/plain");
intent.putExtra(Intent.EXTRA_SUBJECT, Activity1.subj);
intent.putExtra(Intent.EXTRA_TEXT, Activity1.body);
intent.setData(Uri.parse("mailto:".concat(Activity1.rec)));
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
startActivity(arg0,intent);
Toast.makeText(arg0, "I'm running", Toast.LENGTH_SHORT).show();
}
}
日志:
07-15 21:43:13.980 4569-4569/com.mallock.sch_email2 E/AndroidRuntime﹕ FATAL EXCEPTION: main
Process: com.mallock.sch_email2, PID: 4569
java.lang.RuntimeException: Unable to start receiver com.mallock.sch_email2.Broadcast: java.lang.NullPointerException
at android.app.ActivityThread.handleReceiver(ActivityThread.java:2580)
at android.app.ActivityThread.access$1700(ActivityThread.java:151)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1397)
at android.os.Handler.dispatchMessage(Handler.java:110)
at android.os.Looper.loop(Looper.java:193)
at android.app.ActivityThread.main(ActivityThread.java:5292)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:824)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:640)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException
at java.lang.String.concat(String.java:678)
at com.mallock.sch_email2.Broadcast.onReceive(Broadcast.java:16)
at android.app.ActivityThread.handleReceiver(ActivityThread.java:2573)
at android.app.ActivityThread.access$1700(ActivityThread.java:151)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1397)
at android.os.Handler.dispatchMessage(Handler.java:110)
at android.os.Looper.loop(Looper.java:193)
at android.app.ActivityThread.main(ActivityThread.java:5292)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:824)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:640)
at dalvik.system.NativeStart.main(Native Method)
这是给你的!AlarmManager是正确的选择。这是为您准备的!AlarmManager是正确的选择。这是为您准备的!AlarmManager是正确的选择。这是为您准备的!AlarmManager是正确的选择。要在将来的特定时间执行事件,您需要使用AlarmManager类 例如,如果您想在2小时后打开活动,则:
AlarmManager am = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
Intent intent = new Intent(context, MyReciever.class);
PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, intent,
PendingIntent.FLAG_UPDATE_CURRENT);
am.set( AlarmManager.RTC_WAKEUP, System.currentTimeMillis() + 7200000 , pendingIntent );
接收者::
public class MyReciever extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
Intent intent = new Intent(context, MyActivity.class);
intent.addFlags(
Intent.FLAG_ACTIVITY_NEW_TASK
| Intent.FLAG_ACTIVITY_CLEAR_TOP
| Intent.FLAG_ACTIVITY_SINGLE_TOP);
startActivity(intent);
}
}
感谢要在将来的特定时间执行事件,您需要使用AlarmManager类 例如,如果您想在2小时后打开活动,则:
AlarmManager am = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
Intent intent = new Intent(context, MyReciever.class);
PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, intent,
PendingIntent.FLAG_UPDATE_CURRENT);
am.set( AlarmManager.RTC_WAKEUP, System.currentTimeMillis() + 7200000 , pendingIntent );
接收者::
public class MyReciever extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
Intent intent = new Intent(context, MyActivity.class);
intent.addFlags(
Intent.FLAG_ACTIVITY_NEW_TASK
| Intent.FLAG_ACTIVITY_CLEAR_TOP
| Intent.FLAG_ACTIVITY_SINGLE_TOP);
startActivity(intent);
}
}
感谢要在将来的特定时间执行事件,您需要使用AlarmManager类 例如,如果您想在2小时后打开活动,则:
AlarmManager am = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
Intent intent = new Intent(context, MyReciever.class);
PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, intent,
PendingIntent.FLAG_UPDATE_CURRENT);
am.set( AlarmManager.RTC_WAKEUP, System.currentTimeMillis() + 7200000 , pendingIntent );
接收者::
public class MyReciever extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
Intent intent = new Intent(context, MyActivity.class);
intent.addFlags(
Intent.FLAG_ACTIVITY_NEW_TASK
| Intent.FLAG_ACTIVITY_CLEAR_TOP
| Intent.FLAG_ACTIVITY_SINGLE_TOP);
startActivity(intent);
}
}
感谢要在将来的特定时间执行事件,您需要使用AlarmManager类 例如,如果您想在2小时后打开活动,则:
AlarmManager am = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
Intent intent = new Intent(context, MyReciever.class);
PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, intent,
PendingIntent.FLAG_UPDATE_CURRENT);
am.set( AlarmManager.RTC_WAKEUP, System.currentTimeMillis() + 7200000 , pendingIntent );
接收者::
public class MyReciever extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
Intent intent = new Intent(context, MyActivity.class);
intent.addFlags(
Intent.FLAG_ACTIVITY_NEW_TASK
| Intent.FLAG_ACTIVITY_CLEAR_TOP
| Intent.FLAG_ACTIVITY_SINGLE_TOP);
startActivity(intent);
}
}
谢谢我正在使用pendingent.getBroadcast,然后使用BroadcastReceiver启动一个意图。直接使用PendingEvent.getActivity解决了该问题
@密莫石窟里:就在。。。谢谢:)我正在使用pendingent.getBroadcast,然后使用BroadcastReceiver启动一个意图。直接使用PendingEvent.getActivity解决了该问题
@密莫石窟里:就在。。。谢谢:)我正在使用pendingent.getBroadcast,然后使用BroadcastReceiver启动一个意图。直接使用PendingEvent.getActivity解决了该问题
@密莫石窟里:就在。。。谢谢:)我正在使用pendingent.getBroadcast,然后使用BroadcastReceiver启动一个意图。直接使用PendingEvent.getActivity解决了该问题
@密莫石窟里:就在。。。谢谢:)欢迎来到Stack Overflow!请发布您编写的代码,展示您迄今为止所做的工作几乎总是很有帮助的,即使您已经解释了这些方法。@Akshat我忘了在receiver内的intent中添加标志。请检查我的更新答案。logcat显示'Activity1.rec'字段为空,concat不喜欢。欢迎使用堆栈溢出!请发布您编写的代码,展示您迄今为止所做的工作几乎总是很有帮助的,即使您已经解释了这些方法。@Akshat我忘了在receiver内的intent中添加标志。请检查我的更新答案。logcat显示'Activity1.rec'字段为空,concat不喜欢。欢迎使用堆栈溢出!请发布您编写的代码,展示您迄今为止所做的工作几乎总是很有帮助的,即使您已经解释了这些方法。@Akshat我忘了在receiver内的intent中添加标志。请检查我的更新答案。logcat显示'Activity1.rec'字段为空,concat不喜欢。欢迎使用堆栈溢出!请发布您编写的代码,展示您迄今为止所做的工作几乎总是很有帮助的,即使您已经解释了这些方法。@Akshat我忘了在receiver内的intent中添加标志。请检查我的更新答案。logcat显示“Activity1.rec”字段为空,concat不喜欢该字段。为什么要将意图发送到广播,并从广播发送到活动?您可以直接将意图发送到活动我就是这么做的,并且我在BroadcastReceiver中初始化了一个新的意图。此后,我调用了context.startActivity(Intent)方法。它会导致程序崩溃。可能是因为我传递了MainActivity.this作为上下文和BroadcastReceiver对已销毁应用程序的startActivity方法的调用?此外,我可能在这里补充说,BroadcastReceiver无法识别startActivity。为什么不使用PendingEvent.getActivity将意图发送到活动?当然,您需要相同的标志。为什么要将意图发送到广播,并从广播发送到活动?您可以直接将意图发送到活动我就是这么做的,并且我在BroadcastReceiver中初始化了一个新的意图。此后,我调用了context.startActivity(Intent)方法。它会导致程序崩溃。可能是因为我传递了MainActivity.this作为上下文和BroadcastReceiver对已销毁应用程序的startActivity方法的调用?此外,我可能在这里补充说,BroadcastReceiver无法识别startActivity。为什么不使用PendingEvent.getActivity将意图发送到活动?当然,您需要相同的标志。为什么要将意图发送到广播,并从广播发送到活动?您可以直接将意图发送到活动我就是这么做的,并且我在BroadcastReceiver中初始化了一个新的意图。此后,我调用了context.startActivity(Intent)方法。它会导致程序崩溃。可能是因为我传递了MainActivity。这是作为上下文和BroadcastReceiver对已销毁应用程序的startActivity方法的调用吗?此外,我可以在这里补充一点,就是startActivity无法从BroadcastReceiver识别。为什么不这样做