android x5播放视频格式,Android 应用内实现视频播放

阅读: 评论:0

android x5播放视频格式,Android 应用内实现视频播放

android x5播放视频格式,Android 应用内实现视频播放

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

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

接入 TBS

1. 导入 jar 文件和 so 文件

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

2. 初始化 Application

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

@Override

publicvoidonCreate(){

// 回调接口初始化完成接口回调

QbSdk.PreInitCallbackpcb=newQbSdk.PreInitCallback(){

@Override

publicvoidonCoreInitFinished(){

}

@Override

publicvoidonViewInitFinished(booleanb){

//x5 內核初始化完成的回调, 为 true 表示 x5 内核加载成功, 否则表示 x5 内核加载失败, 会自动切换到系统内核.

Log.e("myApplication","x5 内核加载成功?"+b);

}

};

//x5 内核预加载, 异步初始化 x5 webview 所需环境

QbSdk.initX5Environment(getApplicationContext(),pcb);

}

}

在 l 进行声明

android:name=&#h.tbsvideoplay.MyAppliction"

3. 使用

直接在清单文件 l 中配置 SDK 中的视频播放 Activity

android:name=&#t.smtt.sdk.VideoActivity"

android:alwaysRetainTaskState="true"

android:configChanges="orientation|screenSize|keyboardHidden"

android:exported="false"

android:launchMode="singleTask">

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

* 直接调用播放视频

* @param videoUrl 视频地址

*/

privatevoidstartPlay(StringvideoUrl){

// 判断当前是否可用

if(TbsVideo.canUseTbsPlayer(getApplicationContext())){

// 播放视频

TbsVideo.openVideo(getApplicationContext(),videoUrl);

}

}

4. 添加权限

效果图

优化

先看一下优化之后的效果

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

1. 自定义 webview

需继承 TBS 的 webview, 包一定不能导错: t.smtt.sdk.WebViewpublicclassX5WebViewextendsWebView{

privateWebViewClientclient=newWebViewClient(){

/**

* 防止加载网页时调起系统浏览器

*/

publicbooleanshouldOverrideUrlLoading(WebViewview,Stringurl){

view.loadUrl(url);

returntrue;

}

};

@SuppressLint("SetJavaScriptEnabled")

publicX5WebView(Contextarg0,AttributeSetarg1){

super(arg0,arg1);

this.setWebViewClient(client);

initWebViewSettings();

}

/**

* 初始化 webview 设置

*/

privatevoidinitWebViewSettings(){

WebSettingswebSetting&#Settings();

...

}

/**

* 这里可以为自定义 webview 绘制背景或文字

* @param canvas

* @param child

* @param drawingTime

* @return

*/

@Override

protectedbooleandrawChild(Canvascanvas,Viewchild,longdrawingTime){

booleanret=super.drawChild(canvas,child,drawingTime);

canvas.save();

...

returnret;

}

publicX5WebView(Contextarg0){

super(arg0);

setBackgroundColor(85621);

}

}

2. 布局中使用自定义 WebView

android:id="@+id/x5_webview"

android:layout_width="match_parent"

android:layout_height="200dp"

android:scrollbars="none"/>

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

* 使用自定义 webview 播放视频

* @param vedioUrl 视频地址

*/

privatevoidstartPlay(StringvedioUrl){

x5webView.loadUrl(vedioUrl);

getWindow().setFormat(PixelFormat.TRANSLUCENT);

x5webView.setWebChromeClient(newWebChromeClient());

}

4. 支持横竖屏切换

在 l 中给当前 Activity 配置 configChanges 属性

android:name=&#h.tbsvideoplay.VideoPlayActivity"

android:configChanges="orientation|screenSize|keyboardHidden"/>

源码已上传至 GitHub, 需要的可以下载:

来源: .html

本文发布于:2024-02-01 01:37:26,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170672264632906.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23