腾讯浏览服务X5内核集成

2017-01-10  本文已影响476人  xiefy

转自http://www.jianshu.com/p/8a7224ff371a

什么是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

<RelativeLayoutxmlns: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();
    preinitX5WebCore();
}

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 
    // 设置X5初始化完成的回调接口 
        QbSdk.preInit(MainActivity.this, cb);
    }
}

Application代码

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

private void initX5() { 
    QbSdk.initX5Environment(this, null); 
    Intent intent = new Intent(this, PreLoadX5Service.class); 
    startService(intent);
}

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

dexOptions { 
    javaMaxHeapSize "4g" preDexLibraries = false
}

4、一般情况下根据上面操作,就已经完美集成勒,但是自己集成过程中很容易掉的一个坑,就是64位手机上不能使用X5,官方文档中也提到了相应了解决方案。我们上述操作其实也已经规避了64位的问题。

上一篇 下一篇

猜你喜欢

热点阅读