gpt4 book ai didi

push-notification - Phonegap Build,使用 Firebase,通知图标只是白色/灰色方 block

转载 作者:行者123 更新时间:2023-12-05 07:17:00 25 4
gpt4 key购买 nike

很多人一直在问这个问题,但现在所有的解决方案似乎都已经过时了。我尝试了所有解决方案,但仍然无法使用 Phongap Build CLI9.0.0、用于推送通知的 Firebase Cloud 和 phonegap-plugin-push 2.1.3。

我可以毫无问题地将图标添加到我的应用程序中。安装和加载应用程序时会按预期显示正确的 Logo 。但是,当我收到推送通知时,托盘区域中的图标只是一个白色/灰色方 block 。

到目前为止,这是我尝试过的:

我的图标是一个透明背景的白色圆圈。它称为 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 个是我的 Logo 图标,而不是通知图标)...

<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。

到目前为止,我使用它的唯一方法是删除其他 Logo 图标并只使用通知图标 - 但通知图标也显示为图标。

我认为也许只有较小的图标会用作通知图标,所以我尝试使用 ldpi、mdpi 和 hdpi 的通知图标以及 xhdpi、xxhdpi 和 xxxhdpi 的主 Logo ,但无论我尝试什么结果是 notification_icon 有效但它也用作加载应用程序时的 Logo ,或者通知图标被忽略, Logo 用作加载图标,白色/灰色方 block 用作通知图标。

有人能帮忙吗?

最佳答案

我想通了。解决方案花了太长时间才找到,但本质上它真的很简单。为了帮助其他人解决同样的问题(现在是 2019 年,Android 目标 SDK 是 28),使用 Phonegap Build 2、Phonegap cli-9.0.0 并使用 Firebase (FCM) 推送通知:

1) 从 PushNotification.init javascript 中删除您的自定义通知图标。您应该只在此处添加您的 senderID。其余的现在由您的推送负载处理

2) 在您的负载中(我使用我自己的 PHP 通知发送器,遵循 Firebase API 信息),在“通知”参数下添加您的自定义图标名称:

            $notification = array
(
'body' => $message,
'title' => $titlenotification,
"icon" => 'notification_icon',
"content_available" => "1",
"iconColor" => "#e73439",
);

3) 确保您的图标是透明背景的白色形状。另存为.png。确保名称与您的“图标”值完全匹配。在这种情况下: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

关于push-notification - Phonegap Build,使用 Firebase,通知图标只是白色/灰色方 block ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58958568/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com