0

我正在尝试仅在 Android Wear 手表上显示通知。我不希望通知显示在手机上(它在其上打开了应用程序),并且我不希望它直接在活动中(但是,其中一个操作应该打开一个活动)。

为了完成我想要的,我创建了一个带有 onDataChanged 的​​ WearableListenerService。在此方法中,我尝试创建通知。这是我使用的代码:@Override public void onDataChanged(DataEventBuffer dataEvents) { Log.d("Listener", "dataChanged");

    Intent actionIntent = new Intent(getBaseContext(), WatchMainActivity.class);
    actionIntent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
    PendingIntent actionPendingIntent =
            PendingIntent.getActivity(getBaseContext(), 0, actionIntent,
                    PendingIntent.FLAG_CANCEL_CURRENT);

    NotificationManagerCompat manager = NotificationManagerCompat.from(getApplicationContext());
    NotificationCompat.Builder builder = new NotificationCompat.Builder(getApplicationContext());

    Log.d("listener", "Created things");

    builder.setContentTitle("Wearable test")
            .setContentText("Testing 123")
            .setOngoing(true)
            .setSmallIcon(R.drawable.ic_launcher)
    ;

    // Create the action
    NotificationCompat.Action action =
            new NotificationCompat.Action.Builder(R.drawable.ic_full_sad,
                    getString(R.string.label), actionPendingIntent)
                    .build();


    NotificationCompat.WearableExtender extender = new NotificationCompat.WearableExtender();
    extender.addAction(action)
            .setContentAction(0)
            .setHintHideIcon(true)
    ;

    Log.d("listener", "action created, extending...");

    builder.extend(extender);

    Log.d("listener", "extended");


    manager.cancel(101);
    Log.d("listener", "canceled");

    manager.notify(101, builder.build());

    Log.d("listener", "notified");


    Log.d("listener", "created");
}

在查看日志时会导致此崩溃:

D/listener( 1075): listener created
D/Listener( 1075): dataChanged
D/listener( 1075): Created things
D/listener( 1075): action created, extending...
D/listener( 1075): extended
D/listener( 1075): canceled
W/dalvikvm(  597): threadid=20: thread exiting with uncaught exception (group=0xada2fd70)
E/AndroidRuntime(  597): FATAL EXCEPTION: NotificationCollectorService
E/AndroidRuntime(  597): Process: com.google.android.wearable.app, PID: 597
E/AndroidRuntime(  597): java.lang.ClassCastException: android.os.Bundle cannot be cast to android.app.Notification$Action
E/AndroidRuntime(  597):    at android.support.v4.app.NotificationCompatApi20.getActionsFromParcelableArrayList(NotificationCompatApi20.java:145)
E/AndroidRuntime(  597):    at android.support.v4.app.NotificationCompat$NotificationCompatImplApi20.getActionsFromParcelableArrayList(NotificationCompat.java:532)
E/AndroidRuntime(  597):    at android.support.v4.app.NotificationCompat$WearableExtender.<init>(NotificationCompat.java:1876)
E/AndroidRuntime(  597):    at com.google.android.clockwork.stream.StreamManager.stripRemoteViewsFromNotification(StreamManager.java:481)
E/AndroidRuntime(  597):    at com.google.android.clockwork.stream.StreamManager.maybeStripRemoteViewsFromNotification(StreamManager.java:473)
E/AndroidRuntime(  597):    at com.google.android.clockwork.stream.StreamManager.setItem(StreamManager.java:347)
E/AndroidRuntime(  597):    at com.google.android.clockwork.stream.StreamManager.onNotificationPosted(StreamManager.java:253)
E/AndroidRuntime(  597):    at com.google.android.clockwork.stream.NotificationCollectorService$ServiceHandler.handleMessage(NotificationCollectorService.java:264)
E/AndroidRuntime(  597):    at android.os.Handler.dispatchMessage(Handler.java:102)
E/AndroidRuntime(  597):    at android.os.Looper.loop(Looper.java:136)
E/AndroidRuntime(  597):    at android.os.HandlerThread.run(HandlerThread.java:61)
D/listener( 1075): notified
D/listener( 1075): created

因此,通知中存在导致此崩溃的某些内容。当我在构建器中删除扩展调用时,它工作正常,但是当然没有添加该操作。因此,我假设我在 Intent/PendingIntent 或 WearableExtender 中做错了什么,但我不知道我做错了什么。当我从磨损文档中获取示例时,它会导致同样的崩溃。

有人对如何解决此崩溃有任何想法吗?

4

2 回答 2

1

我刚刚测试了您在 DataLayerListenerService(扩展 WearableListenerService)中的 onDataChanged 回调中发布的代码。但是... wverything 工作正常... 我只是将动作标题中的字符串更改为我的 R.string.app_name + 活动名称。除此之外 - 没有任何变化。

  1. 尝试在 Action buider 中将您的 actionPendingIntent 替换为 null(以消除 Intent 和 PendingIntent),并将您的 getString 替换为仅用于测试的硬编码字符串。
  2. 你确定你有最新的 Support-v4 库吗?检查您是否有任何不是最新的 AndroidWear 图像、支持库等。
  3. 尝试使用标准通知 API 而不是 NotificationCompat - 无需在 Watch 上使用 NotificationCompat:

http://developer.android.com/training/wearables/apps/creating.html

对于仅出现在可穿戴设备上的通知(即它们是由在可穿戴设备上运行的应用程序发出的),您可以在可穿戴设备上使用标准框架 API(API 级别 20)并删除移动模块中的支持库依赖你的项目。

http://developer.android.com/training/wearables/apps/layouts.html

注意:在可穿戴设备上创建自定义通知时,您可以使用标准通知 API(API 级别 20)而不是支持库。

请尝试这些步骤,尤其是切换到标准通知而不是 NotificationCompat - 但是您的代码在我的应用程序中运行时被复制,没有任何问题:\

于 2014-07-12T12:36:08.543 回答
0

切换到标准的 4.4W API 可以解决这个问题,当你使用 support.v4 包时,进程 com.google.android.wearable.app 会崩溃。使用 support.v4 包,如果您不想在通知中添加 RemoteInput,您可以添加操作 withbuild.addAction(action)而不是build.extend(extender.addAction(action))

于 2014-08-11T06:45:44.203 回答