- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在使用下面的代码(尤其是 pushMessage
方法)向用户显示一些通知:
public final class MyApplicationMessageFolder
{
public static final long MyFolderId = 0x1256789012F10123L;
private ApplicationMessageFolder folder_;
private ApplicationIndicator indicator_;
private MyReadableListImpl collection_;
public void pushMessage(String subject, String message)
{
try
{
if (collection_ == null)
{
collection_ = new MyReadableListImpl();
}
if (indicator_ == null)
{
registerFolderAndIndicator();
}
ApplicationMessage am = new MyApplicationMessage(message, subject);
collection_.addMessage(am);
folder_.fireElementAdded(am);
// Update indicator
int size = collection_.size();
indicator_.setValue(size);
indicator_.setVisible(size > 0);
}
catch (Exception e)
{
System.out.println(e.getMessage());
}
}
private void registerFolderAndIndicator()
{
// registration application folder and indicator
ApplicationMessageFolderRegistry amfr =
ApplicationMessageFolderRegistry.getInstance();
folder_ = amfr.getApplicationFolder(MyFolderId );
if (folder_ == null)
{
folder_ =
amfr.registerFolder(MyFolderId , "My Folder", collection_, true);
ApplicationIcon icon =
new ApplicationIcon(image_ = EncodedImage.getEncodedImageResource("my_icon.png"), true);
int status = ApplicationMessage.Status.INCOMING | ApplicationMessage.Status.UNOPENED;
amfr.registerMessageIcon(0, status, icon);
folder_.setSearchProperties(new ApplicationMessageSearchProperties(true));
folder_.addListener(
new ApplicationMessageFolderListener() {
public void actionPerformed(int action, ApplicationMessage[] messages,
ApplicationMessageFolder folder) {
if (action == ApplicationMessageFolderListener.MESSAGE_DELETED) {
for (int i = 0; i < messages.length; i++)
collection_.removeMessage(messages[i]);
indicator_.setValue(collection_.size());
indicator_.setVisible(collection_.size() > 0);
}
}
},
ApplicationMessageFolderListener.MESSAGE_DELETED |
ApplicationMessageFolderListener.MESSAGE_MARKED_OPENED |
ApplicationMessageFolderListener.MESSAGE_MARKED_UNOPENED,
ApplicationDescriptor.currentApplicationDescriptor());
ApplicationMenuItem[] menu = new ApplicationMenuItem[] {
new ApplicationMenuItem(0) {
public String toString() {
return "Go to application";
}
public Object run(Object context) {
return null;
}
}
};
amfr.registerMessageMenuItems(0, status, menu,
ApplicationDescriptor.currentApplicationDescriptor());
amfr.setBulkMarkOperationsSupport(0, status, true, false);
ApplicationIndicatorRegistry air = ApplicationIndicatorRegistry.getInstance();
air.register(new ApplicationIcon(EncodedImage
.getEncodedImageResource("bar_icon_25.png")),
false, false);
indicator_ = air.getApplicationIndicator();
}
}
class MyApplicationMessage implements ApplicationMessage
{
private String message_;
private String subject_;
private long timestamp_;
public MyApplicationMessage(String message, String subject) {
message_ = message;
subject_ = subject;
timestamp_ = new Date().getTime();
}
public String getContact() {
return "HelloWorld";
}
public Object getCookie(int cookieId) {
return null;
}
public Object getPreviewPicture() {
return image_;
}
public String getPreviewText() {
return message_;
}
public int getStatus() {
return ApplicationMessage.Status.UNOPENED;
}
public String getSubject() {
return subject_;
}
public long getTimestamp() {
return timestamp_;
}
public int getType() {
return 0x01;
}
}
private class MyReadableListImpl implements ReadableList {
private final Vector messages;
MyReadableListImpl() {
messages = new Vector();
}
public Object getAt(final int index) {
return messages.elementAt(index);
}
public int getAt(final int index, final int count,
final Object[] elements, final int destIndex) {
return 0;
}
public int getIndex(final Object element) {
return messages.indexOf(element);
}
public int size() {
return messages.size();
}
void addMessage(final ApplicationMessage message) {
messages.addElement(message);
}
void removeMessage(final ApplicationMessage message) {
messages.removeElement(message);
}
}
}
我可以在我的消息文件夹中看到我的消息,但我仍然无法在通知栏中看到它们
谁能解释为什么我看到空的通知栏?
谢谢
最佳答案
要在通知下拉列表中查看消息,需要使用:
ApplicationFolderIntegrationConfig config = new
ApplicationFolderIntegrationConfig(true, true,
ApplicationDescriptor.currentApplicationDescriptor());
folder_ = amfr.registerFolder(MyFolderId , "My Folder", collection_, config);
改为:
folder_ = amfr.registerFolder(MyFolderId , "My Folder", collection_, true);
关于java - 黑莓 - "you currently have no new notifications",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14952223/
我遵循了提供的文档 here并且可以在 Android N 及更高版本上成功创建通知组。然而,我遇到的问题是 Android Oreo,每个发布到群组的通知都会为群组播放声音。 这很烦人,因为我只想播
单点触控 当应用程序返回前台时,我需要激活的 ViewController 来了解这一点。 是否有一个事件或覆盖我可以用来确定 View 被带到前台。 我确实找到了“WillEnterForegrou
我正在尝试在我的项目中创建一个通知系统。 这些是我已经完成的步骤: 1-php artisan notifications:table 2-php artisan migrate 3-php arti
我想知道如何批量发送推送通知。我们从以下3个主要模式来看问题: 一次API调用->一条消息->发送给指定用户 一次 API 调用 -> 一条消息 -> 传递给许多不同的用户(由 id 指定) 一个 A
我想在用户点击保存或删除按钮时显示通知。 Here is what i use for it.(Kendo notification) 我认为我的 CSS 部分有问题,我更改了很多东西但我仍然在原地。
在我的测试代码中,我使用了 notification.flags |= Notification.DEFAULT_SOUND; notification.flags |= No
当 Redis Sentinel 通知事件时,它不会提供 Redis 主节点的名称。 配置摘录: # sentinel notification-script # # Call the speci
Microsoft Exchange 引入了流通知作为 Exchange 2010 中拉/推通知的替代方法。有关流的基本介绍可以在此 msdn article 上找到。和 blog 但是,我无法弄清楚
我在理解WebExtensions notification.onClicked事件的文档时遇到问题。 最终,我要在单击通知时将通知文本复制到剪贴板。但是,现在我在理解回调内容或必须在其中插入noti
我即将实现ionic-native Push Notifications .这可以在浏览器中运行吗?还是我需要安装 iOS/Android 模拟器? 最佳答案 除非您使用 Phonegap 推送服务器
Safari 12.1 是否支持服务 worker PWA 推送通知?我试过这个 demo在 iOS 上,但它仍然不适合我。 有机会得到它们吗?谢谢。 最佳答案 目前没有关于此功能的通信...Appl
我遇到了一个奇怪的错误。一段时间以来,这种崩溃一直在我的 Fabric 中出现 致命异常:android.app.RemoteServiceException:startForeground 的错误通
我正在使用 Google Cloud Messaging 在 iOS 应用中接收推送通知。为了了解该系统的可靠性,我进行了两项测试。1.当应用程序处于前台时接收通知 下面称为curl 12. 当应用程
String ns = Context.NOTIFICATION_SERVICE; NotificationManager mNotificationManager = (NotificationM
我想在我的 Android 应用程序中使用 Notification,但我不知道 Android 中的 Notification 和 Push Notification 有什么区别. 我在网上搜索了这
我有两个模型之间的多对多关系: 用户 namespace App\Models; class User extends Model { use HasApiTokens, Notifiable
我在 App Store 中有一个 iPad 应用程序,其逻辑主要依赖于本地通知。换句话说,应用程序内部发生的很多事情都是由委托(delegate)方法应用程序 didReceiveLocalNoti
我知道如何制作每天在特定时间触发的本地通知。但是如何为每个通知更改 UNMutableNotificationContent.Body? 现在它只是一遍又一遍地显示相同的文本。 我正在为 iOS 10
请问,是否可以在没有用户 ID 的情况下发送推送通知?假设我们想向所有下载了我们应用程序的用户发送推送消息。或者出于安全原因,用户 ID 不能存储在数据库中(或在应用程序中使用)。 最佳答案 不管怎样
我在使用 Twilio notify 发送通知时遇到异常。 当我在使用相同的 Twilio NotificationCreator bean 发送 SMS 后发送通知时,如果我发送通知而不发送 SMS
我是一名优秀的程序员,十分优秀!