Я пытался реализовать повторяющиеся локальные уведомления в моем приложении для Android, и я добился этого довольно хорошо (я верю), но когда я хочу щелкнуть свое уведомление и выполнить в нем логику, оно 1. Не запускает MainActivity (не запусти меня в приложение) 2. Не выполняет никакой логики

В моем файле MainActivity.cs у меня для LaunchMode установлено значение SingleTop, а у меня есть соответствующее переопределение метода OnNewIntent (), который будет получать мое уведомление при нажатии на него, но он просто не выполняет этот метод даже

Я отправляю свое уведомление с BroadcastReceiver, который я вызываю в другом классе, который НЕ является MainActivity.cs (потому что я видел, что многие люди так делают) благодаря моей реализации интерфейса, который связывается с моим проектом общего кода.

Метод, который вызывает уведомление:

public void ScheduleNotification(string title, string message, long seconds)
    {
        if (!channelInitialized)
            CreateNotificationChannel();

        NotificationReciever.title = title;
        NotificationReciever.message = message;
        AlarmManager alarmManager = (AlarmManager)AndroidApp.Context.GetSystemService(Context.AlarmService);
        Intent intent = new Intent(AndroidApp.Context, typeof(NotificationReciever));
        intent.PutExtra(TitleKey, title);
        intent.PutExtra(MessageKey, message);
        intent.AddFlags(ActivityFlags.ClearTop);

        PendingIntent pendingIntent = PendingIntent.GetBroadcast(AndroidApp.Context, 0, intent, PendingIntentFlags.UpdateCurrent);

        alarmManager.SetRepeating(AlarmType.ElapsedRealtimeWakeup, SystemClock.ElapsedRealtime() + seconds * 1000, 2000, pendingIntent);
    }

Мой вещательный приемник:

[BroadcastReceiver(Enabled =true)]
    public class NotificationReciever : BroadcastReceiver
    {
        const string channelId = "default";
        public static string title = "";
        public static string message = "";
        const string channelName = "Default";
        const string channelDescription = "The default channel for notifications.";
        const int pendingIntentId = 0;

        public const string TitleKey = "title";
        public const string MessageKey = "message";

        int messageId = -1;
        NotificationManager manager;
        public override void OnReceive(Context context, Intent intent)
        {
            PendingIntent pendingIntent = PendingIntent.GetActivity(AndroidApp.Context, pendingIntentId, intent, PendingIntentFlags.OneShot);

            NotificationCompat.Builder builder = new NotificationCompat.Builder(AndroidApp.Context, channelId)
               .SetContentIntent(pendingIntent)
               .SetContentTitle(title)
               .SetContentText(message)
               .SetLargeIcon(BitmapFactory.DecodeResource(AndroidApp.Context.Resources, Resource.Drawable.OlympiaLogo))
               .SetSmallIcon(Resource.Drawable.OlympiaLogo)
               .SetDefaults((int)NotificationDefaults.Sound | (int)NotificationDefaults.Vibrate);

            manager = (NotificationManager)context.GetSystemService(AndroidApp.NotificationService);
            var notification = builder.Build();
            manager.Notify(messageId, notification);
        }
    }

И, наконец, мой MainActivity.cs (тот, который не запускается, когда я нажимаю на уведомление):

[Activity(Label = "LocalNotificationsApp", Icon = "@mipmap/icon", Theme = "@style/MainTheme", MainLauncher = true, ConfigurationChanges = ConfigChanges.ScreenSize | ConfigChanges.Orientation, LaunchMode = LaunchMode.SingleTop)]
    public class MainActivity : global::Xamarin.Forms.Platform.Android.FormsAppCompatActivity
    {

    protected override void OnCreate(Bundle savedInstanceState)
    {
        TabLayoutResource = Resource.Layout.Tabbar;
        ToolbarResource = Resource.Layout.Toolbar;

        base.OnCreate(savedInstanceState);

        Xamarin.Essentials.Platform.Init(this, savedInstanceState);
        CrossCurrentActivity.Current.Init(this, savedInstanceState);
        global::Xamarin.Forms.Forms.Init(this, savedInstanceState);
        CreateNotificationFromIntent(Intent);

        LoadApplication(new App());
        //
        //AndroidNotificationManager.alarmManager = (AlarmManager)GetSystemService(Context.AlarmService);
    }
    public override void OnRequestPermissionsResult(int requestCode, string[] permissions, [GeneratedEnum] Android.Content.PM.Permission[] grantResults)
    {
        Xamarin.Essentials.Platform.OnRequestPermissionsResult(requestCode, permissions, grantResults);

        base.OnRequestPermissionsResult(requestCode, permissions, grantResults);
    }

    protected override void OnNewIntent(Intent intent)
    {
        CreateNotificationFromIntent(intent);
    }

    void CreateNotificationFromIntent(Intent intent)
    {
        if (intent?.Extras != null)
        {
            string title = intent.Extras.GetString(AndroidNotificationManager.TitleKey);
            string message = intent.Extras.GetString(AndroidNotificationManager.MessageKey);
            if(title != null && message != null)
                DependencyService.Get<INotificationManager>().ReceiveNotification(title, message);
        }
    }
}
0
Andrés Quiroz Valdovinos 19 Дек 2019 в 22:55

1 ответ

Лучший ответ

Попробуйте создать новое намерение и использовать основное действие вместо повторного использования действия, переданного в OnReceived

[BroadcastReceiver(Enabled =true)]
public class NotificationReciever : BroadcastReceiver
{
    const string channelId = "default";
    public static string title = "";
    public static string message = "";
    const string channelName = "Default";
    const string channelDescription = "The default channel for notifications.";
    const int pendingIntentId = 0;

    public const string TitleKey = "title";
    public const string MessageKey = "message";

    int messageId = -1;
    NotificationManager manager;
    public override void OnReceive(Context context, Intent intent)
    {
        // pull stuff from old intent.
        string title = intent.Extras.GetString(TitleKey);
        string message = intent.Extras.GetString(MessageKey);

        // Instead of using intent that is passed in. Create a new one.
        Intent mainIntent = new Intent(AndroidApp.Context, typeof(MainActivity));
        var bundle = new Bundle();
        bundle.PutString(TitleKey, title);
        bundle.PutString(MessageKey, message);
        mainIntent.PutExtras(bundle);
        mainIntent.AddFlags(ActivityFlags.ClearTop);

        PendingIntent pendingIntent = PendingIntent.GetActivity(AndroidApp.Context, pendingIntentId, intent, PendingIntentFlags.UpdateCurrent);

        NotificationCompat.Builder builder = new NotificationCompat.Builder(AndroidApp.Context, channelId)
            .SetContentIntent(pendingIntent)
            .SetContentTitle(title)
            .SetContentText(message)
            .SetLargeIcon(BitmapFactory.DecodeResource(AndroidApp.Context.Resources, Resource.Drawable.OlympiaLogo))
            .SetSmallIcon(Resource.Drawable.OlympiaLogo)
            .SetDefaults((int)NotificationDefaults.Sound | (int)NotificationDefaults.Vibrate);

        manager = (NotificationManager)context.GetSystemService(AndroidApp.NotificationService);
        var notification = builder.Build();
        manager.Notify(messageId, notification);
    }
}
0
Andres Castro 19 Дек 2019 в 20:44