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

轉(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)題俩檬。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市碾盟,隨后出現(xiàn)的幾起案子豆胸,更是在濱河造成了極大的恐慌,老刑警劉巖巷疼,帶你破解...
    沈念sama閱讀 212,599評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件晚胡,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡嚼沿,警方通過(guò)查閱死者的電腦和手機(jī)估盘,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,629評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)骡尽,“玉大人遣妥,你說(shuō)我怎么就攤上這事∨氏福” “怎么了箫踩?”我有些...
    開(kāi)封第一講書(shū)人閱讀 158,084評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀(guān)的道長(zhǎng)谭贪。 經(jīng)常有香客問(wèn)我境钟,道長(zhǎng),這世上最難降的妖魔是什么俭识? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,708評(píng)論 1 284
  • 正文 為了忘掉前任慨削,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘缚态。我一直安慰自己磁椒,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,813評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布玫芦。 她就那樣靜靜地躺著浆熔,像睡著了一般。 火紅的嫁衣襯著肌膚如雪桥帆。 梳的紋絲不亂的頭發(fā)上蘸拔,一...
    開(kāi)封第一講書(shū)人閱讀 50,021評(píng)論 1 291
  • 那天,我揣著相機(jī)與錄音环葵,去河邊找鬼调窍。 笑死,一個(gè)胖子當(dāng)著我的面吹牛张遭,可吹牛的內(nèi)容都是我干的邓萨。 我是一名探鬼主播,決...
    沈念sama閱讀 39,120評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼菊卷,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼缔恳!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起洁闰,我...
    開(kāi)封第一講書(shū)人閱讀 37,866評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤歉甚,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后扑眉,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體纸泄,經(jīng)...
    沈念sama閱讀 44,308評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,633評(píng)論 2 327
  • 正文 我和宋清朗相戀三年腰素,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了聘裁。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,768評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡弓千,死狀恐怖衡便,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情洋访,我是刑警寧澤镣陕,帶...
    沈念sama閱讀 34,461評(píng)論 4 333
  • 正文 年R本政府宣布,位于F島的核電站姻政,受9級(jí)特大地震影響呆抑,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜扶歪,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,094評(píng)論 3 317
  • 文/蒙蒙 一理肺、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧善镰,春花似錦妹萨、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,850評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至品洛,卻和暖如春树姨,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背桥状。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,082評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工帽揪, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人辅斟。 一個(gè)月前我還...
    沈念sama閱讀 46,571評(píng)論 2 362
  • 正文 我出身青樓转晰,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親士飒。 傳聞我的和親對(duì)象是個(gè)殘疾皇子查邢,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,666評(píng)論 2 350

推薦閱讀更多精彩內(nèi)容