信鸽接入与测试指南

demo下载地址:https://download.youkuaiyun.com/download/flying_vip_521/10554207

 

第一步:app build.gradle配置:

 

配置ndk、信鸽ID、KEY:

ndk {
    //根据需要 自行选择添加的对应cpu类型的.so库。
    abiFilters 'armeabi', 'armeabi-v7a', 'arm64-v8a'
    // 还可以添加 'x86', 'x86_64', 'mips', 'mips64'
}
manifestPlaceholders = [
        XG_ACCESS_ID : XG_ACCESS_ID,
        XG_ACCESS_KEY: XG_ACCESS_KEY,
]

配置依赖:

//信鸽3.2.4 beta版本
compile 'com.tencent.xinge:xinge:3.2.4-beta'
//wup包
compile 'com.tencent.wup:wup:1.0.0.E-release'
//mid包
compile 'com.tencent.mid:mid:4.0.6-release'

第二步:配置useDeprecatedNdk

则在 Project 根目录的 gradle.properties 文件中添加:

  android.useDeprecatedNdk=true

第三步:如果需要,配置消息监听

自行继承XGBaseReceiver并且在配置文件中配置如下内容:

<receiver android:name="完整的类名如:com.qq.xgdemo.receiver.MessageReceiver"
      android:exported="true" >
      <intent-filter>
          <!-- 接收消息透传 -->
          <action android:name="com.tencent.android.tpush.action.PUSH_MESSAGE" />
          <!-- 监听注册、反注册、设置/删除标签、通知被点击等处理结果 -->
          <action android:name="com.tencent.android.tpush.action.FEEDBACK" />
      </intent-filter>
  </receiver>

第四步:启动消息监听

  private void initXGPush() {
    XGPushConfig.enableOtherPush(getApplicationContext(), true);
    XGPushConfig.enableDebug(this, true);
    XGPushManager.registerPush(getApplicationContext(),
        new XGIOperateCallback() {
          @Override
          public void onSuccess(Object data, int flag) {
            Log.d(TAG, "+++ register push sucess. token:" + data + "; flag:" + flag);
          }

          @Override
          public void onFail(Object data, int errCode, String msg) {
            Log.w(TAG, "+++ register push fail. token:" + data + ", errCode:" + errCode + ",msg:" + msg);
          }
        });
  }

第五步:通知点击事件处理

自定义点击事件入口类:

public class XGClickDispatchActivity extends Activity {
  private static final String TAG = XGClickDispatchActivity.class.getSimpleName();
  private static final String XG_PUSH = "xgscheme://click/dispatch?url=";

  @Override
  protected void onCreate(@Nullable Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    Log.d(TAG, "onCreate :  xg push notification clicked");
    Uri uri = getIntent().getData();
    if (uri != null) {
      String url = uri.toString().replace(XG_PUSH,"");
      Log.d(TAG, "uri = " + uri.toString());
      handleUrl(url);
    } else {
      Log.d(TAG, "uri =  null");
      handleUrl("");
    }
    finish();
  }

  @Override
  protected void onDestroy() {
    super.onDestroy();
    Log.d(TAG, "onDestroy");
  }

  private void handleUrl(String url) {
    Log.d(TAG, "handleUrl = " + url);
    Intent intent = new Intent(this, MainActivity.class);
    intent.putExtra(MainActivity.EXTRA_URL, url);
    intent.putExtra(MainActivity.EXTRA_CLEAR_FRAGMENT, false);
    startActivity(intent);
  }
}

注册分发类:

<activity
    android:name=".xg.XGClickDispatchActivity"
    android:theme="@android:style/Theme.NoTitleBar.Fullscreen" >
    <intent-filter >
        <action android:name="android.intent.action.VIEW" />
        <category android:name="android.intent.category.DEFAULT"/>
        <data android:scheme="xgscheme"
            android:host="click"
            android:path="/dispatch" />
    </intent-filter>
</activity>

 

第六步:点击事件测试

 应用:默认会打开应用

应用内界面:配置activity全路径

URL:配置https://www.baidu.com【点击打开外部浏览器,并加载url】

客户端自定义:

如果只打开界面XGClickDispatchActivity,配置xgscheme://click/dispatch即可

如果需要打开多个不同的界面,可以在界面配置里定义不同的xgscheme、host、path,组成界面uri,然后在信鸽推送配置进行测试

我只定义了1个点击入口界面,在入口内根据参数 做分发,打开不同的界面

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

flying_vip_521

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值