目录
- 1、背景说明
- 1.1 开发环境
- 1.2 实现效果
- 1.2.1 推送的界面
- 1.2.2 推送的设置
- 1.2.3 推送的功能实现
- 1.2.3.1、`Activity`的设置【重要】
- 1.2.3.2、代码的实现
- 2、源码下载
- 3、总结
- 4、参考资料
1、背景说明
在App开发中,通知(或消息)的推送,是必须要有的功能。若在纯互联网的环境中,可以使用第三方的通知推送的功能,例如:小米推送、极光推送等,这个可以参考第三方的使用手册既可。但是在局域网中,例如医院内部的局域网中,则无法使用第三方的通知推送。因此在局域网环境中实现App通知推送的功能,就非常重要和关键。
本文将分为上下两部分。第一部分主要阐述Xamarin.Android的通知推送的功能实现。第二部分阐述如何在局域网环境下实现推送,并借助第一部分消息推送,从而实现整体的通知推送。
1.1 开发环境
使用VS2022社区版17.10.1,其中Xamarin为17.10.0.110
1.2 实现效果
Xamarin.Android中实现通知推送与Android基本一致。实现的效果如下:
图1 为主界面,点击右下角信封按钮,则系统会进行消息推送(主界面为:MainActivity
)
图2 系统收到推送后,在状态栏中弹出的推送内容
图3 当点击状态栏中的推送消息时,跳转到该推送的详细说明页面(即后续的NotificationDetailInfoActivity
)
图4 当在推送详细页面(NotificationDetailInfoActivity
)点击返回
按钮后,App返回至第二个Activity(即:SecondActivity
)
图5 在图4的界面上(即SecondActivity
),点击返回按钮后,App返回至主界面(即MainActivity
)
1.2.1 推送的界面
在整个工程中,涉及到3个Activity:MainActivity
、SecondActivity
、NotificationDetailInfoActivity
。如下图6所示
图6 工程涉及到的三个Activity
1.2.2 推送的设置
因为推送是在Activity
中发生,所以需要再Activity
的OnCreate
方法中初始化通知设置
(NotificationChannel
)
private string CHANNEL_ID = "20000";
protected override void OnCreate(Bundle savedInstanceState)
{base.OnCreate(savedInstanceState);//初始化一个ChannelCreateNotificationChannel();
}void CreateNotificationChannel()
{if (Build.VERSION.SdkInt < BuildVersionCodes.O){// Notification channels are new in API 26 (and not a part of the// support library). There is no need to create a notification// channel on older versions of Android.return;}var channelName = Resources.GetString(Resource.String.second_channel_name);var channelDescription = GetString(Resource.String.second_channel_description);var channel = new NotificationChannel(CHANNEL_ID, channelName, NotificationImportance.Default){Description = channelDescription};var notificationManager = (NotificationManager)GetSystemService(NotificationService);notificationManager.CreateNotificationChannel(channel);
}
其中会涉及到Channel
的名称和描述。也就是Resource.String.second_channel_name
和Resource.String.second_channel_description
。这部分信息在Strings.xml
中。具体如下:
<resources><string name="app_name">通知推送Demo</string><string name="action_settings">Settings</string><string name="channel_name">推送测试的名称</string><string name="channel_description">用于说明本推送的具体内容</string><string name="second_channel_name">第二个推送的名称</string><string name="second_channel_description">第二个用于说明推送的说明性文字(例如:本推送用于推送患者的用药服用信息!)</string>
</resources>
在MainActivity
、SecondActivity
中的OnCreate
方法中都应用,因此效果如下
图7 在MainActivity
、SecondActivity
设置通知后,可以在手机的通知界面看到这两个推送的设置
图8 这个是MainActivity
中推送设置
图8 这个是SecondActivity
中推送设置详细信息界面,可以看到标题和提示的内容
1.2.3 推送的功能实现
1.2.3.1、Activity
的设置【重要】
若要设置返回时,按指定的顺序返回,则必须要设置Activity
的ParentActivity
属性。在Android
原生开发中,是在AndroidManifest.xml
进行设置的。设置一般是这样子的:
<activity android:name=".MessageActivity" android:parentActivityName=".MainActivity"/>
但是,在Xamarin.Android中,没法在AndroidManifest.xml
设置,需要在Activity.cs
中定义。
//在这儿设置******【重要】
[Activity(Label = "SecondActivity", ParentActivity = typeof(MainActivity))]
public class SecondActivity : Activity
{private TextView tvTitle;private string CHANNEL_ID = "20000";protected override void OnCreate(Bundle savedInstanceState){base.OnCreate(savedInstanceState);// Create your application hereCreateNotificationChannel();//设置推送的通知}....
这个地方是最特殊的地方,一定要注意。
在本项目中,将NotificationDetailInfoActivity
的ParentActivity
设为SecondActivity
;而SecondActivity
的ParentActivity
设置为MainActivity
。
1.2.3.2、代码的实现
以上设置完成后,便可以在按钮的click方法中,实现消息的推送及实现,代码如下:
private void FabOnClick(object sender, EventArgs eventArgs)
{//View view = (View) sender;//Snackbar.Make(view, "Replace with your own action", Snackbar.LengthLong)// .SetAction("Action", (View.IOnClickListener)null).Show();//第二步,在某个地方触发这个通知(此处是点击按钮)//点击推送通知后,要调用起来的ActivityIntent intent = new Intent(this, typeof(NotificationDetailInfoActivity));//传递的数据。也可以使用Bundle,可以搜索Bundle传值intent.PutExtra("message", "附加的详细信息,用于展示提示的具体内容!");//创建TaskStackBuilder,用于形成任务链,就是点击通知后,后续的返回界面等设置Android.App.TaskStackBuilder stackBuilder = Android.App.TaskStackBuilder.Create(this);//1、在Activity中设置ParentActivity属性。在Android的原生开发中,是在Manifest中设置,//但是在Xamarin中,需要直接在Activity中设置//2、直接调用AddNextIntentWithParentStack方法既可stackBuilder.AddNextIntentWithParentStack(intent);//网络上的设置,但在Xamarin中没有作用//stackBuilder.AddParentStack(Java.Lang.Class.FromType(typeof(MainActivity)));//stackBuilder.AddParentStack(Java.Lang.Class.FromType(typeof(SecondActivity)));//stackBuilder.AddNextIntent(intent);//设置PendingIntentconst int pendingIntentId = 0;PendingIntent pendingIntent =stackBuilder.GetPendingIntent(pendingIntentId, PendingIntentFlags.UpdateCurrent);NotificationCompat.Builder builder = new NotificationCompat.Builder(this, CHANNEL_ID).SetContentIntent(pendingIntent).SetContentTitle("推送的标题内容") //1.SetContentText("推送的具体内容信息") //2.SetAutoCancel(true) //设置自动取消.SetWhen(Java.Lang.JavaSystem.CurrentTimeMillis()).SetSmallIcon(Resource.Drawable.zl001);//调用通知Notification notification = builder.Build();NotificationManager notificationManager = GetSystemService(Context.NotificationService) as NotificationManager;const int notificationId = 1;notificationManager.Notify(notificationId, notification);
}
代码说明:
1、网上查找的资料(设置微软的官网上),在设置返回时,是如下面代码设置的。
//stackBuilder.AddParentStack(Java.Lang.Class.FromType(typeof(MainActivity)));
//stackBuilder.AddParentStack(Java.Lang.Class.FromType(typeof(SecondActivity)));
//stackBuilder.AddNextIntent(intent);
但在实际使用中,确是不起作用。在NotificationDetailInfoActivity
界面,点击返回时,会返回至MainActivity
,而不是按照指定的顺序进行。
因此直接使用了stackBuilder.AddNextIntentWithParentStack(intent);
这句话。按自身的Stack
顺序,进行返回。
2、PendingIntentFlags.UpdateCurrent
标识位
这个标识位有很多,比较简单,使用比较多就是UpdateCurrent
,大家可以自行查看资料
2、源码下载
源码已上传,正在审核中。若审核通过,将添加正式的连接地址
3、总结
第一部分主要讲述推送基本设置,推送设置中还有一些样式的设置,大家可以到官网上进行学习。
下一部分将讲述在局域网内实时实现消息的推送
4、参考资料
主要查看了官网微软官网和这篇博文。