Xamarin Forms - Android - FCM - всплывающее уведомление, когда приложение находится на переднем плане, в фоновом режиме и закрыто - PullRequest
0 голосов
/ 09 июля 2020

Мне нужна помощь с уведомлениями android pu sh, пожалуйста. Для контекста я прочитал десятки сообщений о переполнении стека о том, как реализовать уведомления pu sh для android. Все сообщения, которые я видел, касаются только части проблемы. Мне удалось успешно получать уведомления pu sh и отображать уведомление, когда приложение находится на переднем плане или в фоновом режиме, но тогда это не работает, когда приложение закрыто. Чтобы уведомление отображалось в строке состояния, когда приложение закрыто, вам необходимо использовать объект «уведомление» в полезной нагрузке вместо объекта «данные».

Чего я пытаюсь достичь это - мне нужно уведомление в строке состояния, звук и уведомление, когда приложение находится в любом из этих состояний - передний план, фон и закрыто.

Каков секретный рецепт кода, полезная нагрузка json, и конфигурация манифеста, чтобы это произошло? Любое крупное приложение, которое у меня есть на моем телефоне - eBay, etsy, amazon и большинство приложений, которые я загружаю, может делать все это, поэтому это должно быть возможно независимо от того, что говорят некоторые из руководств fcm.

Вот наш метод onMessageReceived в FireBaseMessagingService:

  public override void OnMessageReceived(RemoteMessage message)
  {
    try
    {
        base.OnMessageReceived(message);
        string messageBody = string.Empty;
        string messageTitle = string.Empty;

        if (message.GetNotification() != null)
        {
            messageTitle = message.GetNotification().Title;
            messageBody = message.GetNotification().Body;
        }
        else
        {
            if (message.Data.Values.Count == 1)
            {
                messageTitle = "Alerts Occurred";
                messageBody = message.Data.Values.First();
            }
            else if (message.Data.Values.Count == 2)
            {
                messageTitle = message.Data.Values.ToList()[0];
                messageBody = message.Data.Values.ToList()[1];
            }
        }

        SendLocalNotification(messageTitle, messageBody);

    }
    catch (Exception e)
    {
        NotificationHubHelper.LogInfo($"Error receiving message on device: {e.Message}");
    }
  }

   private void SendLocalNotification(string title, string body)
  {
    try
    {
        _notificationBadgeCount++;
        var intent = new Intent(this, typeof(MainActivity));
        intent.AddFlags(ActivityFlags.ClearTop);
        intent.PutExtra("message", body);
        var pendingIntent = PendingIntent.GetActivity(this, 0, intent, PendingIntentFlags.OneShot);

        int notificationIconId = 
Resources.GetIdentifier(NotificationHubHelper.AndroidNotificationIconImage, "drawable", 
AppInfo.PackageName);
        NotificationHubHelper.LogInfo($"Found notification icon with id: {notificationIconId}");
        var notificationBuilder = new NotificationCompat.Builder(this, 
NotificationHubHelper.NotificationChannelName)
            .SetContentTitle(title)
            .SetSmallIcon(notificationIconId) //.SetSmallIcon(ApplicationInfo.Icon)
            .SetContentText(body)
            .SetAutoCancel(true)
            .SetShowWhen(false)
            .SetContentIntent(pendingIntent)
            .SetPriority((int)NotificationPriority.Max);

        if (Build.VERSION.SdkInt >= BuildVersionCodes.O)
        {
            notificationBuilder.SetChannelId(NotificationHubHelper.NotificationChannelName);
        }

        var notificationManager = NotificationManager.FromContext(this);
        notificationManager.Notify(0, notificationBuilder.Build());
        CrossBadge.Current.SetBadge(_notificationBadgeCount);
    }
    catch (Exception e)
    {
        NotificationHubHelper.LogInfo($"Error sending local notification on device: {e.Message}");
    }
 }

Вот наш манифест:

 <manifest xmlns:android="http://schemas.android.com/apk/res/android" android:versionCode="1" 
    android:versionName="1.0.9" package="HIDDEN_FROM_POST" android:installLocation="auto">
    <uses-sdk android:minSdkVersion="23" android:targetSdkVersion="29" />
    <application android:allowBackup="false" android:label="HIDDEN_FROM_POST" 
    android:icon="@drawable/HIDDEN_FROM_POST">
        <meta-data android:name="com.google.android.maps.v2.API_KEY" android:value="HIDDEN_FROM_POST" />
        <meta-data android:name="com.google.android.gms.version" 
    android:value="@integer/google_play_services_version" />
        <uses-library android:name="org.apache.http.legacy" android:required="false" />
        <provider android:name="android.support.v4.content.FileProvider" 
    android:authorities="${applicationId}.fileprovider" android:exported="false" 
    android:grantUriPermissions="true">
            <meta-data android:name="android.support.FILE_PROVIDER_PATHS" 
    android:resource="@xml/file_paths"></meta-data>
        </provider>
        <receiver android:name="com.google.firebase.iid.FirebaseInstanceIdInternalReceiver" 
    android:exported="false" />
        <receiver android:name="com.google.firebase.iid.FirebaseInstanceIdReceiver" 
    android:exported="true" android:permission="com.google.android.c2dm.permission.SEND">
            <intent-filter>
                <action android:name="com.google.android.c2dm.intent.RECEIVE" />
                <action android:name="com.google.android.c2dm.intent.REGISTRATION" />
                <category android:name="${applicationId}" />
            </intent-filter>
        </receiver>
    <meta-data
      android:name="com.google.firebase.messaging.default_notification_icon"
      android:resource="@drawable/HIDDEN_FROM_POST" />
    </application>
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" />
    <uses-permission android:name="android.permission.WAKE_LOCK" />
    <uses-permission android:name="android.permission.GET_ACCOUNTS" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.VIBRATE" />
    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.CAMERA" />
    <uses-feature android:name="android.hardware.camera" />
  <uses-permission android:name="com.anddoes.launcher.permission.UPDATE_COUNT"/>
  <uses-permission android:name="com.android.launcher.permission.READ_SETTINGS"/>
  <uses-permission android:name="com.android.launcher.permission.WRITE_SETTINGS"/>
  <uses-permission android:name="com.android.launcher.permission.INSTALL_SHORTCUT" />
  <uses-permission android:name="com.android.launcher.permission.UNINSTALL_SHORTCUT" />
  <uses-permission android:name="com.htc.launcher.permission.READ_SETTINGS" />
  <uses-permission android:name="com.htc.launcher.permission.UPDATE_SHORTCUT" /> 
  <uses-permission android:name="com.sec.android.provider.badge.permission.READ" />
  <uses-permission android:name="com.sec.android.provider.badge.permission.WRITE" />
  <uses-permission android:name="com.sonyericsson.home.permission.BROADCAST_BADGE" />
  <uses-permission android:name="com.sonymobile.home.permission.PROVIDER_INSERT_BADGE" />
</manifest>

И, наконец, вот последняя полезная нагрузка, которую мы попробовали:

   {
    "notification":{
      "title":"Portugal vs. Denmark",
      "body":"great match!"
    },
    "data":{
        "message":"this is a message",
        "title":"title"
    }
}

С помощью вышесказанного мы получаем уведомление в строке состояния, когда приложение закрыто, уведомление в строке состояния, когда приложение находится в фоновом режиме, и уведомление в строке состояния с уведомлением, когда приложение находится на переднем плане.

Как мы получаем уведомление о хедз-апе во всех сценариях ios?

Len

1 Ответ

0 голосов
/ 09 июля 2020

Это в основном то же, что и обычные уведомления. В Android версии 8.0 и после этого вы можете приостанавливать уведомления, только установив уровень важности IMPORTANCE_HIGH для важности канала уведомлений. Например:

NotificationChannel notificationChannel = new NotificationChannel("","",NotificationImportance.High);

Он также позволяет пользователям устанавливать уведомления ' уровень важности прямо на телефоне. Может быть реализована аварийная подвеска.

Для Android версий до 8.0 добавьте SetFullScreenIntent к notificationBuilder

notificationBuilder.SetFullScreenIntent(pendingIntent,true); 

Или активируйте звуковые и вибрационные подсказки.

...