Phonegap Build,使用 Firebase,通知图标只是 white/grey 方形
Phonegap Build , using Firebase, notification icon is just white/grey square
很多人一直在问这个问题,但现在所有的解决方案似乎都已经过时了。我尝试了所有解决方案,但仍然无法使用 Phongap Build CLI9.0.0、用于推送通知的 Firebase Cloud 和 phonegap-plugin-push 2.1.3。
我可以毫无问题地向我的应用程序添加图标。安装和加载应用程序时会按预期显示正确的徽标。但是,当我收到推送通知时,托盘区域中的图标只是一个 white/grey 方块。
到目前为止,这是我尝试过的:
我的图标是透明背景的白色圆圈。
它被称为notification_icon.png。
我制作了 6 个不同尺寸的版本以满足 ldpi、hdpi 等要求。
我已经像这样将图标名称添加到推送通知初始化中...
var push = PushNotification.init({
android: {
senderID: senderId,
iconColor: "#e73439",
alert: true,
badge: true,
icon: 'notification_icon',
sound: true,
vibrate: true,
},
ios: {
senderID: senderId,
iconColor: '#e73439',
alert: true,
badge: true,
icon: 'notification_icon',
sound: true,
vibration: true,
},
windows: {}
});
我已将图标的所有变体添加到我的 config.xml 中(前 6 个是我的徽标图标,而不是通知图标)...
<platform name="android">
<icon density="ldpi" src="icons/android/icon36x36.png" />
<icon density="mdpi" src="icons/android/icon48x48.png" />
<icon density="hdpi" src="icons/android/icon72x72.png" />
<icon density="xhdpi" src="icons/android/icon96x96.png" />
<icon density="xxhdpi" src="icons/android/icon144x144.png" />
<icon density="xxxhdpi" src="icons/android/icon192x192.png" />
<icon src="icons/notification_icon96x96.png" target="res/drawable/notification_icon.png" />
<icon density="ldpi" src="icons/notification_icon36x36.png" target="res/drawable-ldpi/notification_icon.png" />
<icon density="mdpi" src="icons/notification_icon48x48.png" target="res/drawable-mdpi/notification_icon.png" />
<icon density="hdpi" src="icons/notification_icon72x72.png" target="res/drawable-hdpi/notification_icon.png" />
<icon density="xhdpi" src="icons/notification_icon96x96.png" target="res/drawable-xhdpi/notification_icon.png" />
<icon density="xxhdpi" src="icons/notification_icon144x144.png" target="res/drawable-xxhdpi/notification_icon.png" />
<icon density="xxxhdpi" src="icons/notification_icon192x192.png" target="res/drawable-xxxhdpi/notification_icon.png" />
</platform>
我什至尝试像这样将图标添加到 FCM 负载中...
$notification = array
(
'body' => $message,
'title' => $titlenotification,
"icon" => 'notification_icon',
"content_available" => "1",
"image" => "push_notification" ,
"icon" => "push_notification" ,
"color" => "#e73439" ,
);
$data = array
(
"title" => $titlenotification,
"message" => $message,
"content_available" => "1",
);
$fields = array
(
'registration_ids' => $registrationtokens,
'notification' => $notification,
'data' => $data,
"priority" => "high",
"content_available" => true,
);
....etc
我正在使用 Phponegap build 进行编译,所以我无法编辑任何其他 xml 部分,只能编辑 config.xml.
到目前为止,我使用它的唯一方法是删除其他徽标图标并仅使用通知图标 - 但是通知图标显示为 main图标也是。
我想也许只有较小的图标会被用作通知图标,所以我尝试使用 ldpi、mdpi 和 hdpi 的通知图标以及 xhdpi、xxhdpi 和 xxxhdpi 的主徽标,但不管我怎样尝试结果是 notification_icon 有效但它也用作加载应用程序时的徽标,或者通知图标被忽略,徽标用作加载图标和 white/grey 方块用于通知图标。
有人能帮忙吗?
我已经弄明白了。解决方案花了太长时间才找到,但本质上它真的很简单。为了帮助其他人解决同样的问题(现在是 2019 年,Android 目标 SDK 是 28),请使用 Phonegap Build 2、Phonegap cli-9.0.0 并使用 Firebase (FCM) 推送通知:
1) 从 PushNotification.init javascript 中删除您的自定义通知图标。您应该只在此处添加您的 senderID。其余部分现在由您的推送负载处理
2) 在您的负载中(我使用我自己的 PHP 通知发送器,跟随 Firebase API 信息),在 "notification" 参数下添加您的自定义图标名称:
$notification = array
(
'body' => $message,
'title' => $titlenotification,
"icon" => 'notification_icon',
"content_available" => "1",
"iconColor" => "#e73439",
);
3) 确保您的图标是透明背景的白色形状。另存为.png。确保名称与您的 "icon" 值完全匹配。在这种情况下:notification_icon.png
4) 创建图标的所有密度版本。您可以在此处执行此操作:https://romannurik.github.io/AndroidAssetStudio/index.html ....这将创建所有必要的尺寸。
5) 将图标保存在各自的文件夹中(例如 /drawable-mdpi/notification_icon.png)。将这些文件夹放在本地以下位置:
/你的项目文件夹/www/locales
6) 在您的 config.xml 中添加以下行(假设 notification_icon.png 是您的图片名称)
<platform name="android">
<resource-file src="locales/android/notification_icon.png" target="app/src/main/res/drawable/notification_icon.png" />
<resource-file src="locales/android/drawable-mdpi/notification_icon.png" target="app/src/main/res/drawable-mdpi/notification_icon.png" />
<resource-file src="locales/android/drawable-hdpi/notification_icon.png" target="app/src/main/res/drawable-hdpi/notification_icon.png" />
<resource-file src="locales/android/drawable-xhdpi/notification_icon.png" target="app/src/main/res/drawable-xhdpi/notification_icon.png" />
<resource-file src="locales/android/drawable-xxhdpi/notification_icon.png" target="app/src/main/res/drawable-xxhdpi/notification_icon.png" />
<!-- Configure Firebase -->
<config-file parent="/manifest/application" target="AndroidManifest.xml">
<meta-data android:name="com.google.firebase.messaging.default_notification_icon" android:resource="@drawable/notification_icon" />
</config-file>
</platform>
...注意目标值,以及末尾的额外配置文件位。非常重要的部分。
这适用于 Android 6、7、8 和 9。Ios 通知图标对我来说是个谜,我认为 Phonegap 目前不支持这个,但无论如何,它适用于 Android.
可在此处找到更多信息:https://arnesson.github.io/cordova-plugin-firebase/docs/NOTIFICATIONS.html
很多人一直在问这个问题,但现在所有的解决方案似乎都已经过时了。我尝试了所有解决方案,但仍然无法使用 Phongap Build CLI9.0.0、用于推送通知的 Firebase Cloud 和 phonegap-plugin-push 2.1.3。
我可以毫无问题地向我的应用程序添加图标。安装和加载应用程序时会按预期显示正确的徽标。但是,当我收到推送通知时,托盘区域中的图标只是一个 white/grey 方块。
到目前为止,这是我尝试过的:
我的图标是透明背景的白色圆圈。 它被称为notification_icon.png。 我制作了 6 个不同尺寸的版本以满足 ldpi、hdpi 等要求。 我已经像这样将图标名称添加到推送通知初始化中...
var push = PushNotification.init({
android: {
senderID: senderId,
iconColor: "#e73439",
alert: true,
badge: true,
icon: 'notification_icon',
sound: true,
vibrate: true,
},
ios: {
senderID: senderId,
iconColor: '#e73439',
alert: true,
badge: true,
icon: 'notification_icon',
sound: true,
vibration: true,
},
windows: {}
});
我已将图标的所有变体添加到我的 config.xml 中(前 6 个是我的徽标图标,而不是通知图标)...
<platform name="android">
<icon density="ldpi" src="icons/android/icon36x36.png" />
<icon density="mdpi" src="icons/android/icon48x48.png" />
<icon density="hdpi" src="icons/android/icon72x72.png" />
<icon density="xhdpi" src="icons/android/icon96x96.png" />
<icon density="xxhdpi" src="icons/android/icon144x144.png" />
<icon density="xxxhdpi" src="icons/android/icon192x192.png" />
<icon src="icons/notification_icon96x96.png" target="res/drawable/notification_icon.png" />
<icon density="ldpi" src="icons/notification_icon36x36.png" target="res/drawable-ldpi/notification_icon.png" />
<icon density="mdpi" src="icons/notification_icon48x48.png" target="res/drawable-mdpi/notification_icon.png" />
<icon density="hdpi" src="icons/notification_icon72x72.png" target="res/drawable-hdpi/notification_icon.png" />
<icon density="xhdpi" src="icons/notification_icon96x96.png" target="res/drawable-xhdpi/notification_icon.png" />
<icon density="xxhdpi" src="icons/notification_icon144x144.png" target="res/drawable-xxhdpi/notification_icon.png" />
<icon density="xxxhdpi" src="icons/notification_icon192x192.png" target="res/drawable-xxxhdpi/notification_icon.png" />
</platform>
我什至尝试像这样将图标添加到 FCM 负载中...
$notification = array
(
'body' => $message,
'title' => $titlenotification,
"icon" => 'notification_icon',
"content_available" => "1",
"image" => "push_notification" ,
"icon" => "push_notification" ,
"color" => "#e73439" ,
);
$data = array
(
"title" => $titlenotification,
"message" => $message,
"content_available" => "1",
);
$fields = array
(
'registration_ids' => $registrationtokens,
'notification' => $notification,
'data' => $data,
"priority" => "high",
"content_available" => true,
);
....etc
我正在使用 Phponegap build 进行编译,所以我无法编辑任何其他 xml 部分,只能编辑 config.xml.
到目前为止,我使用它的唯一方法是删除其他徽标图标并仅使用通知图标 - 但是通知图标显示为 main图标也是。
我想也许只有较小的图标会被用作通知图标,所以我尝试使用 ldpi、mdpi 和 hdpi 的通知图标以及 xhdpi、xxhdpi 和 xxxhdpi 的主徽标,但不管我怎样尝试结果是 notification_icon 有效但它也用作加载应用程序时的徽标,或者通知图标被忽略,徽标用作加载图标和 white/grey 方块用于通知图标。
有人能帮忙吗?
我已经弄明白了。解决方案花了太长时间才找到,但本质上它真的很简单。为了帮助其他人解决同样的问题(现在是 2019 年,Android 目标 SDK 是 28),请使用 Phonegap Build 2、Phonegap cli-9.0.0 并使用 Firebase (FCM) 推送通知:
1) 从 PushNotification.init javascript 中删除您的自定义通知图标。您应该只在此处添加您的 senderID。其余部分现在由您的推送负载处理
2) 在您的负载中(我使用我自己的 PHP 通知发送器,跟随 Firebase API 信息),在 "notification" 参数下添加您的自定义图标名称:
$notification = array
(
'body' => $message,
'title' => $titlenotification,
"icon" => 'notification_icon',
"content_available" => "1",
"iconColor" => "#e73439",
);
3) 确保您的图标是透明背景的白色形状。另存为.png。确保名称与您的 "icon" 值完全匹配。在这种情况下:notification_icon.png
4) 创建图标的所有密度版本。您可以在此处执行此操作:https://romannurik.github.io/AndroidAssetStudio/index.html ....这将创建所有必要的尺寸。
5) 将图标保存在各自的文件夹中(例如 /drawable-mdpi/notification_icon.png)。将这些文件夹放在本地以下位置:
/你的项目文件夹/www/locales
6) 在您的 config.xml 中添加以下行(假设 notification_icon.png 是您的图片名称)
<platform name="android">
<resource-file src="locales/android/notification_icon.png" target="app/src/main/res/drawable/notification_icon.png" />
<resource-file src="locales/android/drawable-mdpi/notification_icon.png" target="app/src/main/res/drawable-mdpi/notification_icon.png" />
<resource-file src="locales/android/drawable-hdpi/notification_icon.png" target="app/src/main/res/drawable-hdpi/notification_icon.png" />
<resource-file src="locales/android/drawable-xhdpi/notification_icon.png" target="app/src/main/res/drawable-xhdpi/notification_icon.png" />
<resource-file src="locales/android/drawable-xxhdpi/notification_icon.png" target="app/src/main/res/drawable-xxhdpi/notification_icon.png" />
<!-- Configure Firebase -->
<config-file parent="/manifest/application" target="AndroidManifest.xml">
<meta-data android:name="com.google.firebase.messaging.default_notification_icon" android:resource="@drawable/notification_icon" />
</config-file>
</platform>
...注意目标值,以及末尾的额外配置文件位。非常重要的部分。
这适用于 Android 6、7、8 和 9。Ios 通知图标对我来说是个谜,我认为 Phonegap 目前不支持这个,但无论如何,它适用于 Android.
可在此处找到更多信息:https://arnesson.github.io/cordova-plugin-firebase/docs/NOTIFICATIONS.html