修正方法: android.app.RemoteServiceException: パッケージから不正な通知が投稿されました *: アイコンを作成できませんでした: StatusBarIcon 質問する

修正方法: android.app.RemoteServiceException: パッケージから不正な通知が投稿されました *: アイコンを作成できませんでした: StatusBarIcon 質問する

クラッシュ ログに次の例外が表示されます。

android.app.RemoteServiceException: Bad notification posted from package com.my.package: Couldn't create icon: StatusBarIcon(pkg=com.my.package user=0 id=0x7f02015d level=0 visible=true num=0 )
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1456)
    at android.os.Handler.dispatchMessage(Handler.java:102)
    at android.os.Looper.loop(Looper.java:146)
    at android.app.ActivityThread.main(ActivityThread.java:5487)
    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:1283)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1099)
    at dalvik.system.NativeStart.main(Native Method)

次の方法を使用して、AlarmManager を介して設定された PendingIntent の IntentService から通知を投稿しています。ここで渡されるすべての値は、PendingIntent / IntentService のバンドル エクストラからのものです。

/**
 * Notification 
 *
 * @param c
 * @param intent
 * @param notificationId
 * @param title
 * @param message
 * @param largeIcon
 * @param smallIcon
 */
public static void showNotification(Context c, Intent intent,
        int notificationId, String title, String message, int largeIcon,
        int smallIcon) {
    PendingIntent detailsIntent = PendingIntent.getActivity(c,
            notificationId, intent, PendingIntent.FLAG_UPDATE_CURRENT);

    // BUILD
    NotificationCompat.Builder mNotifyBuilder = new NotificationCompat.Builder(
            c);
    // TITLE
    mNotifyBuilder.setContentTitle(title).setContentText(message);

    // ICONS
    mNotifyBuilder.setSmallIcon(smallIcon);
    if (Util.isAndroidOSAtLeast(Build.VERSION_CODES.HONEYCOMB)) {
        Bitmap large_icon_bmp = ((BitmapDrawable) c.getResources()
                .getDrawable(largeIcon)).getBitmap();
        mNotifyBuilder.setLargeIcon(large_icon_bmp);
    }

    mNotifyBuilder.setContentIntent(detailsIntent);
    mNotifyBuilder.setVibrate(new long[] { 500, 1500 });
    mNotifyBuilder.setTicker(message);
    mNotifyBuilder.setContentText(message);

    // NOTIFY
    NotificationManager nm = (NotificationManager) c
            .getSystemService(Context.NOTIFICATION_SERVICE);
    nm.notify(notificationId, mNotifyBuilder.build());
}

他の回答を見た限りでは、私が見ている例外は、setSmallIcon()適切に呼び出されなかったときに発生します。

渡されるリソース ID がすべて正しいことを何度も確認しました。

ベストアンサー1

何が起こっていたかというと、PendingIntent バンドルにアイコンへの整数参照を含めていて、その整数が後で NotificationManager に投稿されるときに参照されていたのです。

整数参照を取得してから保留中のインテントがオフになるまでの間に、アプリが更新され、すべての描画可能参照が変更されました。正しい描画可能を参照していた整数が、間違った描画可能を参照するか、まったく参照しなくなりました (まったく参照していないため、このクラッシュが発生します)

おすすめ記事