我正在关注 this在 Android 设备 上显示通知 的教程。当我在设备上运行该应用程序时,状态栏上出现了一个图标(通常它出现在 Android 设备上),这绝对是完美的。但出于好奇,我想知道当设备收到通知时,我可以显示警报或一些细节很少的 View 吗?我想在我的下一个应用程序中实现这个概念。
一些样本会对我有很大帮助。
最佳答案
一种典型的模式是让您注册应用程序的特定部分以“接收”或监听特定 Intent 。这样,您的应用程序可以在任意时间点唤醒,查看调用 Intent ,并决定如何处理它(启动完整应用程序、显示对话框或其他)。随之而来的一件好事是使用 AlarmManager 设置一个警报,该警报将在将来触发并唤醒您的应用程序(定期更新)。
这是否回答了您的问题?我在我的应用程序中做过类似的事情,如果您愿意,我可以帮助您编写代码。
编辑 要实现这一点,您将创建一个扩展 BroadcastReceiver 或 IntentService 的 java 类(取决于您是希望该类分别在 ui 线程上运行还是作为服务运行)。在下面的示例中,我定义了自己的 Intent 操作键,但通常您会使用 intent.getAction() 检查操作:
public class QueryService extends IntentService {
public final static String SERVICE_NAME = "QueryService";
// incoming flags
public final static String FLAG_ACTION = "R_ACTION";
public final static String FLAG_EVENTS_RETURNED = "R_EVENTS";
public final static String FLAG_EVENTS_ARCHIVED_RETURNED = "R_EVENTS_ARCH";
public final static String FLAG_SHARED_PREFERNCES_RETURNED = "R_PREFS";
// outgoing flags
public final static String RETURN_EVENTS = "RETURN_E";
public final static String RETURN_EVENTS_ARCHIVED = "RETURN_E_A";
public final static String RETURN_SHARED_PREFS = "RETURN_S_P";
public QueryService() {
super(SERVICE_NAME);
}
protected void onHandleIntent(Intent intent) {
String rAction = intent.getStringExtra(FLAG_ACTION);
boolean rEvents = intent.getBooleanExtra(FLAG_EVENTS_RETURNED, true);
boolean rEventsArchived = intent.getBooleanExtra(FLAG_EVENTS_ARCHIVED_RETURNED, true);
boolean rSharedPrefs = intent.getBooleanExtra(FLAG_SHARED_PREFERNCES_RETURNED, true);
if(rAction == null){
Log.e(SERVICE_NAME, "no return action specified, exiting...");
return;
}
Log.i(SERVICE_NAME, "Caller: " + rAction);
DroidTaskApplication app = (DroidTaskApplication)getApplicationContext();
Intent resultsIntent = new Intent(rAction);
// TODO assembling events / archived events from a database needs
// a function that gets the complete event instead of just its headers
// assemble event objects and insert them
if(rEvents){
List<Event> liteEvents = app.edo.getAllEvents();
if(liteEvents != null){
for(Event e : liteEvents){
int id = e.getId();
e.setAlarms(app.edo.getAlarmsById(id));
e.setSubtasks(app.edo.getSubtasksById(id));
e.setNotes(app.edo.getNotesById(id));
}
}
resultsIntent.putExtra(RETURN_EVENTS, (Serializable)liteEvents);
}
// assemble archived event objects and insert
if(rEventsArchived){
List<Event> liteEventsA = app.edo.getAllArchivedEvents();
resultsIntent.putExtra(RETURN_EVENTS_ARCHIVED, (Serializable)liteEventsA);
}
// collect the shared data and send it
if(rSharedPrefs){
SharedPreferences prefs = getSharedPreferences(getString(R.string.PREFS_FILE_NAME), MODE_WORLD_READABLE);
resultsIntent.putExtra(RETURN_SHARED_PREFS, (Serializable)(prefs == null? null : prefs.getAll()));
}
Log.i(SERVICE_NAME, "returning results");
// send everything to the caller
sendBroadcast(resultsIntent);
}
}
无论该类是服务还是广播接收器,您都必须在应用程序中将其注册为“接收器”(意味着它可以接受某种 Intent 广播);这可以在 Java 代码或 Android list 中完成。下面是我在 list 中用于该服务的示例(尽管我的 Java 类不关心 Intent 操作 yet):
<!-- Notification Launcher -->
<receiver android:name="edu.clarkson.dtask.BK.NotificationReceiver" android:enabled="true">
<intent-filter>
<action android:name="edu.clarkson.dtask.BK.NotificationReceiver.DISPATCH_ALARM" />
<action android:name="edu.clarkson.dtask.BK.NotificationReceiver.CANCEL_ALARM" />
</intent-filter>
</receiver>
当某个状态发生变化时,操作系统会广播不同的系统 Action 和通知;如果您想了解这些更改,您可以按照与上述相同的方式在 list 中为不同的 Intent 操作(例如 ACTION_BATTERY_STATE_CHANGED)注册一个 broadcastreceiver 或 intentservice。所有文档都可以在 android dev site 上找到.我希望这会让您走上正确的道路。
关于android - 在收到通知时显示警报或 View ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6994243/
大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje
我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何
我想要做的是有2个不同的Controller,client和test_client。客户端Controller已经构建,我想创建一个test_clientController,我可以使用它来玩弄客户端的UI并根据需要进行调整。我主要是想绕过我在客户端中内置的验证及其对加载数据的管理Controller的依赖。所以我希望test_clientController加载示例数据集,然后呈现客户端Controller的索引View,以便我可以调整客户端UI。就是这样。我在test_clients索引方法中试过这个:classTestClientdefindexrender:template=>
我是一个Rails初学者,但我想从我的RailsView(html.haml文件)中查看Ruby变量的内容。我试图在ruby中打印出变量(认为它会在终端中出现),但没有得到任何结果。有什么建议吗?我知道Rails调试器,但更喜欢使用inspect来打印我的变量。 最佳答案 您可以在View中使用puts方法将信息输出到服务器控制台。您应该能够在View中的任何位置使用Haml执行以下操作:-puts@my_variable.inspect 关于ruby-on-rails-如何在我的R
我是rails的新手,想在form字段上应用验证。myviewsnew.html.erb.....模拟.rbclassSimulation{:in=>1..25,:message=>'Therowmustbebetween1and25'}end模拟Controller.rbclassSimulationsController我想检查模型类中row字段的整数范围,如果不在范围内则返回错误信息。我可以检查上面代码的范围,但无法返回错误消息提前致谢 最佳答案 关键是您使用的是模型表单,一种显示ActiveRecord模型实例属性的表单。c
简而言之错误:NOTE:Gem::SourceIndex#add_specisdeprecated,useSpecification.add_spec.Itwillberemovedonorafter2011-11-01.Gem::SourceIndex#add_speccalledfrom/opt/local/lib/ruby/site_ruby/1.8/rubygems/source_index.rb:91./opt/local/lib/ruby/gems/1.8/gems/rails-2.3.8/lib/rails/gem_dependency.rb:275:in`==':und
目前,Itembelongs_toCompany和has_manyItemVariants。我正在尝试使用嵌套的fields_for通过Item表单添加ItemVariant字段,但是使用:item_variants不显示该表单。只有当我使用单数时才会显示。我检查了我的关联,它们似乎是正确的,这可能与嵌套在公司下的项目有关,还是我遗漏了其他东西?提前致谢。注意:下面的代码片段中省略了不相关的代码。编辑:不知道这是否相关,但我正在使用CanCan进行身份验证。routes.rbresources:companiesdoresources:itemsenditem.rbclassItemi
有人知道在发布新版本的Ruby和Rails时收到电子邮件的方法吗?他们有邮件列表,RubyonRails有一个推特,但我不想听到那些随之而来的喧嚣,我只想知道什么时候发布新版本,尤其是那些有安全修复的版本。 最佳答案 从therailsblog获取提要.http://weblog.rubyonrails.org/feed/atom.xml 关于ruby-on-rails-如何在发布新的Ruby或Rails版本时收到通知?,我们在StackOverflow上找到一个类似的问题:
如果我在模型中设置验证消息validates:name,:presence=>{:message=>'Thenamecantbeblank.'}我如何让该消息显示在闪光警报中,这是我迄今为止尝试过的方法defcreate@message=Message.new(params[:message])if@message.valid?ContactMailer.send_mail(@message).deliverredirect_to(root_path,:notice=>"Thanksforyourmessage,Iwillbeintouchsoon")elseflash[:error]
最近因为项目需要,需要将Android手机系统自带的某个系统软件反编译并更改里面某个资源,并重新打包,签名生成新的自定义的apk,下面我来介绍一下我的实现过程。APK修改,分为以下几步:反编译解包,修改,重打包,修改签名等步骤。安卓apk修改准备工作1.系统配置好JavaJDK环境变量2.需要root权限的手机(针对系统自带apk,其他软件免root)3.Auto-Sign签名工具4.apktool工具安卓apk修改开始反编译本文拿Android系统里面的Settings.apk做demo,具体如何将apk获取出来在此就不过多介绍了,直接进入主题:按键win+R输入cmd,打开命令窗口,并将路