OnStartCommand / OnCreate未调用

时间:2019-06-10 18:39:56

标签: c# xamarin.android visual-studio-2017

我创建了一个在前台服务中运行SignalR的服务。当启动服务时,我没有收到任何错误,但是从未调用过OnCreate和OnStartCommand。是的,我检查了清单中的ForeGround_Service。我用来启动该服务的代码是:

    public void StartForegroundServiceComapt<SignalRSrv>(Context context, Bundle args = null) where SignalRSrv : Service
    {
        var intent = new Intent(context, typeof(SignalRSrv));
        if (args != null)
        {
            intent.PutExtras(args);
        }

        if (Android.OS.Build.VERSION.SdkInt >= Android.OS.BuildVersionCodes.O)
        {
            context.StartForegroundService(intent);
        }
        else
        {
            context.StartService(intent);
        }
    }

服务代码为:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Acr.UserDialogs;
using Android.App;
using Android.Content;
using Android.OS;
using Android.Runtime;
using Android.Support.V4.App;
using Android.Views;
using Android.Widget;
using Java.Lang;
using Java.Util.Concurrent;
using Microsoft.AspNet.SignalR.Client;
using Microsoft.AspNet.SignalR.Client.Transports;


namespace MyService_Android
{
    public class SignalRSrv : Service
    {
        private bool InstanceFieldsInitialized = false;

        private void InitializeInstanceFields()
        {
            mBinder = new LocalBinder(this);
        }

        private Handler mHandler; // to display Toast message
        private IBinder mBinder; // Binder given to clients
        private SignalRSingleton mInstance;
        internal const string MY_ACTION = "MY_ACTION";

        public SignalRSrv()
        {
            if (!InstanceFieldsInitialized)
            {
                InitializeInstanceFields();
                InstanceFieldsInitialized = true;
            }

        }

        public override void OnCreate()
        {
            base.OnCreate();
            mInstance = SignalRSingleton.getInstance();
            mHandler = new Handler(Looper.MainLooper);
        }

        public override void OnDestroy()
        {
            mInstance.mHubConnection.Stop();
            base.OnDestroy();
        }


        public override IBinder OnBind(Intent intent)
        {
            Bundle bundlee = intent.GetBundleExtra("TheBundle");
            startSignalR();
            return mBinder;
        }

        private void startSignalR()
        {
            mInstance.setmHubConnection();
            mInstance.setHubProxy();

            try
            {
                // Connect the client to the hup
                mInstance.mHubConnection.Start();
                // Set the event handler
                mInstance.WireUp();

            }
            catch (System.Exception e) when (e is InterruptedException || e is ExecutionException)
            {
                //opps
                var x = 1;
                return;
            }

        }

        public async void showMessage(string message)
        {

            var result = await UserDialogs.Instance.ConfirmAsync(new ConfirmConfig
            {
                Message = "Text Message from OML: " + System.Environment.NewLine + message,
                OkText = "Ok",

            });
            if (result)
            {
                // do something
                var x = message;
            }
        }

        public override StartCommandResult OnStartCommand(Intent intent, StartCommandFlags flags, int startId)
        {
            if (intent.Action.Equals(Constants.ACTION_START_SERVICE))
            {
                if (InstanceFieldsInitialized)
                {

                    //Log.Info(TAG, "OnStartCommand: The service is already running.");
                }
                else
                {
                    //Log.Info(TAG, "OnStartCommand: The service is starting.");
                    startSignalR();
                    RegisterForegroundService();
                    InstanceFieldsInitialized = true;
                }
            }
            else if (intent.Action.Equals(Constants.ACTION_STOP_SERVICE))
            {
                StopSelf();
                InstanceFieldsInitialized = false;

            }
            else if (intent.Action.Equals(Constants.ACTION_RESTART))
            {

            }

            // This tells Android not to restart the service if it is killed to reclaim resources.
            return StartCommandResult.Sticky;
        }

        void RegisterForegroundService()
        {
            var notification = new NotificationCompat.Builder(this)
                .SetContentTitle(Resources.GetString(Resource.String.app_name))
                .SetContentText(Resources.GetString(Resource.String.notification_text))
                .SetSmallIcon(Resource.Drawable.alert_box)
                .SetOngoing(true)
                .Build();


            // Enlist this instance of the service as a foreground service
            StartForeground(Constants.SERVICE_RUNNING_NOTIFICATION_ID, notification);
        }

    }
    public class LocalBinder : Binder
    {
        private readonly SignalRSrv outerInstance;

        public LocalBinder(SignalRSrv outerInstance)
        {
            this.outerInstance = outerInstance;
        }

        public virtual SignalRSrv Service
        {
            get
            {
                // Return this instance of SignalRService so clients can call public methods
                return outerInstance;
            }
        }
    }

我在调试器中设置了断点,但它们从未被击中。在RegisterForegroundService()中设置的图标从不显示(由于服务未实例化,因此不会感到惊讶)。

1 个答案:

答案 0 :(得分:0)

嗯,事实证明这是一个简单的答案(不是全部吗?)。我将[Service]添加到服务类IE的顶部;

[Service]
public class SignalRSrv : Service
{
   ..... all my other stuff .....
}

现在它按预期命中了OnCreate和OnStartCommand。 没有理由怀疑我为什么喝酒....