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

Android MediaRecorder 视频录制及报错解决

目录

一、start failed: -19

二、使用MediaRecorder录制视频

2.1 申请权限

2.2 布局文件

2.3 MediaRecordActivity

2.4 运行结果 

三、拓展

3.1 录制视频模糊(解决)

3.2 阿里云OSS上传文件

3.2.1 权限(刚需)

3.2.2 安装SDK

3.2.3 使用 

相关链接


一、start failed: -19

        根据应用内的指引需要对当前用户面部眼部变化进行分析,当前卡在视频录制上有异常,不同的设备处理起来不一样。因此对代码进行重新调整.

I/MediaRecorderJNI: prepare: surface=0xb4000075ece8e200
E/MediaRecorder: start failed: -19Got a deoptimization request on un-deoptimizable method void android.media.MediaRecorder.start()
D/AAudio: AAudioStream_close(s#1) called ---------------
D/AAudioStream: setState(s#1) from 10 to 11
D/AAudioStream: setState(s#1) from 11 to 12
D/AAudioStream: ~AudioStream(s#1) mPlayerBase strongCount = 2
D/AAudio: AAudioStream_close(s#1) returned 0 ---------
W/System.err: java.lang.RuntimeException: start failed.
W/System.err:     at android.media.MediaRecorder.start(Native Method)

        (1)检查权限。确保应用拥有录音权限。 
        (2)检查麦克风占用情况。确保没有其他应用或进程正在使用麦克风。
        (3)检查设备兼容性。某些设备可能不支持特定的音频源或设置。尝试使用不同的音频源和采样率。
        (4)确保正确初始化 MediaRecorder。在调用 start() 方法之前,确保 MediaRecorder 已经正确初始化并设置了所有必要参数。

//设备为1080*1920的手机
mediaRecorder!!.setVideoSize(1920, 1080)//正确
mediaRecorder!!.setVideoSize(1080, 1920)//报错=》start failed: -19

        (5)检查设备资源。如果设备资源不足(例如内存或 CPU 负载过高),也可能会导致此错误。尝试关闭其他不必要的应用,或重启设备后再尝试。        

二、使用MediaRecorder录制视频

2.1 申请权限

    <!--如需使用人脸识别,还要添加:摄相头权限,拍照需要用到 -->
    <uses-permission android:name="android.permission.CAMERA" />

    <!--获取手机录音机使用权限,听写、识别、语义理解需要用到此权限 -->
    <uses-permission android:name="android.permission.RECORD_AUDIO" />

        需要在代码中动态申请权限的哦。
        自己玩,可以直接在设置中授权。

2.2 布局文件

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"android:layout_width="match_parent"android:layout_height="match_parent"><TextureViewandroid:id="@+id/textureView"android:layout_width="match_parent"android:layout_height="match_parent"/><Buttonandroid:id="@+id/btn_start"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_marginBottom="70dp"android:text="开始"app:layout_constraintBottom_toBottomOf="parent"app:layout_constraintEnd_toEndOf="parent"app:layout_constraintStart_toStartOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>

2.3 MediaRecordActivity

class MediaRecordActivity : AppCompatActivity() {private var mediaRecorder: MediaRecorder? = nullprivate var camera: Camera? = nullvar binding: ActivityMrBinding? = nulloverride fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)binding = ActivityMrBinding.inflate(layoutInflater)setContentView(binding!!.root)binding!!.btnStart.setOnClickListener { v: View? -> start() }checkPermission()}//申请权限@SuppressLint("WrongConstant")fun checkPermission() {PermissionUtils.permission(PermissionConstants.CAMERA, Manifest.permission.RECORD_AUDIO,).rationale { activity: UtilsTransActivity?, shouldRequest: OnRationaleListener.ShouldRequest ->shouldRequest.again(true)}.callback(object : FullCallback {override fun onGranted(permissionsGranted: List<String>) {}override fun onDenied(permissionsDeniedForever: List<String>,permissionsDenied: List<String>) {}}).request()}private fun start() {val text = binding!!.btnStart.textif (TextUtils.equals(text, "开始")) {binding!!.btnStart.text = "结束"// 将预览视频设置为正常的 不然会颠倒val openId = Camera.getNumberOfCameras() - 1camera = Camera.open(Math.max(openId, 0))//设置前置摄像头camera!!.setDisplayOrientation(90)//旋转90度,可根据设备自行旋转camera!!.unlock()//解锁相机mediaRecorder = MediaRecorder()//初始化mediaRecorder!!.setCamera(camera)mediaRecorder!!.setAudioSource(MediaRecorder.AudioSource.MIC) //设置音频源 麦克风mediaRecorder!!.setVideoSource(MediaRecorder.VideoSource.CAMERA) // 设备视频源 摄像头mediaRecorder!!.setOutputFormat(MediaRecorder.OutputFormat.MPEG_4) // 指定视频文件格式mediaRecorder!!.setAudioEncoder(MediaRecorder.AudioEncoder.AAC)mediaRecorder!!.setVideoEncoder(MediaRecorder.VideoEncoder.H264)// 将视频输出文件设置为正常的 不然会颠倒mediaRecorder!!.setOrientationHint(270)// 设置视频输出文件mediaRecorder!!.setOutputFile(File(getExternalFilesDir(""),"scc.mp4").absoluteFile)mediaRecorder!!.setVideoSize(1920, 1080)mediaRecorder!!.setPreviewDisplay(Surface(binding!!.textureView.surfaceTexture))try {mediaRecorder!!.prepare()} catch (e: IOException) {e.printStackTrace()}mediaRecorder!!.start()} else {binding!!.btnStart.text = "开始"mediaRecorder!!.stop()mediaRecorder!!.release()camera!!.stopPreview()camera!!.release()}}
}

2.4 运行结果 

        成功录制

三、拓展

3.1 录制视频模糊(解决)

    mediaRecorder!!.setVideoEncodingBitRate(10*1920*1080)

        setVideoEncodingBitRate:设置视频每秒录制的字节数。越大视频越清晰。

        设置后的scc.mp4明显更清晰了,别看290>8,但是他俩单位不一样哦。

3.2 阿里云OSS上传文件

        录制视频,肯定不是自己玩,是要上传至服务器进行存储的。这里咱们以阿里云OSS为例。

3.2.1 权限(刚需)

    <!--连接网络权限,用于执行云端语音能力 -->
    <uses-permission android:name="android.permission.INTERNET" />
    <!--外存储写权限,构建语法需要用到此权限 -->
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

3.2.2 安装SDK

implementation 'com.aliyun.dpa:oss-android-sdk:2.9.13'      

3.2.3 使用 

// yourEndpoint填写Bucket所在地域对应的Endpoint。以华东1(杭州)为例,Endpoint填写为https://oss-cn-hangzhou.aliyuncs.com。
String endpoint = "yourEndpoint";
// 从STS服务获取的临时访问密钥(AccessKey ID和AccessKey Secret)。
String accessKeyId = "yourAccessKeyId";
String accessKeySecret = "yourAccessKeySecret";
// 从STS服务获取的安全令牌(SecurityToken)。
String securityToken = "yourSecurityToken";OSSCredentialProvider credentialProvider = new OSSStsTokenCredentialProvider(accessKeyId, accessKeySecret, securityToken);
// 创建OSSClient实例。
OSSClient oss = new OSSClient(getApplicationContext(), endpoint, credentialProvider);// 填写存储空间名称。
CreateBucketRequest createBucketRequest = new CreateBucketRequest("bucketName");
// 设置存储空间的访问权限为公共读,默认为私有读写。
createBucketRequest.setBucketACL(CannedAccessControlList.PublicRead);
// 指定存储空间所在的地域。
createBucketRequest.setLocationConstraint("oss-cn-hangzhou");
OSSAsyncTask createTask = oss.asyncCreateBucket(createBucketRequest, new OSSCompletedCallback<CreateBucketRequest, CreateBucketResult>() {@Overridepublic void onSuccess(CreateBucketRequest request, CreateBucketResult result) {Log.d("locationConstraint", request.getLocationConstraint());}@Overridepublic void onFailure(CreateBucketRequest request, ClientException clientException, ServiceException serviceException) {// 请求异常。if (clientException != null) {// 本地异常,如网络异常等。clientException.printStackTrace();}if (serviceException != null) {// 服务异常。Log.e("ErrorCode", serviceException.getErrorCode());Log.e("RequestId", serviceException.getRequestId());Log.e("HostId", serviceException.getHostId());Log.e("RawMessage", serviceException.getRawMessage());}}
});

相关链接

对象存储(OSS)-Android SDK快速入门-阿里云帮助中心本文介绍如何快速使用OSS Android SDK完成常见操作,例如创建存储空间、上传文件(Object)、下载文件等。icon-default.png?t=N7T8https://help.aliyun.com/zh/oss/developer-reference/getting-started-with-oss-sdk-for-android?spm=a2c4g.11186623.0.0.62e95e0f5jxEDJAndroid SDK 遇到的坑之讯飞语音合成-CSDN博客文章浏览阅读1.2k次,点赞46次,收藏30次。loadLibrary msc error:java.lang.UnsatisfiedLinkError: dlopen failed: library "libmsc.so" not found组件未安装.(错误码:21002)https://shuaici.blog.csdn.net/article/details/141169429

相关文章:

Android MediaRecorder 视频录制及报错解决

目录 一、start failed: -19 二、使用MediaRecorder录制视频 2.1 申请权限 2.2 布局文件 2.3 MediaRecordActivity 2.4 运行结果 三、拓展 3.1 录制视频模糊(解决) 3.2 阿里云OSS上传文件 3.2.1 权限(刚需) 3.2.2 安装SDK 3.2.3 使用 相关链接 一、start failed…...

HarmonyOS应用程序访问控制探究

关于作者 白晓明 宁夏图尔科技有限公司董事长兼CEO、坚果派联合创始人 华为HDE、润和软件HiHope社区专家、鸿蒙KOL、仓颉KOL 华为开发者学堂/51CTO学堂/CSDN学堂认证讲师 开放原子开源基金会2023开源贡献之星 一、引言 随着信息技术的飞速发展&#xff0c;移动应用程序已经成为…...

董卫民赴考拉悠然等企业调研,强调加快发展人工智能产业

8月14日&#xff0c;按照省政府重点产业链协同推进机制有关工作安排&#xff0c;省委常委、常务副省长董卫民在成都市调研人工智能产业发展情况&#xff0c;并召开座谈会。他强调&#xff0c;要坚决落实党的二十届三中全会精神和省委省政府决策部署&#xff0c;充分把握人工智能…...

MFC将类A中的事件在类B中处理采用回调函数实现

需求&#xff1a; 在类A的界面上有一个tab控件。tab控件上面有那个页面。在MFC编程中一个tab的一个页面就应该是一个新的类。在tab的一个页面上有一个list控件。现在需要将list控件的点击事件&#xff0c;双击事件等在类A里面处理。 解决&#xff1a; 在类B里面给控件list添加…...

公众号 微信登录

export function getWxCode(that, localhostUrl) { // localhostUrl 当前页面的路径 传这个也可以this.$route.fullPath// console.log(that.$store.state.wxSessionData)// console.log(that.$store.state.wxSessionData.openId)//openId为undefine执行获取openid判断是否没有…...

sanic + webSocket:股票实时行情推送服务实现

&#x1f49d;&#x1f49d;&#x1f49d;欢迎莅临我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐&#xff1a;「storm…...

Unity动态给按钮各个状态下的图片赋值

Unity动态给按钮各个状态下的图片赋值 using UnityEngine; using UnityEngine.UI; public class ButtonOnClickTest : MonoBehaviour {public Button btn;public Sprite _highlighterSprite;public Sprite _pressedSprite;public Sprite _selectesdSprite;public Sprite _disa…...

xiaomi pad 6PRO 小米平板6 pro hyperOS降级 澎湃os 降级MIUI 14 教程 免解锁BL 降级,168小时解锁绑定

小米平板 6 Pro 机型代号 &#xff1a;liuqin 降级MIUI 14 小米澎湃 OS 正式版 澎湃OS安卓发布日期卡刷包线刷包OS1.0.7.0.UMYCNXM14.02024-07-13miui_LIUQIN_OS1.0.7.0.UMYCNXM_d618a5c980_14.0.zipliuqin_images_OS1.0.7.0.UMYCNXM_20240705.0000.00_14.0_cn_8cbf5920be.…...

MySQL 备份一个表

语法(创建一个与table1结构相同的新表table2&#xff0c;并且将table1的数据复制到table2)&#xff1a; create table table2 as select * from table1 举例(备份tb_log表到tb_log_20240815中去)&#xff1a; create table tb_log_20240815 as select * from tb_log...

鸿蒙开发入门day10-组件导航

(创作不易&#xff0c;感谢有你&#xff0c;你的支持&#xff0c;就是我前行的最大动力&#xff0c;如果看完对你有帮助&#xff0c;还请三连支持一波哇ヾ(&#xff20;^∇^&#xff20;)ノ&#xff09; 目录 组件导航 (Navigation) 设置页面显示模式 设置标题栏模式 设置菜…...

虚拟机Linux的坑 | VMware无法从主机向虚拟机 跨系统复制粘贴拖动 文件/文本

这个情况下&#xff0c;还是没办法跨系统拖拽文件 解决办法&#xff1a; 在终端中输入命令 sudo apt-get autoremove open-vm-tools sudo apt-get install open-vm-tools sudo apt-get install open-vm-tools-desktop过程中只要需要选择是否覆盖的地方&#xff0c;都输入&…...

Chat App 项目之解析(二)

Chat App 项目介绍与解析&#xff08;一&#xff09;-CSDN博客文章浏览阅读76次。Chat App 是一个实时聊天应用程序&#xff0c;旨在为用户提供一个简单、直观的聊天平台。该应用程序不仅支持普通用户的注册和登录&#xff0c;还提供了管理员登录功能&#xff0c;以便管理员可以…...

数据结构与算法 - 双指针

一、移动零 给定一个数组 nums&#xff0c;编写一个函数将所有 0 移动到数组的末尾&#xff0c;同时保持非零元素的相对顺序。 请注意 &#xff0c;必须在不复制数组的情况下原地对数组进行操作。 示例 1: 输入: nums [0,1,0,3,12]输出: [1,3,12,0,0]示例 2: 输入: nums …...

Python3网络爬虫开发实战(10)模拟登录(需补充账号池的构建)

文章目录 一、基于 Cookie 的模拟登录二、基于 JWT 模拟登入三、账号池四、基于 Cookie 模拟登录爬取实战五、基于JWT 的模拟登录爬取实战六、构建账号池 很多情况下&#xff0c;网站的一些数据需要登录才能查看&#xff0c;如果需要爬取这部分的数据&#xff0c;就需要实现模拟…...

SQL 调优最佳实践笔记

定义与重要性 SQL 调优&#xff1a;提高SQL性能&#xff0c;减少查询时间和资源消耗。目标&#xff1a;减少查询时间和扫描的数据行数。 基本原则 减少扫描行数&#xff1a;只扫描所需数据。使用合适索引&#xff1a;确保WHERE条件命中最优索引。合适的Join类型&#xff1a;…...

Eclipse的使用配置教程:必要设置、创建工程及可能遇到的问题(很详细,很全面,能解决90%的问题)

Eclipse的使用配置&#xff1a; Ⅰ、Eclipse 的必要配置&#xff1a;1、Eclipse 的安装&#xff1a;其一、将 Eclipse 解压或安装到没有中文且没有空格的路径下。其二、拿到 eclipse.exe 文件&#xff0c;傻瓜式安装即可; 2、设置工作空间(workspace)&#xff1a;其一、首次启动…...

遗传算法与深度学习实战(4)——遗传算法详解与实现

遗传算法与深度学习实战&#xff08;4&#xff09;——遗传算法详解与实现 0. 前言1. 遗传算法简介1.1 遗传学和减数分裂1.2 类比达尔文进化论 2. 遗传算法的基本流程2.1 创建初始种群2.2 计算适应度2.3 选择、交叉和变异2.4算法终止条件 3. 使用 Python 实现遗传算法3.1 构建种…...

Nginx+Tomcat实现负载均衡、动静分离集群部署

文章目录 一、Nginx​​实现负载均衡原理1.正向代理和反向代理2.负载均衡模式1. 轮询&#xff08;Round Robin&#xff09;&#xff1a;2. 最少连接数&#xff08;Least Connections&#xff09;&#xff1a;3. IP 哈希&#xff08;IP Hash&#xff09;&#xff1a;4. 加权轮询…...

英语学习8月19日

词根前缀后缀 accomplishment 成就 acid n.酸的&#xff0c;adj.酸的 acidity n.酸性 ace adj.顶尖的 acute adj.敏锐的&#xff1b;急性的&#xff1b;严重的 acuity n.敏锐 obtuse adj.迟钝的&#xff1b;钝角的 acuity n.敏锐&#xff0c;严重 1.前缀ac: 尖&#x…...

关于windows环境使用nginx的一些性能问题

遇到的问题 最近在一个windows环境中部署nginx&#xff0c;遇到了以下问题&#xff1a; 1. nginx启动了九个线程&#xff08;1master8woekr&#xff09;&#xff0c;但是所有链接都被1个woker接收&#xff0c;其余worker不工作 2. 用户端访问web很慢&#xff0c;登录服务器使…...

java调用dll出现unsatisfiedLinkError以及JNA和JNI的区别

UnsatisfiedLinkError 在对接硬件设备中&#xff0c;我们会遇到使用 java 调用 dll文件 的情况&#xff0c;此时大概率出现UnsatisfiedLinkError链接错误&#xff0c;原因可能有如下几种 类名错误包名错误方法名参数错误使用 JNI 协议调用&#xff0c;结果 dll 未实现 JNI 协…...

基于Docker Compose部署Java微服务项目

一. 创建根项目 根项目&#xff08;父项目&#xff09;主要用于依赖管理 一些需要注意的点&#xff1a; 打包方式需要为 pom<modules>里需要注册子模块不要引入maven的打包插件&#xff0c;否则打包时会出问题 <?xml version"1.0" encoding"UTF-8…...

华为云Flexus+DeepSeek征文|DeepSeek-V3/R1 商用服务开通全流程与本地部署搭建

华为云FlexusDeepSeek征文&#xff5c;DeepSeek-V3/R1 商用服务开通全流程与本地部署搭建 前言 如今大模型其性能出色&#xff0c;华为云 ModelArts Studio_MaaS大模型即服务平台华为云内置了大模型&#xff0c;能助力我们轻松驾驭 DeepSeek-V3/R1&#xff0c;本文中将分享如何…...

Golang——6、指针和结构体

指针和结构体 1、指针1.1、指针地址和指针类型1.2、指针取值1.3、new和make 2、结构体2.1、type关键字的使用2.2、结构体的定义和初始化2.3、结构体方法和接收者2.4、给任意类型添加方法2.5、结构体的匿名字段2.6、嵌套结构体2.7、嵌套匿名结构体2.8、结构体的继承 3、结构体与…...

【网络安全】开源系统getshell漏洞挖掘

审计过程&#xff1a; 在入口文件admin/index.php中&#xff1a; 用户可以通过m,c,a等参数控制加载的文件和方法&#xff0c;在app/system/entrance.php中存在重点代码&#xff1a; 当M_TYPE system并且M_MODULE include时&#xff0c;会设置常量PATH_OWN_FILE为PATH_APP.M_T…...

Python 训练营打卡 Day 47

注意力热力图可视化 在day 46代码的基础上&#xff0c;对比不同卷积层热力图可视化的结果 import torch import torch.nn as nn import torch.optim as optim from torchvision import datasets, transforms from torch.utils.data import DataLoader import matplotlib.pypl…...

【Linux】Linux安装并配置RabbitMQ

目录 1. 安装 Erlang 2. 安装 RabbitMQ 2.1.添加 RabbitMQ 仓库 2.2.安装 RabbitMQ 3.配置 3.1.启动和管理服务 4. 访问管理界面 5.安装问题 6.修改密码 7.修改端口 7.1.找到文件 7.2.修改文件 1. 安装 Erlang 由于 RabbitMQ 是用 Erlang 编写的&#xff0c;需要先安…...

CSS3相关知识点

CSS3相关知识点 CSS3私有前缀私有前缀私有前缀存在的意义常见浏览器的私有前缀 CSS3基本语法CSS3 新增长度单位CSS3 新增颜色设置方式CSS3 新增选择器CSS3 新增盒模型相关属性box-sizing 怪异盒模型resize调整盒子大小box-shadow 盒子阴影opacity 不透明度 CSS3 新增背景属性ba…...

【免费数据】2005-2019年我国272个地级市的旅游竞争力多指标数据(33个指标)

旅游业是一个城市的重要产业构成。旅游竞争力是一个城市竞争力的重要构成部分。一个城市的旅游竞争力反映了其在旅游市场竞争中的比较优势。 今日我们分享的是2005-2019年我国272个地级市的旅游竞争力多指标数据&#xff01;该数据集源自2025年4月发表于《地理学报》的论文成果…...

Selenium 查找页面元素的方式

Selenium 查找页面元素的方式 Selenium 提供了多种方法来查找网页中的元素&#xff0c;以下是主要的定位方式&#xff1a; 基本定位方式 通过ID定位 driver.find_element(By.ID, "element_id")通过Name定位 driver.find_element(By.NAME, "element_name"…...