文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

【Android -- 开源库】腾讯 TBS 浏览器 SDK 接入

2023-09-26 11:47

关注

简介

在 Android 开发项目中,经常会用到 Webview 。而 WebView 是出了名的坑,各种 Bug。腾讯 TBS 浏览服务面向应用开发商和广大开发者,提供浏览增强,内容框架,广告体系,H5游戏分发,大数据等服务,能够帮助应用开发商大幅改善应用体验,有效提升开发,运营,商业化的效率。

官网地址: https://x5.tencent.com/

1. 优势

其中,X5云端服务包括云加速、云安全、云转换三大功能。云加速是通过首屏加速、智能路由、图片压缩等技术保障网页浏览的快、省、悦;云安全是通过代理加密、URL安全检测、JS黑名单管理、负载监控等防范网页被劫持插入广告、保障网页浏览的安全稳定;云转换是使用URL聚合+XPATH的解决方案,解决移动阅读难题。

2. 运行环境

使用

1. 基础配置

1.1 SDK 接入

方式一:jar包方式集成(推荐)

您可将官网下载的jar包复制到您的App的libs目录,并且通过Add As Library的方式集成TBS SDK。

前往官网下载SDK

方式二:自动集成
使用 mavenCentral 仓库

在项目级别(通常是根目录下)的 build.gradle 中添加:

repositories {    google()    // 增加这行    mavenCentral()}

在应用级别(通常是 app 模块下)的 build.gradle 中添加依赖:

dependencies {    ...    // 增加这行    implementation 'com.tencent.tbs:tbssdk:44286'}
1.2 权限配置

AndroidManifest.xml 里权限声明

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /><uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /><uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /><uses-permission android:name="android.permission.INTERNET" /><uses-permission android:name="android.permission.READ_PHONE_STATE" /><uses-permission android:name="android.permission.GET_TASKS"/>

2. 代码

2.1 在 Application 初始化 x5 内核接口
        QbSdk.PreInitCallback callback = new QbSdk.PreInitCallback() {            @Override            public void onViewInitFinished(boolean arg) {                //x5內核初始化完成的回调,                // true表示x5内核加载成功,                // false表示x5内核加载失败,会自动切换到系统内核。                Log.i("kevin", "X5内核是否成功加载= " + arg);            }            @Override            public void onCoreInitFinished() {            }        };        QbSdk.setTbsListener(new TbsListener() {            @Override            public void onDownloadFinish(int i) {                Log.i("kevin", "onDownloadFinish: " + i);            }            @Override            public void onInstallFinish(int i) {                Log.i("kevin", "onInstallFinish: " + i);            }            @Override            public void onDownloadProgress(int i) {                Log.i("kevin", "onInstallFinish: " + i);            }        });        QbSdk.initX5Environment(getApplicationContext(), callback);

2.2 初始化 WebSettings

private void initWebSettings() {    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.setAppCacheEnabled(true);    webSetting.setDomStorageEnabled(true);    webSetting.setGeolocationEnabled(true);    webSetting.setAppCacheMaxSize(Long.MAX_VALUE);    webSetting.setPluginState(WebSettings.PluginState.ON_DEMAND);    webSetting.setCacheMode(WebSettings.LOAD_NO_CACHE);}

2.3 简单封装

如果在项目中使用,一般来说最好是封装多一层。

public class ProgressWebView extends WebView {    //进度条    private ProgressBar progressbar;    //进度条的高度,默认10px    private int progressHeight = 10;    public ProgressWebView(Context context) {        this(context,null);    }    public ProgressWebView(Context context, AttributeSet attributeSet) {        super(context, attributeSet);        initView(context);    }    private void initView(Context context) {        //创建进度条        progressbar = new ProgressBar(context, null,                android.R.attr.progressBarStyleHorizontal);        //设置加载进度条的高度        progressbar.setLayoutParams(new AbsoluteLayout.LayoutParams(FrameLayout.LayoutParams.MATCH_PARENT, progressHeight, 0, 0));        Drawable drawable = context.getResources().getDrawable(R.drawable.progress_bar_states);        progressbar.setProgressDrawable(drawable);        //添加进度到WebView        addView(progressbar);        //初始化 WebSettings        initWebSettings();        setWebChromeClient(new WVChromeClient());        setWebViewClient(new WVClient());    }    private void initWebSettings() {        WebSettings webSetting = this.getSettings();        webSetting.setJavaScriptEnabled(true);        webSetting.setJavaScriptCanOpenWindowsAutomatically(true);        webSetting.setAllowFileAccess(true);        webSetting.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.NARROW_COLUMNS);        webSetting.setSupportZoom(true);        webSetting.setBuiltInZoomControls(true);        webSetting.setUseWideViewPort(true);        webSetting.setSupportMultipleWindows(true);        webSetting.setAppCacheEnabled(true);        webSetting.setDomStorageEnabled(true);        webSetting.setGeolocationEnabled(true);        webSetting.setAppCacheMaxSize(Long.MAX_VALUE);        webSetting.setPluginState(WebSettings.PluginState.ON_DEMAND);        webSetting.setCacheMode(WebSettings.LOAD_NO_CACHE);    }    //进度显示    private class WVChromeClient extends WebChromeClient {        @Override        public void onProgressChanged(WebView view, int newProgress) {            if (newProgress == 100) {                progressbar.setVisibility(GONE);            } else {                if (progressbar.getVisibility() == GONE) {                    progressbar.setVisibility(VISIBLE);                }                progressbar.setProgress(newProgress);            }            if (mListener != null) {                mListener.onProgressChange(view, newProgress);            }            super.onProgressChanged(view, newProgress);        }    }    private class WVClient extends WebViewClient {        @Override        public boolean shouldOverrideUrlLoading(WebView view, String url) {            //在当前Activity打开            view.loadUrl(url);            return true;        }        @Override        public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) {            //https忽略证书问题            handler.proceed();        }        @Override        public void onPageFinished(WebView view, String url) {            progressbar.setVisibility(GONE);            if (mListener != null) {                mListener.onPageFinish(view);            }            super.onPageFinished(view, url);        }    }    private onWebViewListener mListener;    public void setOnWebViewListener(onWebViewListener listener) {        this.mListener = listener;    }    //进度回调接口    public interface onWebViewListener {        void onProgressChange(WebView view, int newProgress);        void onPageFinish(WebView view);    }}

来源地址:https://blog.csdn.net/duoduo_11011/article/details/130989566

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-移动开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯