HMS Core地理圍欄能力助你實現指定範圍人群的精準消息推送

来源:https://www.cnblogs.com/hmscore/archive/2022/05/07/16241125.html
-Advertisement-
Play Games

精準推送是移動端產品留存階段的主要運營手段,精準推送常常會與用戶畫像緊密結合,針對用戶的喜好、畫像,採用不同策略,但基於用戶所屬區域推送消息卻很難實現。目前市面上大多數第三方消息推送服務商,在系統未深度定製的情況下,通常不支持將推送人群範圍精確到某個商圈或較小的區域,而地理圍欄技術可以很好地彌補這一 ...


精準推送是移動端產品留存階段的主要運營手段,精準推送常常會與用戶畫像緊密結合,針對用戶的喜好、畫像,採用不同策略,但基於用戶所屬區域推送消息卻很難實現。目前市面上大多數第三方消息推送服務商,在系統未深度定製的情況下,通常不支持將推送人群範圍精確到某個商圈或較小的區域,而地理圍欄技術可以很好地彌補這一點。地理圍欄就是用一個虛擬的柵欄圍出一個虛擬地理邊界,當手機進入、離開或在這個圍起來的特定地理區域內活動時,手機可以自動接收通知和警告消息。將地理圍欄和消息推送相結合,即可實現對特定區域人群的精準消息推送。

舉個例子,一款旅游出行類App想在江蘇推廣其門票業務,他可以針對南京、蘇州等城市的熱門旅游景點劃定地理圍欄,當目標受眾在特定時間段到達某個旅游景點附近時,將會收到一條特定消息推送“XX景點門票優惠券已放入賬戶中,立即領取>>”在用戶有購買XX景點門票需求時應景推送優惠信息,讓用戶無法拒絕。

實現方法

華為定位服務地理圍欄能力結合推送服務消息推送能力,就可實現對指定範圍人群的精準消息推送。通過設置特定的區域,可以檢測用戶的事件狀態,例如他們何時進入、離開或停留在該區域,一旦滿足觸發條件,用戶設備將實時收到消息推送。即使應用不在後臺運行,也可以在用戶設備上傳遞和顯示消息,消息傳遞率可達99%。

效果展示:

  1. 在測試設備上安裝演示應用。

  2. 啟動演示應用程式,點擊地理圍欄屏幕上的添加地理圍欄,然後設置相關參數以創建地理圍欄。

  3. 等待地理圍欄被觸發。

  4. 在觸發地理圍欄時檢查收到的消息。

開發步驟

  1. 配置SDK的Maven倉地址。

(Android Studio的代碼庫配置在Gradle插件7.0以下版本、7.0版本和7.1及以上版本有所不同。請根據您當前的Gradle插件版本,選擇對應的配置過程。這裡以7.1版本為例)

a) 在“buildscript > dependencies”中增加agcp插件配置。

buildscript {
i.	    dependencies {
ii.	        ...
iii.	        // 增加agcp插件配置,推薦您使用最新版本的agcp插件。
iv.	        classpath 'com.huawei.agconnect:agcp:1.6.0.300'
    }
v.	}

b) 項目級“settings.gradle”文件,配置HMS Core SDK的Maven倉地址。

pluginManagement {
    repositories {
        gradlePluginPortal()
        google()
        mavenCentral()
        // 配置HMS Core SDK的Maven倉地址。
        maven { url 'https://developer.huawei.com/repo/' }
    }
}
dependencyResolutionManagement {
    ...
    repositories {
        google()
        mavenCentral()
        // 配置HMS Core SDK的Maven倉地址。
        maven { url 'https://developer.huawei.com/repo/' }
    }
}

2.在“dependencies ”中添加如下編譯依賴。

//應用級的“build.gradle”文件
dependencies {
    implementation 'com.huawei.hms:location: 6.4.0.300'
    implementation 'com.huawei.hms:push: 6.3.0.304'
}
  1. 在 AndroidManifest.xml 文件中聲明系統許可權。

因華為定位服務採用GNSS、Wi-Fi、基站等多種混合定位模式進行定位,賦予您的應用程式快速、精準地獲取用戶位置信息的能力,需要用到網路,精確的位置許可權,粗略的位置許可權如果您需要應用程式在後臺執行時也具備持續定位能力,需要在Manifest文件中申請ACCESS_BACKGROUND_LOCATION許可權:

<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.ACCESS_COARES_LOCATION" />

註:由於ACCESS_FINE_LOCATION,WRITE_EXTERNAL_STORAGE和READ_EXTERNAL_STORAGE是危險的系統許可權,因此,您需要動態的申請這些許可權。如果許可權不足,Location Service將會拒絕為您的應用開啟定位。

關鍵代碼說明

代碼文件路徑: com.huawei.hmssample2.geofence\GeoFenceActivity.java

如果您的應用需要集成圍欄Service實現服務推送,僅僅需要參考將GeoFenceActivity集成到您的應用中在接收圍欄回調的同時發出推送的廣播,即可實現。

  1. 觸發地理圍欄。

a) 根據需要創建地理圍欄和地理圍欄組,並設置相應的參數,比如圍欄半徑,觸發時間等。

if (checkStyle(geofences, data.uniqueId) == false) {
    LocationLog.d("GeoFenceActivity", "not unique ID!");
    LocationLog.i("GeoFenceActivity", "addGeofence failed!");
    return;
}
geoBuild.setRoundArea(data.latitude, data.longitude, data.radius);
geoBuild.setUniqueId(data.uniqueId);
geoBuild.setConversions(data.conversions);
geoBuild.setValidContinueTime(data.validContinueTime);
geoBuild.setDwellDelayTime(data.dwellDelayTime);
geoBuild.setNotificationInterval(data.notificationInterval);
geofences.add(geoBuild.build());
LocationLog.i("GeoFenceActivity", "addGeofence success!");

b) 設置好相關參數之後通過intent註冊廣播

GeofenceRequest.Builder geofenceRequest = new GeofenceRequest.Builder();
geofenceRequest.createGeofenceList(GeoFenceData.returnList());
if (trigger.getText() != null) {
    int trigGer = Integer.parseInt(trigger.getText().toString());
    geofenceRequest.setInitConversions(trigGer);
    LocationLog.d(TAG, "trigger is " + trigGer);
} else {
    geofenceRequest.setInitConversions(5);
    LocationLog.d(TAG, "default trigger is 5");
}

final PendingIntent pendingIntent = getPendingIntent();
try {
    geofenceService.createGeofenceList(geofenceRequest.build(), pendingIntent)
        .addOnCompleteListener(new OnCompleteListener<Void>() {
            @Override
            public void onComplete(Task<Void> task) {
                if (task.isSuccessful()) {
                    LocationLog.i(TAG, "add geofence success!");
                    setList(pendingIntent, GeoFenceData.getRequestCode(), GeoFenceData.returnList());
                    GeoFenceData.createNewList();
                } else {
                    // Get the status code for the error and log it using a user-friendly message.
                    LocationLog.w(TAG, "add geofence failed : " + task.getException().getMessage());
                }
            }
        });
} catch (Exception e) {
    LocationLog.i(TAG, "add geofence error:" + e.getMessage());
}
private PendingIntent getPendingIntent() {
    Intent intent = new Intent(this, GeoFenceBroadcastReceiver.class);
    intent.setAction(GeoFenceBroadcastReceiver.ACTION_PROCESS_LOCATION);
    Log.d(TAG, "new request");
    GeoFenceData.newRequest();
    return PendingIntent.getBroadcast(this, GeoFenceData.getRequestCode(), intent,
        PendingIntent.FLAG_UPDATE_CURRENT);
}
  1. 觸發消息推送。
在GeoFenceBroadcastReceiver的onReceive接收到圍欄觸發成功提示後發送推送通知,在通知欄接收通知並展示。
GeofenceData geofenceData = GeofenceData.getDataFromIntent(intent);
if (geofenceData != null) {
    int errorCode = geofenceData.getErrorCode();
    int conversion = geofenceData.getConversion();
    ArrayList<Geofence> list = (ArrayList<Geofence>) geofenceData.getConvertingGeofenceList();
    Location myLocation = geofenceData.getConvertingLocation();
    boolean status = geofenceData.isSuccess();
    sb.append("errorcode: " + errorCode + next);
    sb.append("conversion: " + conversion + next);
    if (list != null) {
        for (int i = 0; i < list.size(); i++) {
            sb.append("geoFence id :" + list.get(i).getUniqueId() + next);
        }
    }
    if (myLocation != null) {
        sb.append("location is :" + myLocation.getLongitude() + " " + myLocation.getLatitude() + next);
    }
    sb.append("is successful :" + status);
    LocationLog.i(TAG, sb.toString());
    Toast.makeText(context, "" + sb.toString(), Toast.LENGTH_LONG).show();
    //
    new PushSendUtils().netSendMsg(sb.toString());
}

註意:使用示例代碼創建的地理圍欄將觸發轉化類型 1 和 4 的兩個回調。一個在用戶進入地理圍欄時觸發,另一個在用戶停留在地理圍欄內時觸發。如果在代碼中將 Trigger 設置為 7,則會配置所有方案(包括進入、停留和離開地理圍欄)的回調。

完成以上開發步驟就可以完成地理圍欄推送功能,實現在指定區域內推送消息通知實現精準營銷。

瞭解更多詳情>>

訪問華為開發者聯盟官網
獲取開髮指導文檔
華為移動服務開源倉庫地址:GitHubGitee

關註我們,第一時間瞭解 HMS Core 最新技術資訊~


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • unzip 命令可以查看和解壓縮 zip 文件。該命令的基本格式如下: [root@localhost ~]# unzip [選項] 壓縮包名 此命令常用的選項以及各自的含義如表 1 所示。 選項 含義 -d 目錄名 將壓縮文件解壓到指定目錄下。 -n 解壓時並不覆蓋已經存在的文件。 -o 解壓時覆 ...
  • 一、安裝JDK8 【溫馨提示】這裡使用jdk8,這裡不要用其他jdk了,可能會出現一些其他問題的,我用jdk11有些包就找不到,好像jdk9都不行 1)JDK下載地址 http://www.oracle.com/technetwork/java/javase/downloads/index.html ...
  • 1、下載安裝包 打開官網,跳轉至下載界面,選擇對應版本的安裝包,拷貝其鏈接,這裡是手動安裝,所以下載tgz安裝包,如果要自動化安裝,選擇server的rpm自動安裝包 https://www.mongodb.com/try/download/community 這裡直接使用wget下載至伺服器中,然 ...
  • **導讀:**京東智能商客之推薦賣點是基於NLP的產品,目前已廣泛地助力和賦能於京東商城的各個平臺。今天和大家分享一下自然語言處理如何在工業界落地實現。主要圍繞以下5個方面展開: 推薦賣點技術背景 架構描述 核心AI技術 模型研發與實踐 產品的落地與回報 -- 01 推薦賣點技術背景 1. 什麼是推 ...
  • 大家見過這張圖嗎? Swami Chandrasekaran在2013年用地鐵圖來描述如何通過“一段旅程”來成為數據科學家 (鏈接:http://nirvacana.com/thoughts/2013/07/08/becoming-a-data-scientist/) 這個圖幫助很多人叩開了數據科學 ...
  • 解決MySQL 8.0在Linux環境下的安裝、初始化、配置。參考環境:MySQL Community Server 8.0.28;CentOS Linux release 7.9.2009。 ...
  • 本文收集了各種資料庫的SQL語句優化原理思路、技術要點和方法實操案例文檔!希望大家都能寫得一手好SQL、掌握資料庫高性能運行秘訣! ...
  • HarmonyOS Connect智能硬體開放生態即將步入富設備產業化時代!為了讓廣大開發者能搶先體驗鴻蒙智聯富設備開發,本期我們將為大家帶來七款支持富設備開發的開發板。 ...
一周排行
    -Advertisement-
    Play Games
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...