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

时间:2022-09-22 10:03:59

TBS视频播放

TBS视频播放器可以支持市面上几乎所有的视频格式,包括mp4, flv, avi, 3gp, webm, ts, ogv, m3u8, asf, wmv, rm, rmvb, mov, mkv等18种视频格式。同时支持硬件解码,使得内存占用,稳定性相较于系统播放器都更优。

接入TBS

1.导入jar文件和so文件

官网SDK下载地址:https://x5.tencent.com/tbs/sdk.html,示例中有jar文件和so文件,具体导入方式我上一篇文章有详细介绍(Android应用内展示office文件–腾讯浏览服务(TBS)

2.初始化Application

自定义一个Application类,对X5内核进行初始化

public class MyAppliction extends Application {
@Override
public void onCreate() {
super.onCreate();
//回调接口初始化完成接口回调
QbSdk.PreInitCallback pcb=new QbSdk.PreInitCallback() {
@Override
public void onCoreInitFinished() { }
@Override
public void onViewInitFinished(boolean b) {
//x5內核初始化完成的回调,为true表示x5内核加载成功,否则表示x5内核加载失败,会自动切换到系统内核。
Log.e("myApplication", " x5内核加载成功?" + b);
}
}; //x5内核预加载,异步初始化x5 webview所需环境
QbSdk.initX5Environment(getApplicationContext(), pcb);
}
}

在AndroidManifest.xml进行声明

<application
android:name="com.example.xch.tbsvideoplay.MyAppliction"

3.使用

直接在清单文件AndroidManifest.xml中配置SDK中的视频播放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>

在代码中直接调用TbsVideo.openVideo()播放

/**
* 直接调用播放视频
* @param videoUrl 视频地址
*/
private void startPlay(String videoUrl){
//判断当前是否可用
if(TbsVideo.canUseTbsPlayer(getApplicationContext())){
//播放视频
TbsVideo.openVideo(getApplicationContext(), videoUrl);
}
}

4.添加权限

<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.READ_SETTINGS" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<!-- 硬件加速对X5视频播放有利,建议开启 -->
<uses-permission android:name="android.permission.GET_TASKS" />

效果图

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

 优化


先看一下优化之后的效果

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

自定义TBS的WebView,充分发挥X5内核的作用

1.自定义webview

需继承TBS的webview,包一定不能导错:com.tencent.smtt.sdk.WebView

public class X5WebView extends WebView {
private WebViewClient client = new WebViewClient() {
/**
* 防止加载网页时调起系统浏览器
*/
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return true;
}
}; @SuppressLint("SetJavaScriptEnabled")
public X5WebView(Context arg0, AttributeSet arg1) {
super(arg0, arg1);
this.setWebViewClient(client);
initWebViewSettings();
this.getView().setClickable(true);
} /**
* 初始化webview设置
*/
private void initWebViewSettings() {
WebSettings webSetting = this.getSettings();
...
} /**
* 这里可以为自定义webview绘制背景或文字
* @param canvas
* @param child
* @param drawingTime
* @return
*/
@Override
protected boolean drawChild(Canvas canvas, View child, long drawingTime) {
boolean ret = super.drawChild(canvas, child, drawingTime);
canvas.save();
...
return ret;
} public X5WebView(Context arg0) {
super(arg0);
setBackgroundColor(85621);
}
}

2.布局中使用自定义WebView

<com.example.xch.tbsvideoplay.tools.X5WebView
android:id="@+id/x5_webview"
android:layout_width="match_parent"
android:layout_height="200dp"
android:scrollbars="none" />

3.使用自定义WebView播放视频

/**
* 使用自定义webview播放视频
* @param vedioUrl 视频地址
*/
private void startPlay(String vedioUrl) {
x5webView.loadUrl(vedioUrl);
getWindow().setFormat(PixelFormat.TRANSLUCENT);
x5webView.getView().setOverScrollMode(View.OVER_SCROLL_ALWAYS);
x5webView.setWebChromeClient(new WebChromeClient());
}

4.支持横竖屏切换

在AndroidManifest.xml中给当前Activity配置configChanges属性

<activity
android:name="com.example.xch.tbsvideoplay.VideoPlayActivity"
android:configChanges="orientation|screenSize|keyboardHidden"/>

源码已上传至GitHub,需要的可以下载: https://github.com/yangxch/TBSVideoPlay


更多技术干货,欢迎关注我的公众号:ChaoYoung

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

Android应用内实现视频播放--腾讯浏览服务(TBS)的更多相关文章

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

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

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

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

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

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

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

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

  5. TencentTbs腾讯浏览服务 x5内核使用

    Tencent TBS (下简称TBS) 腾讯浏览服务 What is it? 百度百科解释: 腾讯浏览服务(Tencent Browsing Service,以下简称TBS),由腾讯X5浏览服务升级 ...

  6. 集成TBS&lpar;腾讯浏览服务&rpar;x5内核的webView

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

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

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

  8. 记一次腾讯TBS浏览服务集成实践

    这次的分享源于最近的实际开发工作. 项目需求是 在原生Android应用中嵌入WebView,放置用于支撑音视频直播业务的Web页: 另外还需提供Word.Excel.PowerPoint.PDF等常 ...

  9. Android获取内置sdcard跟外置sdcard路径

    Android获取内置sdcard跟外置sdcard路径.(测试过两个手机,亲测可用) 1.先得到外置sdcard路径,这个接口是系统提供的标准接口. 2.得到上一级文件夹目录 3.得到该目录的所有文 ...

随机推荐

  1. dp重拾-01背包--HDU 2602

    Many years ago , in Teddy’s hometown there was a man who was called “Bone Collector”. This man like ...

  2. 用jquery 实现 超出字符 截断加上省略号并且可以提示全部内容

    1.test.jsp Java代码 <%@ page language="java" pageEncoding="UTF-8"%> <html ...

  3. Linux kernel &OpenCurlyQuote;uio&lowbar;mmap&lowbar;physical’函数缓冲区溢出漏洞

    漏洞名称: Linux kernel ‘uio_mmap_physical’函数缓冲区溢出漏洞 CNNVD编号: CNNVD-201311-154 发布时间: 2013-11-13 更新时间: 201 ...

  4. asp&period;net core利用DI实现自定义用户系统,脱离ControllerBase&period;User

    前言 很多时候其实我们并不需要asp.net core自带的那么复杂的用户系统,基于角色,各种概念,还得用EF Core,而且在web应用中都是把信息存储到cookie中进行通讯(我不喜欢放cooki ...

  5. nginx常用场景

    1.浏览器缓存 server { listen 8083; server_name 127.0.0.1; sendfile on; access_log /var/log/nginx/static_s ...

  6. python学习day22 面向对象&lpar;四&rpar; 约束&amp&semi;反射

    1.栈与队列 栈:类似弹夹,先进后出 队列:类似水管,先进先出 class Stack(object): """ 先进后出 """ def ...

  7. openStack虚拟机error 错误状态基于差异镜像&plus;基镜像做恢复

  8. Centos下查看和修改网卡Mac地址

    linux/Centos下查看网卡Mac地址,输入命令: #ifconfig -a eth0 Link encap:Ethernet HWaddr 00:e4:56:2E:D8:20 00:e4:56 ...

  9. webkit内核的浏览器为什么removeAttribute&lpar;&&num;39&semi;style&&num;39&semi;&rpar;会失效&quest;

    做了一些研究,应该算是理清了问题. 首先,我们在这里常说的「属性」(attributes)其实分为两种:内容属性(content attributes)以及 IDL 属性(IDL attributes ...

  10. Android ADT远程主机强迫关闭了一个现有的连接 Connection attempts&colon; 1 解决方法

    adb有一个限制, 也可以说是bug.  当手机上同时运行的进程数大于64时, 就会引发adb奔溃. 更深层次的原因, 就是windows API的WaitForMultipleObjects所支持的 ...