轉(zhuǎn)自http://www.reibang.com/p/8a7224ff371a
什么是X5內(nèi)核?
用官方文檔的話(huà)說(shuō),就是解決系統(tǒng)webview兼容性差葵陵、加載速度慢分瘦、功能缺陷等問(wèn)題蘸泻,騰訊QQ瀏覽器大神們產(chǎn)出的一個(gè)WebView可以替換原生WebView。前面不重要嘲玫,關(guān)鍵是開(kāi)源的悦施,還能解決我們開(kāi)發(fā)中的一些問(wèn)題和需求,舉個(gè)例子:QQ瀏覽器獨(dú)立小窗播放視頻的功能去团,還有WebView播放原生H5Video難以很好解決的全屏播放問(wèn)題~~~~....用X5都能解決抡诞。官方文檔入口http://x5.tencent.com/doc?id=1004
需求場(chǎng)景
解決WebView播放H5 Video全屏問(wèn)題
嘗試過(guò)的其他方法
重寫(xiě)WebChromeClient的onShowCustomView開(kāi)啟全屏;onHideCustomView退出全屏土陪。使用過(guò)這個(gè)方法的人昼汗,都應(yīng)該知道android4.4以后,不會(huì)在走這個(gè)回調(diào)
開(kāi)始搬磚
準(zhǔn)備工作:
集成準(zhǔn)備工作就不多說(shuō)了鬼雀,步驟太簡(jiǎn)單不過(guò)了顷窒,就兩個(gè)文件,一個(gè)tbs_sdk....的lib包源哩,一個(gè)32位的liblbs.so庫(kù)鞋吉。直接可以從官方文檔那里下出刷。
需要提一下,如果是Eclipse用戶(hù)坯辩,so庫(kù)的導(dǎo)入馁龟,需要在工程libs目錄創(chuàng)建armeabi文件夾,把so庫(kù)放armeabi目錄里(libs——>armeabi)漆魔;如果是AndroidStudio目錄坷檩,則直接在main目錄下創(chuàng)建jniLib,然后在jniLibs目錄下創(chuàng)建armeabi文件夾改抡,再把so放armeabi目錄(main——>jniLibs——>armeabi)
簡(jiǎn)單使用(直接上代碼):
X5的WebView還原度非常高矢炼,使用起來(lái)和原生的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); //自適應(yīng)屏幕
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>
這個(gè)很簡(jiǎn)單,幾分鐘就能看到X5的效果了阿纤,但是這樣只能在部分手機(jī)上運(yùn)行句灌,不能適配大多數(shù)手機(jī),原因在于我們只創(chuàng)建并armeabi的目錄欠拾,也就是說(shuō)只有arm cpu的手機(jī)上才能有效果胰锌。
優(yōu)化
1、上述問(wèn)題藐窄,適配所有的cpu的機(jī)型
解決方案也很簡(jiǎn)單资昧,把其他cpu的目錄也創(chuàng)建出來(lái)就ok了(mips,mips64荆忍,x86格带,x86_64,armeabi-v7a刹枉,armeabi叽唱,arm64-v8a);第二步就是把上面那個(gè)liblbs.so庫(kù)依次放置到各個(gè)cpu目錄下即可微宝;最最關(guān)鍵的最后一步棺亭,在build.config文件中的defaultConfig里面加上這行配置代碼
ndk {
abiFilters"armeabi","armeabi-v7a","x86","mips"
}
下面是我項(xiàng)目的build.config配置
defaultConfig {
applicationId "spanlogistics.oxbix.com.webviewfullscreen"
minSdkVersion 14
targetSdkVersion 23
versionCode 1
versionName "1.0"
ndk {
abiFilters"armeabi","armeabi-v7a","x86","mips"
}
}
重新運(yùn)行一下,應(yīng)該就解決勒芥吟。
2侦铜、體驗(yàn)的問(wèn)題专甩,初次啟動(dòng)打開(kāi)頁(yè)面時(shí)钟鸵,會(huì)有個(gè)白屏的過(guò)程,大概4秒鐘左右(手機(jī)配置差的話(huà)可能會(huì)更長(zhǎng))
原因:使用X5內(nèi)核需要有個(gè)初始化的過(guò)程涤躲,我們Demo中是直接用的棺耍,并未做預(yù)初始化的操作,換句話(huà)說(shuō)种樱,如果預(yù)初始化完成后蒙袍,在去打開(kāi)該就不會(huì)出現(xiàn)白屏體驗(yàn)了
解決方案:在我們應(yīng)用的Application里面去對(duì)X5進(jìn)行預(yù)初始化俊卤,我們創(chuàng)建一個(gè)服務(wù)去預(yù)加載它,然后在Application中去開(kāi)啟該服務(wù)
預(yù)初始化X5的服務(wù)代碼,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只需要調(diào)用一次害幅,如果已經(jīng)完成了初始化消恍,那么就直接構(gòu)造view
// 設(shè)置X5初始化完成的回調(diào)接口
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、我們會(huì)發(fā)現(xiàn)集成X5后以现,項(xiàng)目編譯變慢了狠怨,如果項(xiàng)目太大的話(huà),還不容易跑起來(lái)邑遏,可以在build.config里面加上下面這段代碼試試
dexOptions {
javaMaxHeapSize "4g" preDexLibraries = false
}
4佣赖、一般情況下根據(jù)上面操作,就已經(jīng)完美集成勒记盒,但是自己集成過(guò)程中很容易掉的一個(gè)坑憎蛤,就是64位手機(jī)上不能使用X5,官方文檔中也提到了相應(yīng)了解決方案纪吮。我們上述操作其實(shí)也已經(jīng)規(guī)避了64位的問(wèn)題俩檬。