当前位置: 首页 > news >正文

MediaPlayer+TextureView实现视频播放功能

前面写一些基础知识的学习,这篇写个小demo,实现视频循环播放功能。
1、xml代码:

<TextureViewandroid:id="@+id/textureView"android:layout_width="600px"android:layout_height="400px"android:focusable="false" /> 

2、初始化视频资源,这里把需要播放的视频集成在应用中,位置放在res/raw下。

private void initVideoUri() {mVideoUris = new ArrayList<>();mVideoUris.add(Uri.parse("android.resource://" + getPackageName() + "/" + R.raw.video1));mVideoUris.add(Uri.parse("android.resource://" + getPackageName() + "/" + R.raw.video2));mVideoUris.add(Uri.parse("android.resource://" + getPackageName() + "/" + R.raw.video3));
}

3、初始化TextureView,并设置监听,需求需要给给TextureView加一个圆角,角度是16。

private void initTextureView() {mTextureView = findViewById(R.id.textureView);//加圆角mTextureView.setOutlineProvider(new TextureVideoViewOutlineProvider(16));mTextureView.setClipToOutline(true);mTextureView.setSurfaceTextureListener(new TextureView.SurfaceTextureListener() {@Overridepublic void onSurfaceTextureAvailable(SurfaceTexture surface, int width, int height) {// SurfaceTexture准备就绪,初始化MediaPlayerinitPlayer(surfaceTexture);}@Overridepublic void onSurfaceTextureSizeChanged(SurfaceTexture surface, int width, int height) {// SurfaceTexture缓冲大小变化}@Overridepublic boolean onSurfaceTextureDestroyed(SurfaceTexture surface) {// SurfaceTexture即将被销毁return false;}@Overridepublic void onSurfaceTextureUpdated(SurfaceTexture surface) {// SurfaceTexture通过updateImage更新}});
}

圆角类:

public class TextureVideoViewOutlineProvider extends ViewOutlineProvider {private float mRadius;public TextureVideoViewOutlineProvider(float radius) {this.mRadius = radius;}@Overridepublic void getOutline(View view, Outline outline) {Rect rect = new Rect();view.getGlobalVisibleRect(rect);int leftMargin = 0;int topMargin = 0;Rect selfRect = new Rect(leftMargin, topMargin,rect.right - rect.left - leftMargin, rect.bottom - rect.top - topMargin);outline.setRoundRect(selfRect, mRadius);}}

4、初始化MediaPalyer播放器

private void initPlayer(SurfaceTexture surfaceTexture) {try {mPlayer = new MediaPlayer();mPlayer.setSurface(new Surface(surfaceTexture));mPlayer.setAudioStreamType(AudioManager.STREAM_MUSIC);mPlayer.setDataSource(mContext, mVideoUris.get(0));mPlayer.setOnPreparedListener(new MediaPlayer.OnPreparedListener() {@Overridepublic void onPrepared(MediaPlayer mp) {//这里可以调用start()方法开始播放视频      mPlayer.start(); }}mPlayer.setOnCompletionListener(new MediaPlayer.OnCompletionListener() {@Overridepublic void onCompletion(MediaPlayer mp) {//循环播放列表中的内容if (mPlayIndex < mVideoUris.size() - 1) {mPlayIndex = ++mPlayIndex;} else {mPlayIndex = 0;}Log.e(TAG, "onCompletion - mPlayIndex: " + mPlayIndex);playVideo(mVideoUris.get(index));}}mPlayer.setOnErrorListener(new MediaPlayer.OnErrorListener() {@Overridepublic boolean onError(MediaPlayer mp, int what, int extra) {Log.e(TAG, "onError - what: " + what + " | extra: " + extra);return false;}}mPlayer.prepareAsync();} catch (IOException e) {Log.e(TAG, e.toString());}
}   

5、视频播放

private void playVideo(Uri uri) {try {mPlayer.reset();mPlayer.setDataSource(mContext, uri);mPlayer.prepareAsync();} catch (IOException e) {Log.e(TAG, e.toString());}

6、资源释放

private void releaseMediaPlayer() {if (mPlayer != null) {if (mPlayer.isPlaying()) {mPlayer..stop();}mPlayer.release();}
}

这个demo只是简单实现,具体播放最好放子线程进行。

如何实现TextureView或者SurfaceView 预览框为圆角

相关文章:

MediaPlayer+TextureView实现视频播放功能

前面写一些基础知识的学习&#xff0c;这篇写个小demo&#xff0c;实现视频循环播放功能。 1、xml代码&#xff1a; <TextureViewandroid:id"id/textureView"android:layout_width"600px"android:layout_height"400px"android:focusable&quo…...

webpack 优化

打包优化 webpack 优化1、依赖转化&#xff0c;兼容低版本浏览器2、生产环境关闭sourceMap3、打包输出目录名称修改和静态资源的存放4、修改图标5、修改webpack配置5-1、写在此处的配置可以覆盖掉脚手架本来就预设上有的配置5-2、写在此处的都是预设没有配置的&#xff0c;脚手…...

保障 Golang 项目安全的最佳实践

对任何项目来说&#xff0c;安全都是一个永恒的话题&#xff0c;本文详细讲解一下保障 Golang 项目的安全性需要遵循一些最佳实践。 对源代码和构建出的二进制文件做全面的安全扫描 定期对源代码和二进制文件进行全面的安全扫描&#xff0c;查找漏洞&#xff0c;以便及早识别…...

PG物理备份与恢复之pg_basebackup

PG物理备份与恢复之pg_basebackup 开启WAL日志归档pg_basebackup备份工具全库恢复&#xff1a;recovery.conf &#x1f418; 数据库版本&#xff1a;PostgreSQL 10.4 开启WAL日志归档 通过数据库的全量备份和WAL日志&#xff0c;可以将数据库恢复到任意时间点。每个WAL日志文件…...

npm : 无法将“npm”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保路径正确,然后再试一次。

1 bug描述 使用vscode执行npm run dev指令时出现 “npm : 无法将“npm”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写&#xff0c;如果包括路径&#xff0c;请确保路径正确&#xff0c;然后再试一次 “ 的错误提示&#xff0c;原因是系统里没有安装n…...

Android 13.0 通过驱动实现禁用usb鼠标和usb键盘功能

1.概述 在13.0的系统产品定制化开发中,在进行定制中有关于usb键盘和usb鼠标的需求中,产品要求禁止usb口挂载usb鼠标和usb键盘,所以需要要求在usb挂载类型的时候 判断如果是usb鼠标和usb键盘就不让挂载,这就需要从驱动方面入手来解决这个问题,接下来看下驱动的某些挂载usb…...

Ubuntu 22.04配置/etc/rc.local开机自启文件

1.查看系统版本 rootbogon-virtual-machine:~# lsb_release -a No LSB modules are available. Distributor ID: Ubuntu Description: Ubuntu 22.04 LTS Release: 22.04 Codename: jammy rootbogon-virtual-machine:~ 2. 解决 /etc/rc.local 开机启动问题 看rc-loc…...

python爬虫之正则表达式解析实战

文章目录 1. 图片爬取流程分析2. 实现代码—爬取家常菜图片 1. 图片爬取流程分析 先获取网址&#xff0c;URL&#xff1a;https://www.xiachufang.com/category/40076/ 定位想要爬取的内容使用正则表达式爬取导入模块指定URLUA伪装&#xff08;模拟浏览器&#xff09;发起请求…...

什么是虚拟dom?

虚拟DOM是利用js描述元素与元素的关系&#xff0c;用js对象来表示真实的dom树结构&#xff0c;创建一个虚拟的dom对象。 虚拟DOM的原理是根据真实DOM生成一个js对象&#xff0c;里面有元素、属性和文本&#xff0c;这些与真实DOM中的元素、属性、文本一一对应。虚拟DOM可以更好…...

大数据学习(18)-任务并行度优化

&&大数据学习&& &#x1f525;系列专栏&#xff1a; &#x1f451;哲学语录: 承认自己的无知&#xff0c;乃是开启智慧的大门 &#x1f496;如果觉得博主的文章还不错的话&#xff0c;请点赞&#x1f44d;收藏⭐️留言&#x1f4dd;支持一下博主哦&#x1f91…...

C++学习笔记之四(标准库、标准模板库、vector类)

C 1、C标准库2、C标准模板库2.1、vector2.1.1、vector与array2.1.2、vector与函数对象2.1.3、vector与迭代器2.1.4、vector与算法 1、C标准库 C C C标准库指的是标准程序库( S t a n d a r d Standard Standard L i b a r a y Libaray Libaray)&#xff0c;它定义了十个大类…...

IDEA部署SSM项目mysql数据库MAVEN项目部署教程

如果 SSM 项目是基于 Maven 构建的&#xff0c;则需要配置 maven 环境&#xff0c;否则跳过这一步 步骤一&#xff1a;配置 Maven 第一步&#xff1a;用 IDEA 打开项目&#xff0c;准备配置 maven 环境 &#xff0c;当然如果本地没有提前配置好 maven&#xff0c;就用 IDEA 默…...

uniapp 将流转化为视频并播放 微信小程序

该问题最关键的一步是将后端传回来的流&#xff0c;转化成视频&#xff0c;并播放。 1、从服务器请求数据流到前端 2、新建一个临时文件&#xff0c;将数据流写入这个文件里面&#xff0c;并自定义路径命名。 const fs wx.getFileSystemManager(); //获取全局唯一的文件管理…...

【软考】系统集成项目管理工程师(十)项目质量管理【3分】

一、质量概念 1、定义 国际&#xff1a;反应实体满足主体明确和隐含需求的能力的特性总和 国内&#xff1a;一组固有特性满足要求的程度 2、质量与等级 质量&#xff1a;作为实现的性能或成果&#xff0c;是一系列内在特性满足要求的程度ISO9000 等级&#xff1a;作为设计意…...

七层负载均衡 HAproxy

一、HAproxy 1、负载均衡类型&#xff1a; (1) 无负载均衡&#xff1a; 没有负载均衡&#xff0c;用户直接连接到 Web 服务器。当许多用户同时访问服务器时&#xff0c;可能无法连接。 (2) 四层负载均衡&#xff1a; 用户访问负载均衡器&#xff0c;负载均衡器将用户的请求…...

SQL SELECT TOP, LIMIT, ROWNUM

SQL SELECT TOP 子句 SELECT TOP 子句用于指定要返回的记录数量。 SELECT TOP子句在包含数千条记录的大型表上很有用。返回大量记录会影响性能。 注&#xff1a;并不是所有的数据库系统都支持SELECT TOP子句。MySQL支持LIMIT子句来选择有限数量的记录&#xff0c;而Oracle使用…...

vue3-admin-element框架登录如何修改?

1、找到vite.config.js文件 配置反向代理 2、找到src文件下的user.js文件 3、找到views文件下的login文件 打开找到comp文件夹找到LoginFrom.vue页面进去 把这个改成自己的账户数据&#xff08;密码不一致自行更改&#xff09; 4、找到store文件下的modules下的user.js 5、找到…...

基于mysql的请假系统,java/springboot/jsp/javaweb/tomcat

系统分为 学生/辅导员/超级管理员 登录注册、修改头像、个人资料。 学生登录可以提交请假申请。 辅导员登录可以管理学生信息、管理班级信息、管理课程信息。 超级管理员登陆可以管理用户信息、管理学生信息、管理辅导员信息、管理班级信息、管理二级学院信息、管理课程信息、…...

【Python机器学习】零基础掌握partial_dependence检验、检查

在医疗健康的领域,有一个问题一直困扰着专家——如何从多个健康指标中找出影响患者健康最关键的因素?在这样的场景下,做出准确的预测非常关键,因为它直接关联到患者的生命安全。 解决这一问题的一个有效方法是利用机器学习算法,具体来说就是通过偏依赖图(Partial Depend…...

前端Vue页面中如何展示本地图片

<el-table :data"tableData" stripe style"width: 100%"><el-table-column prop"imgUrl" label"图片"><template v-slot"scope"><img :src "http://localhost:8888/image/ scope.row.imgUrl&qu…...

免费Flash反编译工具:JPEXS Free Flash Decompiler完整使用指南

免费Flash反编译工具&#xff1a;JPEXS Free Flash Decompiler完整使用指南 【免费下载链接】jpexs-decompiler JPEXS Free Flash Decompiler 项目地址: https://gitcode.com/gh_mirrors/jp/jpexs-decompiler 还在为无法打开老旧SWF文件而烦恼吗&#xff1f;想要提取Fla…...

通过taotoken cli工具一键配置多开发环境下的api密钥与端点

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 通过taotoken cli工具一键配置多开发环境下的api密钥与端点 在团队协作或个人多项目开发中&#xff0c;管理不同大模型服务的API密…...

企业内训系统集成Taotoken实现多模型AI助教与可控的交互成本

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 企业内训系统集成Taotoken实现多模型AI助教与可控的交互成本 对于现代企业而言&#xff0c;构建一个高效、智能的内训系统是提升员…...

TinyRS-R1:轻量级遥感视觉语言模型的技术解析与应用

1. TinyRS-R1&#xff1a;轻量级遥感视觉语言模型的技术解析 在遥感图像分析领域&#xff0c;视觉语言模型&#xff08;Vision-Language Models, VLMs&#xff09;正逐渐成为关键技术。这类模型能够同时理解图像内容和自然语言描述&#xff0c;为卫星和航拍图像的分析提供了全新…...

用STM32F401和千分之一精度电阻,我亲手焊了个10位R-2R DAC,误差竟然小于1.5mV

从零打造10位R-2R DAC&#xff1a;高精度电阻与STM32的实战碰撞 在电子设计领域&#xff0c;数模转换器&#xff08;DAC&#xff09;是实现数字信号到模拟信号转换的核心部件。而R-2R梯形电阻网络因其结构简单、成本低廉的特点&#xff0c;成为DIY爱好者实现DAC功能的热门选择。…...

如何在3小时内快速掌握Python SECS/GEM协议实现:secsgem库的终极指南

如何在3小时内快速掌握Python SECS/GEM协议实现&#xff1a;secsgem库的终极指南 【免费下载链接】secsgem Simple Python SECS/GEM implementation 项目地址: https://gitcode.com/gh_mirrors/se/secsgem 你是否正在寻找一个简单高效的Python SECS/GEM协议实现方案&…...

告别手动抢号烦恼:Python健康160自动挂号完整指南

告别手动抢号烦恼&#xff1a;Python健康160自动挂号完整指南 【免费下载链接】health160 健康160自动挂号脚本&#xff0c;用魔法对抗魔法&#xff0c;禁止商用&#x1f596; 项目地址: https://gitcode.com/gh_mirrors/he/health160 还在为每次打开医院预约网站都看到…...

JWT安全实战:从算法漏洞到生产级防御体系

1. 为什么JWT不是“自带安全”的令牌&#xff0c;而是一把双刃剑JWT&#xff08;JSON Web Token&#xff09;在现代Web应用中几乎无处不在——登录成功后返回一串Base64Url编码的字符串&#xff0c;前端存进localStorage&#xff0c;后续请求带上Bearer头&#xff0c;后端解析、…...

如何突破Windows远程桌面限制?RDP Wrapper Library让家庭版也能支持多人连接

如何突破Windows远程桌面限制&#xff1f;RDP Wrapper Library让家庭版也能支持多人连接 【免费下载链接】rdpwrap RDP Wrapper Library 项目地址: https://gitcode.com/gh_mirrors/rd/rdpwrap 你是否曾因Windows家庭版无法支持多人远程桌面连接而感到困扰&#xff1f;R…...

终极指南:如何用Blender 3MF插件实现3D打印数据无损传递

终极指南&#xff1a;如何用Blender 3MF插件实现3D打印数据无损传递 【免费下载链接】Blender3mfFormat Blender add-on to import/export 3MF files 项目地址: https://gitcode.com/gh_mirrors/bl/Blender3mfFormat 你是否曾经在3D打印工作流中遇到过这样的问题&#x…...