腾讯浏览服务X5内核集成

作者: b77535296c81 | 来源:发表于2016-10-15 17:43 被阅读15659次

导读
<a name="label">1、什么是X5内核?</a>
<a name="label">2、需求场景</a>
<a name="label">3、开始搬砖</a>
<a name="label">4、优化</a>
<a name="label">5、补充:去除QQ浏览器推广</a>
(ps:由于Markdown在简书里对锚点的支持效果不是很好,就没设置跳转)

一、什么是X5内核?

用官方文档的话说,就是解决系统webview兼容性差、加载速度慢、功能缺陷等问题,腾讯QQ浏览器大神们产出的一个WebView可以替换原生WebView。前面不重要,关键是开源的,还能解决我们开发中的一些问题和需求,举个例子:QQ浏览器独立小窗播放视频的功能,还有WebView播放原生H5Video难以很好解决的全屏播放问题~~~~....用X5都能解决。官方文档入口http://x5.tencent.com/doc?id=1004

二、需求场景

解决WebView播放H5 Video全屏问题

尝试过的其他方法

重写WebChromeClient的onShowCustomView开启全屏;onHideCustomView退出全屏。使用过这个方法的人,都应该知道android4.4以后,不会在走这个回调

三、开始搬砖

准备工作:
集成准备工作就不多说了,步骤太简单不过了,就两个文件,一个tbs_sdk....的lib包,一个32位的liblbs.so库。直接可以从官方文档那里下。
需要提一下,如果是Eclipse用户,so库的导入,需要在工程libs目录创建armeabi文件夹,把so库放armeabi目录里(libs——>armeabi);如果是AndroidStudio目录,则直接在main目录下创建jniLib,然后在jniLibs目录下创建armeabi文件夹,再把so放armeabi目录(main——>jniLibs——>armeabi)

简单使用(直接上代码):

X5的WebView还原度非常高,使用起来和原生的WebView基本上是一模一样

MainActiviy

 @Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    // Set layout
    getWindow().setFormat(PixelFormat.TRANSLUCENT);
    setContentView(R.layout.activity_main);
    mWebView = (com.tencent.smtt.sdk.WebView) findViewById(R.id.forum_context);
    mWebView.getSettings().setJavaScriptEnabled(true);// 支持js
    mWebView.getSettings().setUseWideViewPort(true); //自适应屏幕
    mWebView.loadUrl("http://res.ky-express.com/h5/video/72.html");
}

activity_main

<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">

<com.tencent.smtt.sdk.WebView
    android:id="@+id/forum_context"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:paddingLeft="5dp"
    android:paddingRight="5dp"/>

</RelativeLayout>

这个很简单,几分钟就能看到X5的效果了,但是这样只能在部分手机上运行,不能适配大多数手机,原因在于我们只创建并armeabi的目录,也就是说只有arm cpu的手机上才能有效果。

四、优化

1、上述问题,适配所有的cpu的机型

解决方案也很简单,把其他cpu的目录也创建出来就ok了(mips,mips64,x86,x86_64,armeabi-v7a,armeabi,arm64-v8a);第二步就是把上面那个liblbs.so库依次放置到各个cpu目录下即可;最最关键的最后一步,在build.config文件中的defaultConfig里面加上这行配置代码

ndk {
        abiFilters"armeabi","armeabi-v7a","x86","mips"
    }

下面是我项目的build.config配置

defaultConfig {
    applicationId "spanlogistics.oxbix.com.webviewfullscreen"
    minSdkVersion 14
    targetSdkVersion 23
    versionCode 1
    versionName "1.0"

    ndk {
        abiFilters"armeabi","armeabi-v7a","x86","mips"
    }
}

重新运行一下,应该就解决勒。

2、体验的问题

初次启动打开页面时,会有个白屏的过程,大概4秒钟左右(手机配置差的话可能会更长)
原因:使用X5内核需要有个初始化的过程,我们Demo中是直接用的,并未做预初始化的操作,换句话说,如果预初始化完成后,在去打开该就不会出现白屏体验了

解决方案:在我们应用的Application里面去对X5进行预初始化,我们创建一个服务去预加载它,然后在Application中去开启该服务

预初始化X5的服务代码,PreLoadX5Service
 @Nullable
@Override
public IBinder onBind(Intent intent) {
    return null;
}

@Override
public void onCreate() {
    super.onCreate();
    initX5();
    preinitX5WebCore();
}

private void initX5() {
    QbSdk.initX5Environment(getApplicationContext(), QbSdk.WebviewInitType.FIRSTUSE_AND_PRELOAD, cb);
    Log.d("gggbbb","预加载中...");
}

QbSdk.PreInitCallback cb = new QbSdk.PreInitCallback() {

    @Override
    public void onViewInitFinished(boolean arg0) {
        // TODO Auto-generated method stub
        Log.e("0912", " onViewInitFinished is " + arg0);
    }

    @Override
    public void onCoreInitFinished() {
        // TODO Auto-generated method stub

    }
};
 private void preinitX5WebCore() {

    if(!QbSdk.isTbsCoreInited()) {

        // preinit只需要调用一次,如果已经完成了初始化,那么就直接构造view

        QbSdk.preInit(MainActivity.this, null);// 设置X5初始化完成的回调接口

    }
}

Application代码

@Override
public void onCreate() {
    super.onCreate();
    initX5();
}
private void initX5() {
    Intent intent = new Intent(this, PreLoadX5Service.class);
    startService(intent);
}

3、我们会发现集成X5后,项目编译变慢了,如果项目太大的话,还不容易跑起来,可以在主module的build.gradle里面加上下面这段代码试试

 dexOptions {
    javaMaxHeapSize "4g"
    preDexLibraries = false
}

4、一般情况下根据上面操作,就已经完美集成勒,但是自己集成过程中很容易掉的一个坑,就是64位手机上不能使用X5,官方文档中也提到了相应了解决方案,就是把32位的so库直接放到64位的文件夹中当64位使用

补充

看到不少童鞋再问如何去除QQ浏览器推广,其实评论里已经有童鞋给了解决方案,可能有的小伙伴没能看到,在这里做个补充,先感谢下 @StoneHui 童鞋。下面是去除QQ浏览器推广的代码:

 getWindow().getDecorView().addOnLayoutChangeListener(new View.OnLayoutChangeListener() {
            @Override
            public void onLayoutChange(View v, int left, int top, int right, int bottom, int oldLeft, int oldTop, int oldRight, int oldBottom) {
                ArrayList<View> outView = new ArrayList<View>();
                getWindow().getDecorView().findViewsWithText(outView,"QQ浏览器",View.FIND_VIEWS_WITH_TEXT);
                int size = outView.size();
                if(outView!=null&&outView.size()>0){
                    outView.get(0).setVisibility(View.GONE);
                }
            }
     });

怎么加呢?
很简单,直接在使用到X5 Webview的那个Activity里面加上这段代码就ok了

相关文章

网友评论

  • 代码界的泥石流:楼主有没有遇到过 vedio一点击全屏就 界面就卡了的情况么?
  • 韩英明:如何使用h5去掉那个 QQ 浏览器的推广
  • Lucida_star:请问一下,怎么调用支付宝支付界面呢?
  • 苦行者__298c:其实使用调用initX5Environment一个接口就可以了,QbSdk.preInit接口的调用是多余的,反而会导致首次无法加载x5内核
    Easylover_7f89:QbSdk.initX5Enviroment(context,new QbSdk.PreInitCallback{});
    只有这一个接口吗?你能发一下你写的吗?
  • 蜗牛1:您好,我接手的项目好像没有开服务初始化X5只是在引导页面写了 两个方法QbSdk.setTbsListener(new TbsListener(){})
    QbSdk.initX5Environment(getApplicationContext(), new QbSdk.PreInitCallback(){})
    用起来手机如果好的话没问题,但是一旦手机不行就回卡的很,这能解决么?
  • 荆著:视频播放 webView.getX5WebViewExtension().invokeMiscMethod("standardFullScreen", data);打包以后这行总报空指针有遇到吗
    拌饭:@剑出丶群魔伏诛 怎样才能启用x5呢
    962661f1cfbc:官网下的sdk并没有so文件
    喜欢丶下雨天:mWebView.getX5WebViewExtension() 你用这个判断一下 如果为空,说明你还没有启用x5
  • cde86b15d3d6:build.config?
    荆著:视频播放 webView.getX5WebViewExtension().invokeMiscMethod("standardFullScreen", data);打包以后这行总报空指针有遇到吗
    mcp1993:你好,我现在集成了X5,但是第一次打开视频网页的时候是不能播放视频的,第二次之后才可以,请问这是什么问题。第一次加载的是原生的webview,后面加载的才是x5。
    b77535296c81: @沒亊偸著樂 build.gradle
  • silencezwm:腾讯文档太烂了,上个洗手间看到了你的文章,突然觉醒!马上着手修改代码去
  • 王默默:64位手机上怎么办??
  • 花老鼠:视频全屏的时候有个qq浏览器的推广 知道怎么去掉吗
    花老鼠:去不掉,我有在论坛问过
    StoneHui:同问啊,我也想去掉那个 QQ 浏览器的推广
    softSnow:@花老鼠 还有提示我去腾讯视频观看视频的广告,这个大神你是怎么去掉的
  • b3f1cc639f61:我在Activity中可以使用x5内核,但是在frament中调用x5内核却还是系统自带webview
  • e9a0c1f00e8d:317426208 我的QQ,如果有验证信息,麻烦填写 X5 类似的 ,谢啦~ :blush:
  • e9a0c1f00e8d:Hi,最近我也在接入x5,是否可以加个QQ好友交流下呢,

本文标题:腾讯浏览服务X5内核集成

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