美文网首页
Hbuilder app项目离线打包-Android 接入极光

Hbuilder app项目离线打包-Android 接入极光

作者: 全校最帅的人 | 来源:发表于2017-12-21 11:27 被阅读0次

简介:

        最近公司决定试一试Hbuilder那套开发wep app  现在第一个应用已经上线,其中坑还是比较多的,这个暂且不说。因为在项目中使用了极光推送,虽然官方有demo ,但是实际使用过程中还是有坑,今天把我遇到的坑列出来,分享给大家,

       首先是Hbuilder编写好移动app后 ,需要在AndroidStudio里面离线打包,文章链接Android创建最精简离线打包工程 然后参照极光编写的Hbuilder插件demo 先把基本的推送接入进入能收到推送,参考文档JPush HBuilder Demo  。到了这一步,app可以运行 ,推送也能接收了。按照文档弄就ok了?  no no no。

坑1:ndk的so文件过滤配置,原来的配置是

ndk {

//选择要添加的对应 cpu 类型的 .so 库。

abiFilters 'armeabi','armeabi-v7a','arm64-v8a'

//还可以添加 'x86', 'x86_64', 'mips', 'mips64'

}

如果你只集成了极光推送是没有问题的,但是如果你又集成了比如百度地图等  ,这样配置就会报错,因为不是每个SDK都有32 64位的s0文件  所以只需要改成

ndk {

abiFilters'armeabi'

/*  'armeabi-v7a', 'arm64-v8a'

'x86', 'x86_64', 'mips', 'mips64'*/

}

这样,32的so文件兼容64位的cpu

坑2  推送的接收和处理点击通知栏事件

        (1)因为项目是用HBuilder编写的 ,推送的接受可以放到网络请求的那个js文件里面,其他html页面引入这个js即可收到推送,但是,如果接收的是自定义的消息 极光推送不会弹出通知栏,简单的解决方法就是接收到自定义消息然后发一个本地广播 这样就有通知栏提示了,代码如下

//自定义消息的接收监听

document.addEventListener("jpush.receiveMessage",function(event) {

varinfo = plus.Push.receiveMessage;

varmessage = info.message;

varextras = info.extras;

varEXTRA = extras["cn.jpush.android.EXTRA"];

varobj = JSON.parse(EXTRA);

vartitle = obj.title;//额外自定义字段需要根据实际情况取出来

varcontent = obj.content;//额外自定义字段需要根据实际情况取出来

varURL1 = obj.url;//额外自定义字段需要根据实际情况取出来

plus.Push.addLocalNotification(1, content, title,1,10, EXTRA);//发本地广播

},false);

(2)现在自定义消息 通知都会以Notification的形式弹出来了,但是如果点击通知栏进入一个页面的话(跳转到html页面),返回来,再次接收通知点击之后 会出现一个异常-加载一个销毁的WebView 

     如果只是打开一个页面展示消息  这个页面还是需要用原生activity来写 ,点击通知栏使用mui api打开一个activity传参数的代码示例

document.addEventListener("jpush.openNotification",function() {

varinfo = plus.Push.openNotification;

try{

varIntent = plus.android.importClass("android.content.Intent");

varMsg = plus.android.importClass("io.dcloud.Msg");

varmain = plus.android.runtimeMainActivity();

varintent =newIntent(main, Msg.class);

intent.putExtra("msg", JSON.stringify(info));

main.startActivity(intent);

}catch(e) {

mui.toast("error"+ e.message);

}

},false);

这样的话 就不会导致点击的时候包异常页面跳转无效了

(3)如果应用在后台,收到推送后点击会重新打开app  但是只是上面的代码是没有效果的,因为app在后台的情况不能使用mui api.这种情况下可以在JPushReceiver handlingNotificationReceive方法中做处理 标记一下app是在前台还是后台,如果是后台,就把收到的消息存起来  等app启动的时候判断如果是后台启动,就去吧存起来的消息取出来重新使用上面的跳转方法

代码示例

public static booleanisApplicationBroughtToBackground(finalContext context) {

ActivityManager am = (ActivityManager) context.getSystemService(Context.ACTIVITY_SERVICE);

List tasks = am.getRunningTasks(1);

if(!tasks.isEmpty()) {

ComponentName topActivity = tasks.get(0).topActivity;

if(!topActivity.getPackageName().equals(context.getPackageName())) {

return true;

}

}

return false;

}

//*******************************************

booleanisBack=isApplicationBroughtToBackground(context);

sp.save("isBack",""+isBack);

try{

JSONObject obj=newJSONObject();

obj.put("title",title);

obj.put("alert",alert);

obj.put("extras",extras);

sp.save("backMsg",obj.toString());

}catch(JSONException e) {

e.printStackTrace();

}

//*******************************************

第一次写,文笔有限,希望大家多多理解

相关文章

网友评论

      本文标题:Hbuilder app项目离线打包-Android 接入极光

      本文链接:https://www.haomeiwen.com/subject/rlsayttx.html