赞
踩
(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基本上是一模一样
- @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");
- }
- <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"
- }
- }
重新运行一下,应该就解决勒。
- @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了
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。