转发 腾讯浏览服务X5内核集成

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

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">

android:id="@+id/forum_context"

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:paddingLeft="5dp"

android:paddingRight="5dp"/>

这个很简单,几分钟就能看到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 outView = new ArrayList();

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了


转发链接:http://www.jianshu.com/p/8a7224ff371a

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 157,198评论 4 359
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 66,663评论 1 290
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 106,985评论 0 237
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,673评论 0 202
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 51,994评论 3 285
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,399评论 1 211
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,717评论 2 310
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,407评论 0 194
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,112评论 1 239
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,371评论 2 241
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,891评论 1 256
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,255评论 2 250
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,881评论 3 233
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,010评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,764评论 0 192
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,412评论 2 269
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,299评论 2 260

推荐阅读更多精彩内容