精準推送是移動端產品留存階段的主要運營手段,精準推送常常會與用戶畫像緊密結合,針對用戶的喜好、畫像,采用不同策略,但基于用戶所屬區域推送訊息卻很難實作,目前市面上大多數第三方訊息推送服務商,在系統未深度定制的情況下,通常不支持將推送人群范圍精確到某個商圈或較小的區域,而地理圍欄技術可以很好地彌補這一點,地理圍欄就是用一個虛擬的柵欄圍出一個虛擬地理邊界,當手機進入、離開或在這個圍起來的特定地理區域內活動時,手機可以自動接收通知和警告訊息,將地理圍欄和訊息推送相結合,即可實作對特定區域人群的精準訊息推送,
舉個例子,一款旅游出行類App想在江蘇推廣其門票業務,他可以針對南京、蘇州等城市的熱門旅游景點劃定地理圍欄,當目標受眾在特定時間段到達某個旅游景點附近時,將會收到一條特定訊息推送“XX景點門票優惠券已放入賬戶中,立即領取>>”在用戶有購買XX景點門票需求時應景推送優惠資訊,讓用戶無法拒絕,
實作方法
用華為定位服務地理圍欄能力結合推送服務訊息推送能力,就可實作對指定范圍人群的精準訊息推送,通過設定特定的區域,可以檢測用戶的事件狀態,例如他們何時進入、離開或停留在該區域,一旦滿足觸發條件,用戶設備將實時收到訊息推送,即使應用不在后臺運行,也可以在用戶設備上傳遞和顯示訊息,訊息傳遞率可達99%,
效果展示:
-
在測驗設備上安裝演示應用,
-
啟動演示應用程式,點擊地理圍欄螢屏上的添加地理圍欄,然后設定相關引數以創建地理圍欄,
-
等待地理圍欄被觸發,
-
在觸發地理圍欄時檢查收到的訊息,
開發步驟
- 配置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'
}
- 在 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集成到您的應用中在接收圍欄回呼的同時發出推送的廣播,即可實作,
- 觸發地理圍欄,
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);
}
- 觸發訊息推送,
在GeoFenceBroadcastReceiver的onReceive接收到圍欄觸發成功提示后發送推送通知,在通知欄接收通知并展示,
GeofenceData geofenceData = https://www.cnblogs.com/hmscore/archive/2022/05/07/GeofenceData.getDataFromIntent(intent);
if (geofenceData != null) {
int errorCode = geofenceData.getErrorCode();
int conversion = geofenceData.getConversion();
ArrayList list = (ArrayList) 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,則會配置所有方案(包括進入、停留和離開地理圍欄)的回呼,
完成以上開發步驟就可以完成地理圍欄推送功能,實作在指定區域內推送訊息通知實作精準營銷,
了解更多詳情>>
訪問華為開發者聯盟官網
獲取開發指導檔案
華為移動服務開源倉庫地址:GitHub、Gitee
關注我們,第一時間了解 HMS Core 最新技術資訊~
轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/469876.html
標籤:其他