日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

MobPush?for?Flutter集成準備_IOS

作者:MobTech開發者 ? 更新時間: 2022-12-24 編程語言

集成準備

這是一個基于 MobPush 功能的擴展的 Flutter 插件。使用此插件能夠幫助您在使用 Flutter 開發應用時,快速地實現推送功能。

在pubspec.yaml文件中加入下面依賴

dependencies:
  mobcommonlib:
  mobpush_plugin:

然后執行:flutter packages get 導入package 在你的dart工程文件中,導入下面頭文件,開始使用

import 'package:mobcommonlib/mobcommonlib.dart';
import 'package:mobpush_plugin/mobpush_plugin.dart';

iOS

平臺配置參考 iOS集成文檔

實現文檔中 Xcode配置:配置AppKey和AppSecret

Android

導入 MobPush 相關依賴

在項目根目錄的build.gradle中添加以下代碼:

buildscript {
    repositories {
        // 配置Mob Maven庫
        maven {
           url "https://mvn.mob.com/android"
        }
      // 配置HMS Core SDK的Maven倉地址。(集成華為廠商需要添加)
        maven {
           url 'https://developer.huawei.com/repo/'}
        }
        ...
    }
    dependencies {
        ...
        // 集成MobPush
        classpath "com.mob.sdk:MobSDK:2018.0319.1724"
    }
}

在 /android/app/build.gradle 中添加以下代碼:

apply plugin: 'com.android.application'
apply from: "$flutterRoot/packages/flutter_tools/gradle/flutter.gradle"
// 導入MobSDK
apply plugin: 'com.mob.sdk'

平臺相關集成 在項目的/android/app/build.gradle中添加:

MobSDK {
    appKey "您的MobTech平臺appKey"
    appSecret "您的MobTech平臺appSecret"
    //配置MobPush
    MobPush {
        //配置廠商推送(可選配置,不需要廠商推送可不配置,需要哪些廠商推送只需配置哪些廠商配置即可)
        devInfo {
            //配置小米廠商推送
            XIAOMI {
                appId "您的小米平臺appId"
                appKey "您的小米平臺appKey"
            }
            //配置華為廠商推送
            HUAWEI {
                appId "您的華為平臺appId"
            }
            //配置魅族廠商推送
            MEIZU {
                appId "您的魅族平臺appId"
                appKey "您的魅族平臺appKey"
            }
            //配置FCM廠商推送
            FCM {
                //設置默認推送通知顯示圖標
                iconRes "@mipmap/default_ic_launcher"
            }
            //配置OPPO廠商推送
            OPPO {
                appKey "您的OPPO平臺appKey"
                appSecret "您的OPPO平臺appSecret"
            }
            //配置VIVO廠商推送
            VIVO {
                appId "您的VIVO平臺appId"
                appKey "您的VIVO平臺appKey"
            }
        }
    }
}

添加代碼

在MainActivity的onCreate中添加以下代碼:

@Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    GeneratedPluginRegistrant.registerWith(this);
  }

SDK API

回傳用戶隱私授權結果 (submitPrivacyGrantResult)

/**
 * 回傳用戶隱私授權結果
 * @param status     用戶是否同意隱私協議
 * @param result     默認傳null
 */  
Mobcommonlib.submitPolicyGrantResult(bool status, Function(bool)? result)

例:

Mobcommonlib.submitPolicyGrantResult(true, null);

設置遠程推送環境

向用戶授權(setCustomNotification僅 iOS)

setCustomNotification
if (Platform.isIOS) {
      MobpushPlugin.setCustomNotification();
}

設置遠程推送環境 (setAPNsForProduction僅 iOS)

setAPNsForProduction
if (Platform.isIOS) {
     // 開發環境 false, 線上環境 true
      MobpushPlugin.setAPNsForProduction(false)
}

添加推送回調監聽(addPushReceiver 接收自定義透傳消息回調、接收通知消息回調、接收點擊通知消息回調、接收別名或標簽操作回調)

addPushReceiver
MobpushPlugin.addPushReceiver(_onEvent, _onError);
void _onEvent(Object event) {
}
void _onError(Object event) {
}

停止推送(stopPush)

stopPush
MobpushPlugin.stopPush();

重新打開推送服務(restartPush)

restartPush
MobpushPlugin.restartPush();

是否已停止接收推送(isPushStopped)

isPushStopped
MobpushPlugin.isPushStopped();

設置別名(setAlias)

setAlias
MobpushPlugin.setAlias("別名").then((Map<String, dynamic> aliasMap){
    String res = aliasMap['res'];
    String error = aliasMap['error'];
    String errorCode = aliasMap['errorCode'];
    print(">>>>>>>>>>>>>>>>>>>>>>>>>>> setAlias -> res: $res error: $error");
});

獲取別名(getAlias)

getAlias
MobpushPlugin.getAlias().then((Map<String, dynamic> aliasMap){
    String res = aliasMap['res'];
    String error = aliasMap['error'];
    print(">>>>>>>>>>>>>>>>>>>>>>>>>>> getAlias -> res: $res error: $error");
});

刪除別名(deleteAlias)

deleteAlias
MobpushPlugin.deleteAlias().then((Map<String, dynamic> aliasMap){
    String res = aliasMap['res'];
    String error = aliasMap['error'];
    print(">>>>>>>>>>>>>>>>>>>>>>>>>>> deleteAlias -> res: $res error: $error");
});

添加標簽(addTags)

addTags
List tags = new List();
tags.add("tag1");
tags.add("tag2");
MobpushPlugin.addTags(tags).then((Map<String, dynamic> tagsMap){
    String res = tagsMap['res'];
    String error = tagsMap['error'];
    print(">>>>>>>>>>>>>>>>>>>>>>>>>>> addTags -> res: $res error: $error");
});

獲取標簽(getTags)

getTags
MobpushPlugin.getTags().then((Map<String, dynamic> tagsMap) {
          List<String> resList;
          if (tagsMap['res'] == null) {
            resList = [];
          } else {
            resList = tagsMap['res'].toList();
          }
          String error = tagsMap['error'];
          print(
              ">>>>>>>>>>>>>>>>>>>>>>>>>>> getTags -> res: $resList error: $error");
        });

刪除標簽(deleteTags)

deleteTags
List tags = new List();
tags.add("tag1");
tags.add("tag2");
MobpushPlugin.deleteTags(tags).then((Map<String, dynamic> tagsMap){
    String res = tagsMap['res'];
    String error = tagsMap['error'];
    print(">>>>>>>>>>>>>>>>>>>>>>>>>>> deleteTags -> res: $res error: $error");
});

清空標簽(cleanTags)

cleanTags
MobpushPlugin.cleanTags().then((Map<String, dynamic> tagsMap){
    String res = tagsMap['res'];
    String error = tagsMap['error'];
    print(">>>>>>>>>>>>>>>>>>>>>>>>>>> cleanTags -> res: $res error: $error");
});

發送本地通知(addLocalNotification)

addLocalNotification
MobpushPlugin.addLocalNotification();

綁定手機號(bindPhoneNum)

bindPhoneNum
MobpushPlugin.bindPhoneNum("110");

測試模擬推送,用于測試(send)

send
/**
    * 測試模擬推送,用于測試
    * type:模擬消息類型,1、通知測試;2、內推測試;3、定時
    * content:模擬發送內容,500字節以內,UTF-8
    * space:僅對定時消息有效,單位分鐘,默認1分鐘
    * extras: 附加數據,json字符串
    */
MobpushPlugin.send(int type, String content, int space, String extras).then((Map<String, dynamic> sendMap){
    String res = sendMap['res'];
    String error = sendMap['error'];
    print(">>>>>>>>>>>>>>>>>>>>>>>>>>> send -> res: $res error: $error");
});

設置點擊通知是否跳轉默認頁 (setClickNotificationToLaunchMainActivity 僅Android)

setClickNotificationToLaunchMainActivity
MobpushPlugin.setClickNotificationToLaunchMainActivity (bool enable);

移除本地通知(removeLocalNotification 僅Android)

removeLocalNotification
MobpushPlugin.removeLocalNotification(int notificationId);

清空本地通知(clearLocalNotifications 僅)

clearLocalNotifications
MobpushPlugin.clearLocalNotifications();

設置通知欄icon,不設置默認取應用icon(setNotifyIcon 僅Android)

setNotifyIcon
MobpushPlugin.setNotifyIcon(String resId);

設置通知靜音時段(推送選項)(setSilenceTime 僅Android)

setSilenceTime
/**
   * 設置通知靜音時段(推送選項)(僅Android)
   * @param startHour   開始時間[0~23] (小時)
   * @param startMinute 開始時間[0~59](分鐘)
   * @param endHour     結束時間[0~23](小時)
   * @param endMinute   結束時間[0~59](分鐘)
   */
MobpushPlugin.setSilenceTime(int startHour, int startMinute, int endHour, int endMinute)

設置角標 (setBadge僅 iOS)

setBadge
MobpushPlugin.setBadge(int badge);

清空角標,不清除通知欄消息記錄 (clearBadge僅 iOS)

clearBadge
MobpushPlugin.clearBadge();

獲取注冊Id(getRegistrationId)

getRegistrationId
MobpushPlugin.getRegistrationId().then((Map<String, dynamic> ridMap) {
    print(ridMap);
    String regId = ridMap['res'].toString();
    print('------>#### registrationId: ' + regId);
});

Flutter iOS端注意事項

由于插件更新,SDK的Pod依賴被替換,Flutter 本身寫入Pod文件不會先執行刪除原有依賴,導致可能會出現原有本地庫依然存在,請檢查Pod文件夾下文件,直接手動刪除mob_pushsdk 以及 MOBFoundation文件即可,如有疑問,請直接通過官網和我們聯系。

demo地址?GitHub地址

原文鏈接:https://juejin.cn/post/7170274114929147934

欄目分類
最近更新