我有一个Xamarin Forms应用程序,该应用程序会引发Android通知,但是我无法创建一个简单的页面,当用户单击通知时该页面将与用户进行交互。
我了解在Xamarin.Forms中只有1个 Activity ,因此挂起的Intent必须是该mainActivity的 Activity

我已经将LaunchMode设置为SingleTop,并且将Intent Filter设置为与未决Intent中使用的Intent名称相匹配。

现在,当我单击通知时,我确实被路由到MainActivity的OnResume,但是我不知道如何:
1)认识到我由于单击通知而参加了此 Activity -我尝试将Extra添加到待处理的Intent中,但是当我检查此Intent时,它不存在。
2)即使我知道由于单击通知导致我处于 Activity 中,如何从 Activity 中启动特定页面。我是Xamarin的新手,但看不到如何导航到内容页面或访问导航堆栈。

这一定是一个非常普通的用例,但是我找不到任何相关的东西。

最佳答案

确保已在LaunchMode.SingleTop上设置了MainActivity:

LaunchMode.SingleTop

[Activity(~~~, LaunchMode = LaunchMode.SingleTop, ~~~]
public class MainActivity
{
   ~~~~

在您的MainActivity(FormsAppCompatActivity子类)中,添加OnNewIntent覆盖:

OnNewIntent:
protected override void OnNewIntent(Intent intent)
{
    base.OnNewIntent(intent);
    NotificationClickedOn(intent);
}

现在,您可以检查intent.Action/intent.HasExtra以确定发送的是您的通知,然后进行处理。使用Xamarin.Forms最简单的方法是使用MessagingCenter发送一条在.NetStd/PCL Xamarin.Forms代码库中订阅的消息。

NotificationClickedOn:
void NotificationClickedOn(Intent intent)
{
    if (intent.Action == "ASushiNotification" && intent.HasExtra("MessageFromSushiHangover"))
    {
        /// Do something now that you know the user clicked on the notification...

        var notificationMessage = intent.Extras.GetString("MessageFromSushiHangover");
        var winnerToast = Toast.MakeText(this, $"{notificationMessage}.\n\n🍣 Please send 2 BitCoins to SushiHangover to process your winning ticket! 🍣", ToastLength.Long);
        winnerToast.SetGravity(Android.Views.GravityFlags.Center, 0, 0);
        winnerToast.Show();
    }
}

发送通知示例:
void SendNotifacation()
{
    var title = "Winner, Winner, Chicken Dinner";
    var message = "You just won a million StackOverflow reputation points";

    var intent = new Intent(BaseContext, typeof(MainActivity));
    intent.SetAction("ASushiNotification");
    intent.PutExtra("MessageFromSushiHangover", message);
    var pending = PendingIntent.GetActivity(BaseContext, 0, intent, PendingIntentFlags.CancelCurrent);

    using (var notificationManager = NotificationManager.FromContext(BaseContext))
    {
        Notification notification;
        if (Android.OS.Build.VERSION.SdkInt < Android.OS.BuildVersionCodes.O)
        {
#pragma warning disable CS0618 // Type or member is obsolete
            notification = new Notification.Builder(BaseContext)
                                                        .SetContentTitle(title)
                                                        .SetContentText(message)
                                                        .SetAutoCancel(true)
                                                        .SetSmallIcon(Resource.Drawable.icon)
                                                        .SetDefaults(NotificationDefaults.All)
                                                        .SetContentIntent(pending)
                                                        .Build();
#pragma warning restore CS0618 // Type or member is obsolete
        }
        else
        {
            var myUrgentChannel = BaseContext.PackageName;
            const string channelName = "Messages from SushiHangover";

            NotificationChannel channel;
            channel = notificationManager.GetNotificationChannel(myUrgentChannel);
            if (channel == null)
            {
                channel = new NotificationChannel(myUrgentChannel, channelName, NotificationImportance.High);
                channel.EnableVibration(true);
                channel.EnableLights(true);
                channel.SetSound(
                    RingtoneManager.GetDefaultUri(RingtoneType.Notification),
                    new AudioAttributes.Builder().SetUsage(AudioUsageKind.Notification).Build()
                );
                channel.LockscreenVisibility = NotificationVisibility.Public;
                notificationManager.CreateNotificationChannel(channel);
            }
            channel?.Dispose();

            notification = new Notification.Builder(BaseContext)
                                                        .SetChannelId(myUrgentChannel)
                                                        .SetContentTitle(title)
                                                        .SetContentText(message)
                                                        .SetAutoCancel(true)
                                                        .SetSmallIcon(Resource.Drawable.icon)
                                                        .SetContentIntent(pending)
                                                        .Build();
        }
        notificationManager.Notify(1331, notification);
        notification.Dispose();
    }
}

10-07 19:27
查看更多