Android MediaRecorder 视频录制及报错解决

火影  金牌会员 | 2024-8-18 03:42:35 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 804|帖子 804|积分 2412

目次
一、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

        根据应用内的指引需要对当前用户面部眼部变化举行分析,当前卡在视频录制上有异常,差别的设备处理起来不一样。因此对代码举行重新调解.
  1. I/MediaRecorderJNI: prepare: surface=0xb4000075ece8e200
  2. E/MediaRecorder: start failed: -19
  3.     Got a deoptimization request on un-deoptimizable method void android.media.MediaRecorder.start()
  4. D/AAudio: AAudioStream_close(s#1) called ---------------
  5. D/AAudioStream: setState(s#1) from 10 to 11
  6. D/AAudioStream: setState(s#1) from 11 to 12
  7. D/AAudioStream: ~AudioStream(s#1) mPlayerBase strongCount = 2
  8. D/AAudio: AAudioStream_close(s#1) returned 0 ---------
  9. W/System.err: java.lang.RuntimeException: start failed.
  10. W/System.err:     at android.media.MediaRecorder.start(Native Method)
复制代码
        (1)查抄权限。确保应用拥有灌音权限。 
        (2)查抄麦克风占用情况。确保没有其他应用或历程正在利用麦克风。
        (3)查抄设备兼容性。某些设备大概不支持特定的音频源或设置。实验利用差别的音频源和采样率。
        (4)确保正确初始化 MediaRecorder。在调用 start() 方法之前,确保 MediaRecorder 已经正确初始化并设置了全部必要参数。
  1. //设备为1080*1920的手机
  2. mediaRecorder!!.setVideoSize(1920, 1080)//正确
  3. 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 布局文件

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3.     xmlns:app="http://schemas.android.com/apk/res-auto"
  4.     android:layout_width="match_parent"
  5.     android:layout_height="match_parent">
  6.     <TextureView
  7.         android:id="@+id/textureView"
  8.         android:layout_width="match_parent"
  9.         android:layout_height="match_parent"/>
  10.     <Button
  11.         android:id="@+id/btn_start"
  12.         android:layout_width="wrap_content"
  13.         android:layout_height="wrap_content"
  14.         android:layout_marginBottom="70dp"
  15.         android:text="开始"
  16.         app:layout_constraintBottom_toBottomOf="parent"
  17.         app:layout_constraintEnd_toEndOf="parent"
  18.         app:layout_constraintStart_toStartOf="parent" />
  19. </androidx.constraintlayout.widget.ConstraintLayout>
复制代码
2.3 MediaRecordActivity

  1. class MediaRecordActivity : AppCompatActivity() {
  2.     private var mediaRecorder: MediaRecorder? = null
  3.     private var camera: Camera? = null
  4.     var binding: ActivityMrBinding? = null
  5.     override fun onCreate(savedInstanceState: Bundle?) {
  6.         super.onCreate(savedInstanceState)
  7.         binding = ActivityMrBinding.inflate(layoutInflater)
  8.         setContentView(binding!!.root)
  9.         binding!!.btnStart.setOnClickListener { v: View? -> start() }
  10.         checkPermission()
  11.     }
  12.     //申请权限
  13.     @SuppressLint("WrongConstant")
  14.     fun checkPermission() {
  15.         PermissionUtils.permission(PermissionConstants.CAMERA, Manifest.permission.RECORD_AUDIO,)
  16.             .rationale { activity: UtilsTransActivity?, shouldRequest: OnRationaleListener.ShouldRequest ->
  17.                 shouldRequest.again(
  18.                     true
  19.                 )
  20.             }
  21.             .callback(object : FullCallback {
  22.                 override fun onGranted(permissionsGranted: List<String>) {}
  23.                 override fun onDenied(
  24.                     permissionsDeniedForever: List<String>,
  25.                     permissionsDenied: List<String>
  26.                 ) {
  27.                 }
  28.             }).request()
  29.     }
  30.     private fun start() {
  31.         val text = binding!!.btnStart.text
  32.         if (TextUtils.equals(text, "开始")) {
  33.             binding!!.btnStart.text = "结束"
  34.             // 将预览视频设置为正常的 不然会颠倒
  35.             val openId = Camera.getNumberOfCameras() - 1
  36.             camera = Camera.open(Math.max(openId, 0))//设置前置摄像头
  37.             camera!!.setDisplayOrientation(90)//旋转90度,可根据设备自行旋转
  38.             camera!!.unlock()//解锁相机
  39.             mediaRecorder = MediaRecorder()//初始化
  40.             mediaRecorder!!.setCamera(camera)
  41.             mediaRecorder!!.setAudioSource(MediaRecorder.AudioSource.MIC) //设置音频源 麦克风
  42.             mediaRecorder!!.setVideoSource(MediaRecorder.VideoSource.CAMERA) // 设备视频源 摄像头
  43.             mediaRecorder!!.setOutputFormat(MediaRecorder.OutputFormat.MPEG_4) // 指定视频文件格式
  44.             mediaRecorder!!.setAudioEncoder(MediaRecorder.AudioEncoder.AAC)
  45.             mediaRecorder!!.setVideoEncoder(MediaRecorder.VideoEncoder.H264)
  46.             // 将视频输出文件设置为正常的 不然会颠倒
  47.             mediaRecorder!!.setOrientationHint(270)
  48.             // 设置视频输出文件
  49.             mediaRecorder!!.setOutputFile(
  50.                 File(
  51.                     getExternalFilesDir(""),
  52.                     "scc.mp4"
  53.                 ).absoluteFile
  54.             )
  55.             mediaRecorder!!.setVideoSize(1920, 1080)
  56.             mediaRecorder!!.setPreviewDisplay(Surface(binding!!.textureView.surfaceTexture))
  57.             try {
  58.                 mediaRecorder!!.prepare()
  59.             } catch (e: IOException) {
  60.                 e.printStackTrace()
  61.             }
  62.             mediaRecorder!!.start()
  63.         } else {
  64.             binding!!.btnStart.text = "开始"
  65.             mediaRecorder!!.stop()
  66.             mediaRecorder!!.release()
  67.             camera!!.stopPreview()
  68.             camera!!.release()
  69.         }
  70.     }
  71. }
复制代码
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.dpass-android-sdk:2.9.13'      
  3.2.3 利用 

  1. // yourEndpoint填写Bucket所在地域对应的Endpoint。以华东1(杭州)为例,Endpoint填写为https://oss-cn-hangzhou.aliyuncs.com。
  2. String endpoint = "yourEndpoint";
  3. // 从STS服务获取的临时访问密钥(AccessKey ID和AccessKey Secret)。
  4. String accessKeyId = "yourAccessKeyId";
  5. String accessKeySecret = "yourAccessKeySecret";
  6. // 从STS服务获取的安全令牌(SecurityToken)。
  7. String securityToken = "yourSecurityToken";
  8. OSSCredentialProvider credentialProvider = new OSSStsTokenCredentialProvider(accessKeyId, accessKeySecret, securityToken);
  9. // 创建OSSClient实例。
  10. OSSClient oss = new OSSClient(getApplicationContext(), endpoint, credentialProvider);
  11. // 填写存储空间名称。
  12. CreateBucketRequest createBucketRequest = new CreateBucketRequest("bucketName");
  13. // 设置存储空间的访问权限为公共读,默认为私有读写。
  14. createBucketRequest.setBucketACL(CannedAccessControlList.PublicRead);
  15. // 指定存储空间所在的地域。
  16. createBucketRequest.setLocationConstraint("oss-cn-hangzhou");
  17. OSSAsyncTask createTask = oss.asyncCreateBucket(createBucketRequest, new OSSCompletedCallback<CreateBucketRequest, CreateBucketResult>() {
  18.     @Override
  19.     public void onSuccess(CreateBucketRequest request, CreateBucketResult result) {
  20.         Log.d("locationConstraint", request.getLocationConstraint());
  21.         }
  22.     @Override
  23.     public void onFailure(CreateBucketRequest request, ClientException clientException, ServiceException serviceException) {
  24.         // 请求异常。
  25.         if (clientException != null) {
  26.             // 本地异常,如网络异常等。
  27.             clientException.printStackTrace();
  28.         }
  29.         if (serviceException != null) {
  30.             // 服务异常。
  31.             Log.e("ErrorCode", serviceException.getErrorCode());
  32.             Log.e("RequestId", serviceException.getRequestId());
  33.             Log.e("HostId", serviceException.getHostId());
  34.             Log.e("RawMessage", serviceException.getRawMessage());
  35.         }
  36.     }
  37. });
复制代码

相关链接

对象存储(OSS)-Android SDK快速入门-阿里云帮助中央本文介绍如何快速利用OSS Android SDK完成常见操作,例如创建存储空间、上传文件(Object)、下载文件等。
https://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


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

火影

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表