- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个设置,我在 Android 中运行后台服务,附加的 BroadcastReceiver 监听特定类型的 Intent。然后广播接收器使用这些 Intent 来调用服务中的特定方法。下面是描述服务结构的代码:
public class MyService extends Service {
private class ServiceBroadcastReceiver extends BroadcastReceiver {
private MyService getMyService() {
return MyService.this;
}
public IntentFilter getASReceiverFilter() {
IntentFilter filter = new IntentFilter()
filter.addAction(Constants.ACTION_DO_SOMETHING);
return filter;
}
@Override
public void onReceive(Context context, Intent intent) {
// TODO Auto-generated method stub
MyService svc = getMyService();
String intentAction = intent.getAction();
Log.i(Constants.LOG_TAG, "Now trying to dispatch following action: " + intentAction);
//Dispatch to the appropriate method in MyService.
if (intentAction.equals(AppServiceConstants.ACTION_DO_SOMETHING)) {
svc.doSomething();
}
}
}
private ServiceBroadcastReceiver mRequestReceiver = new ServiceBroadcastReceiver();
@Override
public IBinder onBind(Intent intent) {
// TODO Auto-generated method stub
return null;
}
@Override
public void onCreate() {
Log.i(Constants.LOG_TAG, "Service Created!");
//Register for broadcast messages indicating the add music button was pressed
mRequestReceiver = new ServiceBroadcastReceiver();
registerReceiver(mRequestReceiver, mRequestReceiver.getASReceiverFilter());
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
Log.i(Constants.LOG_TAG, "Service Starting ... ");
// If we get killed, after returning from here, restart
return START_STICKY;
}
/***********************************************************************************
* Service Dispatch Methods
*/
protected void doSomething() {
Log.i(Constants.LOG_TAG, "Doing something");
}
}
我的问题是让这项服务及其广播接收器从我的整个应用程序中捕获广播的 Intent 。如果我做类似下面的事情......
getApplicationContext().sendBroadcast(new Intent(Constants.ACTION_DO_SOMETHING));
.. 只有在我从 Activity 中调用它时它才有效。但是,我希望即使在应用程序首次启动时也能“做某事”,所以我在创建 MyService 并启动它之后立即将该语句放在 onCreate() 方法中我自己的自定义 Application 子类中。出于某种原因,当应用程序启动时,广播在 Application 类代码中不起作用,但如果我将它放在 Activity 中的某些代码中(例如在 Activity 的 onCreate() 方法中),它就会起作用。我可以确认在我的 Application 对象中广播 Intent 之前调用了服务的 onCreate() 和 onStartCommand() 方法,但它似乎根本没有获得 Intent 并执行相关工作。
如有任何帮助,我们将不胜感激。
更新:
下面是我如何从我的应用程序发送广播(注意我先启动服务):
public class MyApplication extends Application {
@Override
public void onCreate() {
Intent intent = new Intent(getApplicationContext(), MyService.class);
getApplicationContext().startService(intent);
getApplicationContext().sendBroadcast(new Intent(Constants.ACTION_DO_SOMETHING));
}
}
请注意,我是在实际进行广播之前启动服务的。该服务不接收广播,但如果我从稍后启动的 Activity 中发出类似的调用,它会收到。
最佳答案
您的 Application
在此过程中先于任何其他组件创建。所以在 onCreate()
中没有 Serivce
运行。如果您在调用应用程序的 onCreate()
时发送广播,则 Service
没有注册广播接收器,因为它甚至还没有创建。
因此,换句话说,您的服务没有收到广播通知,因为广播接收器尚未注册。而且它还没有注册,因为 Service
还没有启动。并且它不能在应用程序的 onCreate()
设计返回之前启动。
您可以使用应用程序的 onCreate()
中的 Context.startService()
直接启动服务。您将能够通过 Intent
访问所有必需的数据。
更新问题的更新答案:
当你打电话时:
getApplicationContext().startService(intent);
您要求 Android 稍后启动服务。服务没有立即启动。它只计划在以后开始。事实上,在您从 Application 的 onCreate()
函数返回之前,它肯定不会启动。这是因为所有服务的生命周期回调函数(如 onCreate()
和 onStart()
)都是从主 UI 线程调用的。 Applicaiton 的 onCreate
当前正在阻塞主 UI 线程。
因此当您使用这些代码行发送广播时:
getApplicationContext().startService(intent);
getApplicationContext().sendBroadcast(new Intent(Constants.ACTION_DO_SOMETHING));
您实际上要求在稍后的某个时间开始服务,然后您立即发送广播。而且因为服务甚至没有机会启动和注册这个广播通知,当它真正开始时它不会收到任何东西。
您可以更改服务的 onStart()
代码来处理 Intent ,然后使用以下方式启动服务:
Intent intent = new Intent(getApplicationContext(), MyService.class);
intent.setAction(Constants.ACTION_DO_SOMETHING);
getApplicationContext().startService(intent);
关于android - 无法从应用程序类向 Android 服务广播 Intent ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8537630/
如果我想为收藏创建一个 Intent 。 如果用户问“他最喜欢什么”,它会显示一些建议芯片 因此它会调用与该芯片相关的任何后续 Intent 。 最喜欢的饮料 最喜欢的食物 最喜欢的电影等 我还想直接
我确信有一些显而易见的事情,但还没有找到解决这个简单问题的方法。错误是在用户猜出正确答案时尝试启动另一个 Activity 的主要 Activity : Error:(85, 23) Unresolv
public class MainActivity extends Activity { Button b; //FrameLayout fl; @Override p
我对 intentService 有点困惑。文档说,如果您向 intentService 发送多个任务( Intent ),那么它将在一个单独的线程上一个接一个地执行它们。我的问题是 - 是否可以同时
我正在尝试从其他应用程序获取 mime 类型 text/plain 的 Intent 并将该文本存储在字符串类型的变量中。它在 onCreate 方法中工作正常,但是当我使用 singleTask 作
我想知道,2个代码有什么区别? newIntent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_CLEAR_TOP);
如何设置我的 Activity 以响应任何类型的共享 Intent 。 我试过:- 但是这不起作用,我已经阅读了http://developer.android.co
鉴于子类具有不同的上下文以及在单击监听器后启动的不同 Activity ,父类(super class)中的代码 Intent Intent=new Intent(context,Activity.c
更新#1:更多信息添加到这篇文章的末尾 我是 Android 开发和测试的新手。 我有 3 个 Espresso 测试。第一个测试通过,但第二个不会运行,因为在第二个测试之前调用 setUp() 方法
我是 Espresso UI 测试的新手。 我在运行测试时遇到这个错误(ADT Eclipse IDE)。 该应用程序已经开发完成,并且在启动该应用程序时有很多请求正在进行。无法重写应用程序。但我需要
因此,尝试创建一个我认为是基本简历应用程序的应用程序。我有两个类(class),都有同样的问题。它说它“无法解析符号 Intent ” 谷歌部分做了,但没有任何意义.. 这是我的代码。 MainAct
我正在尝试将 user_id 值从一个 Intent 传递到另一个 Intent。我知道这是一个非常简单的过程,而且我已经这样做了好几次了。但对于下面的代码,我有点困惑。 我需要将 user_id 值
这是我将值传递给名为 choice 的类的主要 Activity 。 @Override public void onClick(View v) { // TODO Auto-generated me
我正在寻找一个 Android Intent 来翻译文本,我发现了这个: Google Translate Activity not working anymore 但我想在任务管理器中使用它。我真的
可以设置多个启动 Intent ,例如,当用户点击通知时。 让我解释一下我的具体问题: 我有一个带通知的应用程序。每个通知都会打开一个不同的 Activity (也有不同的附加功能)。 现在我想提取有
我有一个 Intent launchIntent = packageManagerForListener.getLaunchIntentForPackage(packagesForAdapter[po
List targetedShareIntents = new ArrayList(); Intent shareIntent = new Intent(android.content.Intent.
所以我试图在选择列表中的项目后启动一个新 Activity ......根据我所读的内容非常基本。我也在尝试在附加功能中发送一个值。所以我可以选择列表中的项目,然后新 Activity 开始,extr
有没有一种方法可以将一个Intent bundle 从一个 Intent 传递到另一个 Intent ,而不必提取包并单独处理每个额外的 Intent ? 例子: intent2.setExtras(
这个问题在这里已经有了答案: Android 5.0 (L) Service Intent must be explicit in Google analytics (11 个答案) 关闭 6 个月
我是一名优秀的程序员,十分优秀!