我有一个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();
}
}