極光推送 Xamarin Form Library, Android Push Notification in China via JiGuang
極光推送 Xamarin Form Library, Android Push Notification in China via JiGuang
Product website : https://www.jiguang.cn/push
Currently, this library only support Android
Install-Package XF.JiGuang -Version 1.0.5
Create Custom JCommonService class, setup the service name, replace {ProjectNamespace} to your project namespace like “XF.JiGuangPush.Sample.Droid.Notificaiton”
[Service(Name = "{ProjectNamespace}.MyJCommonService")]
public class MyJCommonService : JiGuangPush.Droid.XFJiGuangCommonService
{
}
Create Custom JPushMessageReceiver class, replace {ProjectNamespace} to your project namespace like “XF.JiGuangPush.Sample.Droid.Notificaiton”. You can also override the methods for your own actions.
[BroadcastReceiver(Name = "{ProjectNamespace}.MyJPushMessageReceiver")]
public class MyJPushMessageReceiver : XFJiGuangPushMessageReceiver
{
public override void OnRegister(Context p0, string p1)
{
base.OnRegister(p0, p1);
}
public override void OnConnected(Context p0, bool p1)
{
base.OnConnected(p0, p1);
}
public override void OnTagOperatorResult(Context p0, JPushMessage p1)
{
base.OnTagOperatorResult(p0, p1);
}
public override void OnAliasOperatorResult(Context p0, JPushMessage p1)
{
base.OnAliasOperatorResult(p0, p1);
}
public override void OnNotifyMessageArrived(Context p0, NotificationMessage p1)
{
base.OnNotifyMessageArrived(p0, p1);
}
public override void OnNotifyMessageOpened(Context p0, NotificationMessage p1)
{
//Open your application before trigger the open action
Intent i = new Intent(p0, typeof(MainActivity));
i.AddFlags(ActivityFlags.SingleTop);
Android.App.Application.Context.StartActivity(i);
base.OnNotifyMessageOpened(p0, p1);
}
}
Manifest sample
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android" android:versionCode="1" android:versionName="1.0" package="{your_application_id}" android:installLocation="auto">
<uses-sdk android:minSdkVersion="21" android:targetSdkVersion="28" ></uses-sdk>
<!-- Required -->
<permission android:name="{your_application_id}.permission.JPUSH_MESSAGE" android:protectionLevel="signature" ></permission>
<!-- Required 一些系统要求的权限,如访问网络等-->
<uses-permission android:name="{your_application_id}.permission.JPUSH_MESSAGE" ></uses-permission>
<uses-permission android:name="android.permission.RECEIVE_USER_PRESENT" ></uses-permission>
<uses-permission android:name="android.permission.INTERNET" ></uses-permission>
<uses-permission android:name="android.permission.READ_PHONE_STATE" ></uses-permission>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" ></uses-permission>
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" ></uses-permission>
<uses-permission android:name="android.permission.WRITE_SETTINGS" ></uses-permission>
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" ></uses-permission>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" ></uses-permission>
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" ></uses-permission>
<!-- Optional. Required for location feature -->
<uses-permission android:name="android.permission.ACCESS_BACKGROUND_LOCATION" ></uses-permission>
<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" ></uses-permission>
<!-- 用于开启 debug 版本的应用在 6.0 系统上的层叠窗口权限 -->
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" ></uses-permission>
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE" ></uses-permission>
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" ></uses-permission>
<uses-permission android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS" ></uses-permission>
<uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" ></uses-permission>
<uses-permission android:name="android.permission.GET_TASKS" ></uses-permission>
<uses-permission android:name="android.permission.VIBRATE" ></uses-permission>
<application android:label="{your_application_id}.Android" android:icon="@mipmap/icon">
<!-- Required SDK 核心功能-->
<!-- 可配置android:process参数将PushService放在其他进程中 -->
<service android:name="cn.jpush.android.service.PushService" android:enabled="true" android:exported="false">
<intent-filter>
<action android:name="cn.jpush.android.intent.REGISTER" ></action>
<action android:name="cn.jpush.android.intent.REPORT" ></action>
<action android:name="cn.jpush.android.intent.PushService" ></action>
<action android:name="cn.jpush.android.intent.PUSH_TIME" ></action>
</intent-filter>
</service>
<!-- since 3.0.9 Required SDK 核心功能-->
<provider android:authorities="{your_application_id}.DataProvider" android:name="cn.jpush.android.service.DataProvider" android:exported="true" ></provider>
<!-- since 1.8.0 option 可选项。用于同一设备中不同应用的JPush服务相互拉起的功能。 -->
<!-- 若不启用该功能可删除该组件,将不拉起其他应用也不能被其他应用拉起 -->
<service android:name="cn.jpush.android.service.DaemonService" android:enabled="true" android:exported="true">
<intent-filter>
<action android:name="cn.jpush.android.intent.DaemonService" ></action>
<category android:name="{your_application_id}" ></category>
</intent-filter>
</service>
<!-- since 3.1.0 Required SDK 核心功能-->
<provider android:authorities="{your_application_id}.DownloadProvider" android:name="cn.jpush.android.service.DownloadProvider" android:exported="true" ></provider>
<!-- Required SDK核心功能-->
<receiver android:name="cn.jpush.android.service.PushReceiver" android:enabled="true">
<intent-filter android:priority="1000">
<action android:name="cn.jpush.android.intent.NOTIFICATION_RECEIVED_PROXY" ></action>
<!--Required 显示通知栏 -->
<category android:name="{your_application_id}" ></category>
</intent-filter>
<intent-filter>
<action android:name="android.intent.action.USER_PRESENT" ></action>
<action android:name="android.net.conn.CONNECTIVITY_CHANGE" ></action>
</intent-filter>
<!-- Optional -->
<intent-filter>
<action android:name="android.intent.action.PACKAGE_ADDED" ></action>
<action android:name="android.intent.action.PACKAGE_REMOVED" ></action>
<data android:scheme="package" ></data>
</intent-filter>
</receiver>
<!-- Required SDK核心功能-->
<activity android:name="cn.jpush.android.ui.PushActivity" android:configChanges="orientation|keyboardHidden" android:theme="@android:style/Theme.NoTitleBar" android:exported="false">
<intent-filter>
<action android:name="cn.jpush.android.ui.PushActivity" ></action>
<category android:name="android.intent.category.DEFAULT" ></category>
<category android:name="{your_application_id}" ></category>
</intent-filter>
</activity>
<!-- SDK 核心功能-->
<activity android:name="cn.jpush.android.ui.PopWinActivity" android:configChanges="orientation|keyboardHidden" android:exported="false" android:theme="@style/MyDialogStyle">
<intent-filter>
<category android:name="android.intent.category.DEFAULT" ></category>
<category android:name="{your_application_id}" ></category>
</intent-filter>
</activity>
<!-- 注意此配置在 JPush 3.2.0 及以前版本是必须配置,3.2.0 以后版本已废弃此配置-->
<service android:name="cn.jpush.android.service.DownloadService" android:enabled="true" android:exported="false"></service>
<!-- Since JCore2.0.0 Required SDK核心功能-->
<!-- 可配置android:process参数将Service放在其他进程中;android:enabled属性不能是false -->
<!-- 这个是自定义Service,要继承极光JCommonService,可以在更多手机平台上使得推送通道保持的更稳定 -->
<service android:name="{ProjectNamespace}.MyJCommonService" android:enabled="true" android:exported="false" android:process=":pushcore">
<intent-filter>
<action android:name="cn.jiguang.user.service.action" ></action>
</intent-filter>
</service>
<!-- Required SDK核心功能-->
<receiver android:name="cn.jpush.android.service.AlarmReceiver" ></receiver>
<!-- User defined. For test only 用户自定义接收消息器,3.0.7开始支持,目前新tag/alias接口设置结果会在该广播接收器对应的方法中回调-->
<receiver android:name="{ProjectNamespace}.MyJPushMessageReceiver" android:enabled="true" android:exported="false">
<intent-filter>
<action android:name="cn.jpush.android.intent.RECEIVE_MESSAGE" ></action>
<category android:name="{your_application_id}"></category>
</intent-filter>
</receiver>
<!--since 3.3.0 Required SDK核心功能-->
<activity android:name="cn.jpush.android.service.JNotifyActivity" android:exported="true" android:taskAffinity="jpush.custom" android:theme="@android:style/Theme.Translucent.NoTitleBar">
<intent-filter>
<action android:name="cn.jpush.android.intent.JNotifyActivity" ></action>
<category android:name="{your_application_id}" ></category>
</intent-filter>
</activity>
<!-- Required . Enable it you can get statistics data with channel -->
<meta-data android:name="JPUSH_CHANNEL" android:value="developer-default" />
<meta-data android:name="JPUSH_APPKEY" android:value="{your_jpush_appkey}" />
</application>
</manifest>
Config manifest.xml for your own project
```
Init the service, prefer doing it in App.cs
JiGuangPush.Shared.JPushInstance.Instance.Init(debugMode);
Setup action when receive callback from JiGuang server, you can let your application response to the callback
JiGuangPush.Shared.JPushInstance.Instance.OnMessageReceived += Instance_OnMessageReceived;
JiGuangPush.Shared.JPushInstance.Instance.OnMessageOpened += Instance_OnMessageOpened;
JiGuangPush.Shared.JPushInstance.Instance.OnConnected += Instance_OnConnected;
JiGuangPush.Shared.JPushInstance.Instance.OnRegistered += Instance_OnRegistered;
JiGuangPush.Shared.JPushInstance.Instance.OnOperationResult += Instance_OnOperationResult;
Current support methods, please refer to official site for the usage.
void Init(bool debugMode);
string GetRegistrationId();
void SetAlias(JiGuangSequence sequence, string alias);
void DeleteAlias(JiGuangSequence sequence);
void GetAlias(JiGuangSequence sequence);
void SetTags(JiGuangSequence sequence, List<string> tags);
void AddTags(JiGuangSequence sequence, List<string> tags);
void DeleteTags(JiGuangSequence sequence, List<string> tags);
void CleanTags(JiGuangSequence sequence);
void GetAllTags(JiGuangSequence sequence);
void SetChannel(string channel);
void ClearAllNotification();
void ClearNotifcation(int notificationId);