android 快速教你集成騰訊X5內(nèi)核

前言:本來(lái)android 自4.0之后已經(jīng)優(yōu)化了內(nèi)核,改用了了chrome內(nèi)核,兼容了大部分網(wǎng)頁(yè),這不第三方使用了一個(gè)直播,強(qiáng)烈要求使用騰訊X5的內(nèi)核,說(shuō)是兼容更好一點(diǎn),既然這樣,我就集成試試,下面教你快速集成:

1.騰訊瀏覽服務(wù)官方:https://x5.tencent.com/tbs/sdk.html

image.png

然后導(dǎo)入:


image.png

image.png

這個(gè)官方demo都有,放在自己的項(xiàng)目下,然后再BaseApplication里面初始化一下:


image.png

附上代碼:

private void initX5Web() {
QbSdk.PreInitCallback cb = new QbSdk.PreInitCallback() {
@Override
public void onViewInitFinished(boolean arg0) {
//x5內(nèi)核初始化完成的回調(diào),為true表示x5內(nèi)核加載成功,否則表示x5內(nèi)核加載失敗,會(huì)自動(dòng)切換到系統(tǒng)內(nèi)核。
MyLog.d("x5WebApp", " onViewInitFinished is " + arg0);
}
@Override
public void onCoreInitFinished() {
}
};
//x5內(nèi)核初始化接口
QbSdk.initX5Environment(getApplicationContext(), cb);
}

然后寫(xiě)個(gè)webview繼承騰訊X5的webview,記得千萬(wàn)別倒錯(cuò)包哦!

代碼如下:

package com.hsz88.zbx.x5webview;

import android.annotation.SuppressLint;
import android.content.Context;
import android.util.AttributeSet;

import com.hsz88.zbx.base.BaseApplication;
import com.hsz88.zbx.constant.StaticConfig;
import com.hsz88.zbx.webview.DefaultJsObject;
import com.tencent.smtt.sdk.WebSettings;
import com.tencent.smtt.sdk.WebSettings.LayoutAlgorithm;
import com.tencent.smtt.sdk.WebView;
import com.tencent.smtt.sdk.WebViewClient;

/**

  • Author: KuenCheung

  • Email: zhang_quan_888@163.com

  • Time: 2018/12/4

  • Description:
    */
    public class X5WebView extends WebView {
    private WebViewClient client = new WebViewClient() {
    // 防止加載網(wǎng)頁(yè)時(shí)調(diào)起系統(tǒng)瀏覽器
    public boolean shouldOverrideUrlLoading(WebView view, String url) {
    view.loadUrl(url);
    return true;
    }
    };

    public X5WebView(Context arg0) {
    super(arg0);
    setBackgroundColor(85621);
    }

    @SuppressLint("SetJavaScriptEnabled")
    @Deprecated
    public X5WebView(Context arg0, AttributeSet arg1) {
    super(arg0, arg1);
    this.setWebViewClient(client);
    // this.setWebChromeClient(chromeClient);
    // WebStorage webStorage = WebStorage.getInstance();
    initWebViewSettings();
    this.getView().setClickable(true);
    }

    @SuppressLint("SetJavaScriptEnabled")
    @Deprecated
    private void initWebViewSettings() {
    WebSettings webSetting = this.getSettings();
    webSetting.setJavaScriptEnabled(true);
    webSetting.setJavaScriptCanOpenWindowsAutomatically(true);
    webSetting.setAllowFileAccess(true);
    webSetting.setLayoutAlgorithm(LayoutAlgorithm.NARROW_COLUMNS);
    webSetting.setSupportZoom(true);
    webSetting.setBuiltInZoomControls(true);
    webSetting.setUseWideViewPort(true);
    webSetting.setSupportMultipleWindows(true);
    // webSetting.setLoadWithOverviewMode(true);
    webSetting.setAppCacheEnabled(true);
    // webSetting.setDatabaseEnabled(true);
    webSetting.setDomStorageEnabled(true);
    webSetting.setGeolocationEnabled(true);
    webSetting.setAppCacheMaxSize(Long.MAX_VALUE);
    // webSetting.setPageCacheCapacity(IX5WebSettings.DEFAULT_CACHE_CAPACITY);
    webSetting.setPluginState(WebSettings.PluginState.ON_DEMAND);
    // webSetting.setRenderPriority(WebSettings.RenderPriority.HIGH);
    webSetting.setCacheMode(WebSettings.LOAD_NO_CACHE);
    //設(shè)置默認(rèn)的JS Object
    addJavascriptInterface(new DefaultJsObject(BaseApplication.mContext), StaticConfig.JS_OBJECT);
    }
    }
    然后,在自己的xml倆面進(jìn)行使用,具體方法和webview一樣,如下:

<com.hsz88.zbx.x5webview.X5WebView
android:id="@+id/default_web"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/white" />
其他操作和webview一樣.

如有其他疑問(wèn),請(qǐng)聯(lián)系:zhang_quan_888@163.com,歡迎指正!
原文地址:https://blog.csdn.net/qq_38508087/article/details/84796831

最后編輯于
?著作權(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)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

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

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