Tencent TBS (下简称TBS)

腾讯浏览服务

What is it?

百度百科解释:

腾讯浏览服务(Tencent Browsing Service,以下简称TBS),由腾讯X5浏览服务升级而来,作为业界首个升级至X5 blink内核,与Android 5.0 版本的Chromium M37一致,解决了Android 多平台兼容性问题。

在我们的手机上如何找到它?微信打开一片公众号的文章,下拉会出现(QQ浏览器X5内核提供技术支持)。QQ/TIM内置浏览器。QQ浏览器,都使用了x5内核。

TIM?如果你还没有用过Tim,可以点击下面的连接进行下载(个人感觉比QQ好用):

https://tim.qq.com/htdocs/vip/share.html?_wv=16777216&_wvSb=1&uid=*St*MzM3MDgxMjY3

Why use it?

  • 让你的app实现基本网页加载(类浏览器功能)
  • 让你的app实现播放视频功能
  • 让你的app实现播放直播流功能

How use it?

  • 第一步:访问TBS官网,下载SDK for Android
  • 第二步:根据集成文档,集成到自己的项目中
  • 第三步:编写自己的代码进行测试。

下载TBS SDK

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



点击首页的SDK下载,

点击下载完整版,或者点击分享链接:

链接:https://pan.baidu.com/s/1jJujWiE 密码:sxkg

点击下载SDK接入示例-Android Studio,或者点击分享链接:

链接:链接:https://pan.baidu.com/s/1kW0T44v 密码:ca11

SDK集成

  1. 解压SDK压缩包,复制里面的jar包到自己工程里面的libs(tbs_sdk_thirdapp_v3.5.0.1004_43500_sharewithdownload_withoutGame_obfs_20170801_113025)文件夹中
  2. 添加jar包到构建路径。如下图

  3. 查看官方接入文档:https://x5.tencent.com/tbs/guide/sdkInit.html

  4. 添加so文件支持,解压SDK接入示例-Android Studio压缩包,复制jniLibs文件夹,粘贴到自己工程main包下。具体的操作查看:https://x5.tencent.com/tbs/technical.html#/detail/sdk/1/34cf1488-7dc2-41ca-a77f-0014112bcab7



5. 添加权限:在清单文件中添加如下权限


<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"/>
  1. 在项目的Application中初始化x5内核

/**
*初始化X5
*/
private void initX5() {
QbSdk.initX5Environment(this, new QbSdk.PreInitCallback() {
@Override
public void onCoreInitFinished() { } @Override
public void onViewInitFinished(boolean b) { }
});
}
  1. 如果想实现视频播放功能可以在清单文件中配置该Activity
     <activity
android:name="com.tencent.smtt.sdk.VideoActivity"
android:alwaysRetainTaskState="true"
android:configChanges="orientation|screenSize|keyboardHidden"
android:exported="false"
android:launchMode="singleTask"> <intent-filter>
<action android:name="com.tencent.smtt.tbs.video.PLAY"/>
<category android:name="android.intent.category.DEFAULT"/>
</intent-filter>
</activity>

编写代码进行测试。

MainActivity.java

public class MainActivity extends AppCompatActivity implements View.OnClickListener {
private Button btnOpenUrl;
private Button btnOpenMp4;
private Button btnOpenM3u8;
private Button btnOpenRtmp;
private FrameLayout mFl_web_view_layout;
private WebView mWebView; /**
* 打开的Url
*/
private String openUrl = "http://www.wintp.top";
/**
* m3u8视频的地址
*/
private String m3u8Url = "http://www.flashls.org/playlists/test_001/stream_1000k_48k_640x360.m3u8";
/**
* m3u8视频的地址
*/
private String mp4Url = "http://v.cctv.com/flash/mp4video6/TMS/2011/01/05/cf752b1c12ce452b3040cab2f90bc265_h264818000nero_aac32-1.mp4";
/**
* rtmp视频的地址 香港卫视:rtmp://live.hkstv.hk.lxdns.com/live/hks
*/
private String rtmp8Url = "rtmp://live.hkstv.hk.lxdns.com/live/hks"; @Override
public void onClick(View v) {
if (v == btnOpenUrl) {
//加载URL
initWebView();
} else if (v == btnOpenMp4) {
startVideo(mp4Url); } else if (v == btnOpenM3u8) {
startVideo(m3u8Url); } else if (v == btnOpenRtmp) {
startVideo(rtmp8Url); }
} /**
* 播放视频
*
* @param url
*/
public void startVideo(String url) {
//判断当前Tbs播放器是否已经可以使用。
//public static boolean canUseTbsPlayer(Context context)
//直接调用播放接口,传入视频流的url
//public static void openVideo(Context context, String videoUrl)
//extraData对象是根据定制需要传入约定的信息,没有需要可以传如null
//public static void openVideo(Context context, String videoUrl, Bundle extraData) if ((TbsVideo.canUseTbsPlayer(this))) {
//可以播放视频
TbsVideo.openVideo(this, url); } else {
Toast.makeText(this, "视频播放器没有准备好", Toast.LENGTH_SHORT).show();
} } @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); //x5 设置键盘
getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_ADJUST_RESIZE
| WindowManager.LayoutParams.SOFT_INPUT_STATE_HIDDEN); initView();
} /**
* 初始化View
*/
private void initView() {
btnOpenUrl = findViewById(R.id.btn_open_url);
btnOpenMp4 = findViewById(R.id.btn_open_mp4);
btnOpenM3u8 = findViewById(R.id.btn_open_m3u8);
btnOpenRtmp = findViewById(R.id.btn_open_rtmp);
mFl_web_view_layout = findViewById(R.id.fl_web_view_layout); btnOpenUrl.setOnClickListener(this);
btnOpenMp4.setOnClickListener(this);
btnOpenM3u8.setOnClickListener(this);
btnOpenRtmp.setOnClickListener(this); } /**
* 初始化WebView
*/
private void initWebView() {
//采用new WebView的方式进行动态的添加WebView
//WebView 的包一定要注意不要导入错了
//com.tencent.smtt.sdk.WebView; mWebView = new WebView(this); LinearLayout.LayoutParams layoutParams =
new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT,
LinearLayout.LayoutParams.MATCH_PARENT); mWebView.setLayoutParams(layoutParams); mWebView.loadUrl(openUrl);
WebSettings settings = mWebView.getSettings(); mWebView.setWebViewClient(new WebViewClient() {
@Override
public boolean shouldOverrideUrlLoading(WebView webView, String url) { webView.loadUrl(url); return true;
} @Override
public void onPageStarted(WebView view, String url, Bitmap favicon) {
//设定加载开始的操作 } @Override
public void onPageFinished(WebView view, String url) {
//设定加载结束的操作
} @Override
public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) {
switch (errorCode) { }
} @Override
public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) {//处理https请
//handler.proceed(); //表示等待证书响应
// handler.cancel(); //表示挂起连接,为默认方式
// handler.handleMessage(null); //可做其他处理
} }); mWebView.setWebChromeClient(new WebChromeClient() {
@Override
public void onProgressChanged(WebView view, int newProgress) {
if (newProgress < 100) {
String progress = newProgress + "%"; } else {
// to do something...
}
} @Override
public void onReceivedTitle(WebView view, String title) {
} }); settings.setJavaScriptEnabled(true); settings.setUseWideViewPort(true); //将图片调整到适合webview的大小 //设置加载图片
settings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.SINGLE_COLUMN);
settings.setDefaultTextEncodingName("utf-8");// 避免中文乱码
mWebView.setScrollBarStyle(View.SCROLLBARS_INSIDE_OVERLAY);
settings.setNeedInitialFocus(false);
settings.setSupportZoom(true);
settings.setLoadWithOverviewMode(true);//适应屏幕
settings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.SINGLE_COLUMN);
settings.setLoadsImagesAutomatically(true);//自动加载图片
settings.setCacheMode(WebSettings.LOAD_DEFAULT
| WebSettings.LOAD_CACHE_ELSE_NETWORK); //将WebView添加到底部布局
mFl_web_view_layout.removeAllViews();
mFl_web_view_layout.addView(mWebView);
} @Override
public void onBackPressed() {
//监听返回键,判断webview是否能够后退,如果能后退,则执行后退功能如不能后退,则关闭该页面
if (mWebView.canGoBack()) {
mWebView.goBack();
} else {
finish();
} } @Override
protected void onResume() {
super.onResume();
if (mWebView != null) {
mWebView.onResume();
}
} @Override
protected void onPause() {
super.onPause();
if (mWebView != null) {
mWebView.onPause();
}
} @Override
protected void onDestroy() { //在Activity销毁的时候同时销毁WebView
//如没有此操作,可能会出现,当你在网页上播放一个视频的时候,直接按home键退出应用,视频仍在播放
if (mWebView != null) {
mWebView.destroy();
mFl_web_view_layout.removeView(mWebView);
mWebView = null;
} super.onDestroy();
}
}

activity_main.xml

    <?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"> <Button
android:id="@+id/btn_open_url"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="打开 wintp.top"/> <Button
android:id="@+id/btn_open_mp4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="打开 mp4"/> <Button
android:id="@+id/btn_open_m3u8"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="打开直播流(m3u8)"/> <Button
android:id="@+id/btn_open_rtmp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="打开直播流(rtmp)"/> <FrameLayout
android:id="@+id/fl_web_view_layout"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1"/>
</LinearLayout>

MyApp.java

    package top.wintp.mytbsdemo;

    import android.app.Activity;
import android.app.Application;
import android.os.Bundle; import com.tencent.smtt.sdk.QbSdk; /**
* 作者: pyfysf
* <p>
* qq: 337081267
* <p>
* CSDN: http://blog.csdn.net/pyfysf
* <p>
* 个人博客: http://wintp.top
* <p>
* 时间: 2018/01/2018/1/22 15:42
* <p>
* 邮箱: pyfysf@163.com
*/
public class MyApp extends Application {
@Override
public void onCreate() {
super.onCreate(); initX5(); } /**
* 初始化X5
*/
private void initX5() {
QbSdk.initX5Environment(this, new QbSdk.PreInitCallback() {
@Override
public void onCoreInitFinished() { } @Override
public void onViewInitFinished(boolean b) { }
});
}
}

该项目的github地址:

https://github.com/pyfysf/MyTbsDemo.git

注意:

视频功能:TBS 支持mp4,rmvb,flv,avi等26种视频格式。

本文只举:mp4,m3u8,rtmp三个格式。

TencentTbs腾讯浏览服务 x5内核使用的更多相关文章

  1. 腾讯浏览服务X5内核集成

    腾讯浏览服务X5内核集成https://www.jianshu.com/p/8a7224ff371a TBS 腾讯浏览器服务接入文档https://x5.tencent.com/tbs/guide/s ...

  2. 集成TBS(腾讯浏览服务)x5内核的webView

    由于公司产品需要展示html5页面,一开始我使用的是android自带webview,一些简单的页面没什么问题,但是碰到比较复杂的页面就让人无语了. 1.Android各大厂商都有自己定制的ROM,导 ...

  3. Android使用腾讯浏览服务X5内核

    [前期准备] 腾讯X5 jar包下载地址 [点击打开] 本次完整DEMO源码 [打开Github] [集成步骤] 第一步:下载jar包添加到项目 第二步:添加权限 <uses-permissio ...

  4. MyX5TbsDemo【体验腾讯浏览服务Android SDK (完整版)】

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 按照官网上的说明:可独立下载x5内核,也可共享使用微信或手Q的x5内核. 本Demo在引用腾讯X5内核的基础上进行了封装.参考< ...

  5. Android应用内实现视频播放--腾讯浏览服务(TBS)

    TBS视频播放 TBS视频播放器可以支持市面上几乎所有的视频格式,包括mp4, flv, avi, 3gp, webm, ts, ogv, m3u8, asf, wmv, rm, rmvb, mov, ...

  6. MyX5TbsPlusDemo【体验腾讯浏览服务Android SDK (TbsPlus 版)】

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 按照官网上的说明:只需接入aar文件和调用一个接口即可完成TBS接入,我们会通过全屏Activity展示TBS WebView,适用 ...

  7. Android应用内展示office文件--腾讯浏览服务(TBS)

    什么是TBS  依托 X5 内核强大的能力,致力于提供优化移动端浏览体验的整套解决方案(官网介绍).我们可利用其做文件浏览功能,支持多种文件格式,完全可以满足需求.更多介绍请看官网:http://x5 ...

  8. android 腾讯x5内核 浏览器

    1.浏览器内核: 主流浏览器内核介绍(前端开发值得了解的浏览器内核历史) 浏览器内核历史介绍: 在android 4.4之前,浏览器用的还是webkit 在android 4.4之后,google就抛 ...

  9. 安卓开发笔记(二十四):手把手教你一步步集成腾讯X5内核(Tencent TBS X5)

    1.为什么要集成腾讯X5内核? X5内核相对于系统webview,具有下述明显优势: 1) 速度快:相比系统webview的网页打开速度有30+%的提升: 2) 省流量:使用云端优化技术使流量节省20 ...

随机推荐

  1. MinGW gcc 生成动态链接库 dll 的一些问题汇总(由浅入深,很详细)

    网络上关于用 MinGW gcc 生成动态链接库的文章很多.介绍的方法也都略有不同.这次我在一个项目上刚好需要用到,所以就花了点时间将网上介绍的各种方法都实验了一遍.另外,还根据自己的理解试验了些网上 ...

  2. c# 计算字符串和文件的MD5值的方法

    快速使用Romanysoft LAB的技术实现 HTML 开发Mac OS App,并销售到苹果应用商店中.   <HTML开发Mac OS App 视频教程> 土豆网同步更新:http: ...

  3. 一次C#和C++的实际应用性能比较(C++允许我们使用任何手段来提高效率,只要愿意做出足够的努力)

    05年时,在微软的Rico Mariani做了一次实际应用的C#和C++的性能比较.事情起源于微软著名的元老Raymond Chen(在下敬仰的超级牛人)用C++写了一个英汉词典程序,来描述讲解优化C ...

  4. How Qt Signals and Slots Work(感觉是通过Meta根据名字来调用)

    Qt is well known for its signals and slots mechanism. But how does it work? In this blog post, we wi ...

  5. VS2010下编译配置Boost_1.53

    一.准备工作 1.下载最新版本的boost库.所在地址:boost_1_53_0.zip.官方推荐7z压缩格式的,因为其压缩效率更好,相应包的大小也比较小. 2.解压缩到指定目录,如C:\boost_ ...

  6. 分享android ADT百度云盘下载地址

    由于android官网经常无法打开,特意把最新的android ADT和SDK放到了百度云盘进行了分享,目录中包含Windows和Macbook两种平台的版本,请自行选择: http://pan.ba ...

  7. Liferay6.1 配置友好的URL映射

    说明:以下内容和官方文档相差不大,如果您英文较好,建议直接去读官方文档,地址是:https://dev.liferay.com/develop/tutorials/-/knowledge_base/6 ...

  8. MSVBVM60.dll中函数

    本文转载!!! 原文作者:飘云(飘云阁安全论坛) 原文地址:http://www.chinapyg.com/forum.php?mod=viewthread&tid=2225&high ...

  9. 附008.Kubernetes TLS证书介绍及创建

    一 Kubernetes证书 1.1 TLS Kubernetes系统的各个组件需要使用TLS证书对其通信加密以及授权认证,建议在部署之前先生成相关的TLS证书. 1.2 CA证书创建方式 kuber ...

  10. Java8新特性——lambda表达式.(案例:公司业务)

    需求:现有一个员工姓名list,其中包含单字母索引.要求输出一个字符串,去掉所有单字母,所有名字首字母大写并用逗号隔开. package cn._2.thecompanyprocess; import ...