騰訊瀏覽服務(wù)X5內(nèi)核集成

轉(zhuǎn)自http://www.itdecent.cn/p/8a7224ff371a

什么是X5內(nèi)核?

用官方文檔的話說,就是解決系統(tǒng)webview兼容性差、加載速度慢、功能缺陷等問題,騰訊QQ瀏覽器大神們產(chǎn)出的一個(gè)WebView可以替換原生WebView。前面不重要,關(guān)鍵是開源的,還能解決我們開發(fā)中的一些問題和需求,舉個(gè)例子:QQ瀏覽器獨(dú)立小窗播放視頻的功能,還有WebView播放原生H5Video難以很好解決的全屏播放問題~~~~....用X5都能解決。官方文檔入口http://x5.tencent.com/doc?id=1004

需求場(chǎng)景

解決WebView播放H5 Video全屏問題
嘗試過的其他方法
重寫WebChromeClient的onShowCustomView開啟全屏;onHideCustomView退出全屏。使用過這個(gè)方法的人,都應(yīng)該知道android4.4以后,不會(huì)在走這個(gè)回調(diào)

開始搬磚

準(zhǔn)備工作:
集成準(zhǔn)備工作就不多說了,步驟太簡(jiǎn)單不過了,就兩個(gè)文件,一個(gè)tbs_sdk....的lib包,一個(gè)32位的liblbs.so庫。直接可以從官方文檔那里下。
需要提一下,如果是Eclipse用戶,so庫的導(dǎo)入,需要在工程libs目錄創(chuàng)建armeabi文件夾,把so庫放armeabi目錄里(libs——>armeabi);如果是AndroidStudio目錄,則直接在main目錄下創(chuàng)建jniLib,然后在jniLibs目錄下創(chuàng)建armeabi文件夾,再把so放armeabi目錄(main——>jniLibs——>armeabi)

簡(jiǎn)單使用(直接上代碼):

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); //自適應(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的目錄,也就是說只有arm cpu的手機(jī)上才能有效果。

優(yōu)化

1、上述問題,適配所有的cpu的機(jī)型

解決方案也很簡(jiǎn)單,把其他cpu的目錄也創(chuàng)建出來就ok了(mips,mips64,x86,x86_64,armeabi-v7a,armeabi,arm64-v8a);第二步就是把上面那個(gè)liblbs.so庫依次放置到各個(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)的問題,初次啟動(dòng)打開頁面時(shí),會(huì)有個(gè)白屏的過程,大概4秒鐘左右(手機(jī)配置差的話可能會(huì)更長)

原因:使用X5內(nèi)核需要有個(gè)初始化的過程,我們Demo中是直接用的,并未做預(yù)初始化的操作,換句話說,如果預(yù)初始化完成后,在去打開該就不會(huì)出現(xiàn)白屏體驗(yàn)了

解決方案:在我們應(yīng)用的Application里面去對(duì)X5進(jìn)行預(yù)初始化,我們創(chuàng)建一個(gè)服務(wù)去預(yù)加載它,然后在Application中去開啟該服務(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)目太大的話,還不容易跑起來,可以在build.config里面加上下面這段代碼試試

dexOptions { 
    javaMaxHeapSize "4g" preDexLibraries = false
}

4、一般情況下根據(jù)上面操作,就已經(jīng)完美集成勒,但是自己集成過程中很容易掉的一個(gè)坑,就是64位手機(jī)上不能使用X5,官方文檔中也提到了相應(yīng)了解決方案。我們上述操作其實(shí)也已經(jīng)規(guī)避了64位的問題。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容