当前位置: 首页 > 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;登录服务器使…...

2个实测免费的AI简历神器,简历回复率翻3倍,顺利过ATS机筛!

当前的求职市场&#xff0c;投简历简直像往海里扔石头。很多同学吐槽&#xff1a;明明自己挺优秀&#xff0c;投了100份简历却连一个面试邀请都没有。 其实&#xff0c;大厂HR第一轮根本不看简历&#xff0c;全是靠ATS&#xff08;简历筛选系统&#xff09;关键词过滤。如果你…...

QT无边框窗口实战:从圆角绘制到自定义标题栏与拖拽交互

1. 为什么需要无边框窗口&#xff1f; 现代桌面应用越来越注重视觉体验&#xff0c;传统的系统标题栏往往与整体设计风格格格不入。想象一下&#xff0c;你精心设计了一款深色主题的音乐播放器&#xff0c;顶部却突兀地挂着Windows默认的白色标题栏——这种割裂感正是无边框窗口…...

Stream Deck与Arduino打造物联网信息看板:软硬云结合实战

1. 项目概述&#xff1a;打造你的专属物理信息看板如果你和我一样&#xff0c;是个桌面极客或者直播爱好者&#xff0c;那你对Elgato的Stream Deck一定不陌生。这个小玩意儿最初是为直播设计的&#xff0c;可以一键切换场景、播放音效&#xff0c;堪称效率神器。但它的潜力远不…...

Gridforms响应式设计原理:如何让表单在手机、平板和桌面端完美适配

Gridforms响应式设计原理&#xff1a;如何让表单在手机、平板和桌面端完美适配 【免费下载链接】gridforms Data entry can be beautiful 项目地址: https://gitcode.com/gh_mirrors/gr/gridforms Gridforms是一个专注于数据录入体验的响应式表单解决方案&#xff0c;通…...

中美Agent生态的路径差异——《重构与崛起——OpenClaw时代的中国Agent产业生态报告》解读三

易观分析&#xff1a;面对OpenClaw掀起的全球AI Agent技术浪潮&#xff0c;中美两国走出截然不同的发展路径。美国生态追求底层框架与协议的原创定义&#xff1b;而中国生态以应用驱动、平台绑定和合规先行为核心逻辑&#xff0c;快速将前沿技术转化为可落地的商业现实。这两条…...

从沙子到车辙(1.5):从图灵机到 ECU

1.5 从图灵机到 ECU 一座恶魔般的机房 1945 年&#xff0c;费城&#xff0c;宾夕法尼亚大学摩尔工程学院。 一座 30 吨重的巨兽蹲在一间约 167 平方米的机房里。它的名字叫 ENIAC&#xff08;Electronic Numerical Integrator and Computer&#xff09;——世界上第一台通用…...

【技术解析】从点测量到全场感知:DIC三维应变测量如何革新传统应变片测试范式

1. 从点到面的技术革命&#xff1a;为什么我们需要全场应变测量&#xff1f; 记得我第一次接触材料力学测试时&#xff0c;导师让我用传统应变片测量一块铝合金板的拉伸变形。我花了整整三天时间&#xff0c;在试样上贴了二十多个应变片&#xff0c;结果数据还是支离破碎。那时…...

Linux驱动开发实战:手把手教你为GT1151触摸屏编写I2C+Input+中断驱动(基于F1C200S)

Linux驱动开发实战&#xff1a;GT1151触摸屏I2CInput中断驱动全解析 1. 嵌入式Linux驱动开发概述 在嵌入式系统开发中&#xff0c;触摸屏作为人机交互的核心组件&#xff0c;其驱动开发一直是工程师必须掌握的技能。GT1151作为一款广泛应用于嵌入式设备的电容式触摸屏控制器&am…...

【风光场景生成】基于改进ISODATA的负荷曲线聚类算法附Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长毕业设计辅导、数学建模、数据处理、程序设计科研仿真。 &#x1f34e;完整代码获取 定制创新 论文复现点击&#xff1a;Matlab科研工作室 &#x1f447; 关注我领取海量matlab电子书和数学建模资料 &…...

Cairo高级特性解析:泛型、Trait系统和元编程的深度应用

Cairo高级特性解析&#xff1a;泛型、Trait系统和元编程的深度应用 【免费下载链接】cairo Cairo is the first Turing-complete language for creating provable programs for general computation. 项目地址: https://gitcode.com/gh_mirrors/ca/cairo Cairo作为首个支…...