安卓多媒体(视频录制、播放、音效播放)

2024-04-28 16:48

本文主要是介绍安卓多媒体(视频录制、播放、音效播放),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

安卓多媒体(视频录制、播放、音效播放)

一、MediaRecorder录制视频

使用MediaRecorder能够编写从设备麦克风与相机捕获音视频、保存音视频并(使用MediaPlayer)进行播放的应用。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-sut5OuR5-1623675956185)(C:\Users\23737\AppData\Roaming\Typora\typora-user-images\image-20210614202933768.png)]
在这里插入图片描述

1.申请权限
 <uses-permission android:name="android.permission.RECORD_AUDIO" /><uses-permission android:name="android.permission.CAMERA" />

分别是音频麦克风和视频相机的权限

2.在主活动的布局文件上添加TextureView和一个按钮
<?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"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context=".VideoRecording.MediaRecordActivity"><TextureViewandroid:id="@+id/textureView"android:layout_width="match_parent"android:layout_height="match_parent" /><Buttonandroid:id="@+id/btn_opt"android:onClick="onClick"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="开始"app:layout_constraintBottom_toBottomOf="parent"app:layout_constraintEnd_toEndOf="parent"app:layout_constraintStart_toStartOf="parent" /></androidx.constraintlayout.widget.ConstraintLayout>
3.在java文件下编辑代码
package com.example.it_train.VideoRecording;import androidx.appcompat.app.AppCompatActivity;import android.hardware.Camera;
import android.media.MediaRecorder;
import android.os.Bundle;
import android.text.TextUtils;
import android.view.Surface;
import android.view.TextureView;
import android.view.View;
import android.widget.Button;import com.example.it_train.R;import java.io.File;
import java.io.IOException;public class MediaRecordActivity extends AppCompatActivity {private TextureView mTextureView;private Button mBtn_opt;private Camera camera;private MediaRecorder mediaRecorder;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_media_record);//找到控件mTextureView = findViewById(R.id.textureView);mBtn_opt = findViewById(R.id.btn_opt);}public void onClick(View view){CharSequence text = mBtn_opt.getText();if (TextUtils.equals(text,"开始")) {mBtn_opt.setText("结束");//初始化相机camera = Camera.open();/*** camera.setDisplayOrientation(90);使用在录制视频的时候,显示的效果不是颠倒的* 录制分为  预览 和  真实拍摄  两个阶段* 预览时候是反的,使用 camera.setDisplayOrientation(90);来解决* 真实拍摄是反的,使用mediaRecorder.setOrientationHint(90);来解决*/camera.setDisplayOrientation(90);camera.unlock();mediaRecorder = new 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(90);//设置视频输出文件mediaRecorder.setOutputFile(new File(getExternalFilesDir(""), "a.mp4").getAbsolutePath());mediaRecorder.setVideoSize(640, 480);//设置摄像头预览的画布mediaRecorder.setPreviewDisplay(new Surface(mTextureView.getSurfaceTexture()));try {//录制视频准备mediaRecorder.prepare();} catch (IOException e) {e.printStackTrace();}//进入了录制mediaRecorder.start();}else{mBtn_opt.setText("开始");//回到初始阶段mediaRecorder.stop();mediaRecorder.release();//这里要记得释放cameracamera.stopPreview();camera.release();}}
}

代码注释已经写得很详细了,不懂的看注释就行

二、MediaPlayer播放视频

1.简介:

MediaPlayer类是媒体框架最重要的组成部分之一。此类的对象能够获取、解码以及播放音频和视频,而且只需极少量设置。它支持多种不同的媒体源,例如:

  • 本地资源
  • 内部URL,例如可能从内容解析器那里获得url
  • 外部网址

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hSTHcNjQ-1623675956187)(C:\Users\23737\AppData\Roaming\Typora\typora-user-images\image-20210614203410240.png)]
在这里插入图片描述

2.在布局文件下添加TextuerView和按钮
<?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"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context=".VideoRecording.VideoActivity"><TextureViewandroid:id="@+id/textureView"android:layout_width="match_parent"android:layout_height="match_parent" /><Buttonandroid:id="@+id/btn_opt"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="开始"app:layout_constraintBottom_toBottomOf="parent"app:layout_constraintEnd_toEndOf="parent"app:layout_constraintStart_toStartOf="parent" /></androidx.constraintlayout.widget.ConstraintLayout>
3.在java文件下编辑代码
package com.example.it_train.VideoRecording;import androidx.annotation.Nullable;
import androidx.appcompat.app.AppCompatActivity;import android.media.MediaPlayer;
import android.os.Bundle;
import android.text.TextUtils;
import android.view.Surface;
import android.view.TextureView;
import android.view.View;
import android.widget.Button;import com.example.it_train.R;import java.io.File;
import java.io.IOException;public class VideoActivity extends AppCompatActivity implements View.OnClickListener,MediaPlayer.OnPreparedListener, MediaPlayer.OnCompletionListener {private TextureView textureView;private Button btn_opt;private MediaPlayer mediaPlayer;@Overrideprotected void onCreate(@Nullable Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_video);textureView = findViewById(R.id.textureView);btn_opt = findViewById(R.id.btn_opt);btn_opt.setOnClickListener(this);}@Overridepublic void onClick(View v) {CharSequence text = btn_opt.getText();if (TextUtils.equals(text, "开始")) {btn_opt.setText("结束");mediaPlayer = new MediaPlayer();//设置准备监听mediaPlayer.setOnPreparedListener(this);mediaPlayer.setOnCompletionListener(this);try {//指定视频源mediaPlayer.setDataSource(new File(getExternalFilesDir(""), "a.mp4").getAbsolutePath());} catch (IOException e) {e.printStackTrace();}//设置画布mediaPlayer.setSurface(new Surface(textureView.getSurfaceTexture()));mediaPlayer.prepareAsync();} else {btn_opt.setText("开始");//释放资源mediaPlayer.stop();mediaPlayer.release();}}@Overridepublic void onPrepared(MediaPlayer mp) {mediaPlayer.start();}@Overridepublic void onCompletion(MediaPlayer mp) {btn_opt.setText("开始");mediaPlayer.release();}}

三、使用VideoView来播放视频

1.添加控件
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"><VideoViewandroid:id="@+id/videoView"android:layout_width="match_parent"android:layout_height="match_parent" /></androidx.constraintlayout.widget.ConstraintLayout>
2.java文件下编辑代码
package com.enjoy.mediademo;import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.MediaController;
import android.widget.VideoView;import androidx.annotation.Nullable;
import androidx.appcompat.app.AppCompatActivity;import java.io.File;public class VideoViewActivity extends AppCompatActivity implements View.OnClickListener {@Overrideprotected void onCreate(@Nullable Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_videoview);VideoView videoView = findViewById(R.id.videoView);//设置一个控制器(可以进行视频播放的操控)MediaController mediaController = new MediaController(this);//给控制器设置一个监听,设置上一个下一个功能mediaController.setPrevNextListeners(this, this);videoView.setMediaController(mediaController);//设置视频路径videoView.setVideoPath(new File(getExternalFilesDir(""), "a.mp4").getAbsolutePath());videoView.start();}@Overridepublic void onClick(View v) {Log.i("VideoView","====");}
}

四、SoundPool播放音效

MediaPlayer虽然也能播放音频,但是它有资源占用量较高、延迟时间较长、不支持多个音频同时播放等缺点。这些缺点决定了MediaPlayer在某些场合的使用情况不会很理想,例如在对时间精准度要求相对较高的场景。而SoundPool一般用来播放密集、急促而又短暂的音效,比如: “滴滴一下,马上出发”。

1.添加控件
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"><androidx.recyclerview.widget.RecyclerViewandroid:id="@+id/recyclerView"android:layout_width="match_parent"android:layout_height="match_parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
2.设置适配器
package com.enjoy.mediademo;import android.content.Context;
import android.view.View;
import android.view.ViewGroup;
import android.widget.LinearLayout;
import android.widget.TextView;import androidx.annotation.NonNull;
import androidx.recyclerview.widget.RecyclerView;import java.util.List;public class MyAdapter extends RecyclerView.Adapter<MyAdapter.MyViewHolder> implements View.OnClickListener {private final List<SoundActivity.Sound> data;private final Context context;private final RecyclerView recyclerView;private OnItemClickListener listener;public MyAdapter(List<SoundActivity.Sound> data, RecyclerView recyclerView, Context context) {this.data = data;this.recyclerView = recyclerView;this.context = context;}@NonNull@Overridepublic MyViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {TextView textView = new TextView(context);LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT);layoutParams.topMargin = 18;layoutParams.leftMargin = 18;textView.setLayoutParams(layoutParams);textView.setOnClickListener(this);return new MyViewHolder(textView);}@Overridepublic void onBindViewHolder(@NonNull MyViewHolder holder, int position) {((TextView) holder.itemView).setText(data.get(position).getName());}@Overridepublic int getItemCount() {return data.size();}@Overridepublic void onClick(View v) {if (listener != null) {listener.onItemClick(recyclerView.getChildAdapterPosition(v));}}public void setOnItemClickListener(OnItemClickListener listener) {this.listener = listener;}interface OnItemClickListener {void onItemClick(int position);}class MyViewHolder extends RecyclerView.ViewHolder {public MyViewHolder(@NonNull View itemView) {super(itemView);}}
}
3.java文件下编辑
package com.enjoy.mediademo;import android.media.SoundPool;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.appcompat.app.AppCompatActivity;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;import java.util.ArrayList;
import java.util.List;public class SoundActivity extends AppCompatActivity implements MyAdapter.OnItemClickListener {private SoundPool soundPool;static class Sound {String name;int soundId;public Sound(String name, int soundId) {this.name = name;this.soundId = soundId;}public int getSoundId() {return soundId;}public String getName() {return name;}}List<Sound> data;@Overrideprotected void onCreate(@Nullable Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_sound);RecyclerView recyclerView = findViewById(R.id.recyclerView);LinearLayoutManager linearLayoutManager = new LinearLayoutManager(this);linearLayoutManager.setOrientation(LinearLayoutManager.VERTICAL);recyclerView.setLayoutManager(linearLayoutManager);soundPool = new SoundPool.Builder().setMaxStreams(6).build();data = new ArrayList<>();data.add(new Sound("a4", soundPool.load(this, R.raw.a4, 1)));data.add(new Sound("a5", soundPool.load(this, R.raw.a5, 1)));data.add(new Sound("a6", soundPool.load(this, R.raw.a6, 1)));data.add(new Sound("a7", soundPool.load(this, R.raw.a7, 1)));data.add(new Sound("a8", soundPool.load(this, R.raw.a8, 1)));data.add(new Sound("a9", soundPool.load(this, R.raw.a9, 1)));MyAdapter myAdapter = new MyAdapter(data, recyclerView, this);myAdapter.setOnItemClickListener(this);recyclerView.setAdapter(myAdapter);}@Overridepublic void onItemClick(int position) {Sound sound = data.get(position);soundPool.play(sound.getSoundId(),1.0f, 1.0f, 1, 0, 1.0f);}@Overrideprotected void onDestroy() {super.onDestroy();for (Sound datum : data) {soundPool.unload(datum.getSoundId());}soundPool.release();}
}

五、一点小零碎

?怎么才能使得APP进入之后就显示权限的申请呢

1.首先在manifest申请权限
<uses-permission android:name="android.permission.RECORD_AUDIO" /><uses-permission android:name="android.permission.CAMERA" />
2.在activity的java代码下编辑
public class MainActivity extends AppCompatActivity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);//申请权限ActivityCompat.requestPermissions(this,new String[]{Manifest.permission.CAMERA, Manifest.permission.RECORD_AUDIO},100);}
}

这篇关于安卓多媒体(视频录制、播放、音效播放)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/943750

相关文章

流媒体平台/视频监控/安防视频汇聚EasyCVR播放暂停后视频画面黑屏是什么原因?

视频智能分析/视频监控/安防监控综合管理系统EasyCVR视频汇聚融合平台,是TSINGSEE青犀视频垂直深耕音视频流媒体技术、AI智能技术领域的杰出成果。该平台以其强大的视频处理、汇聚与融合能力,在构建全栈视频监控系统中展现出了独特的优势。视频监控管理系统EasyCVR平台内置了强大的视频解码、转码、压缩等技术,能够处理多种视频流格式,并以多种格式(RTMP、RTSP、HTTP-FLV、WebS

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

Android平台播放RTSP流的几种方案探究(VLC VS ExoPlayer VS SmartPlayer)

技术背景 好多开发者需要遴选Android平台RTSP直播播放器的时候,不知道如何选的好,本文针对常用的方案,做个大概的说明: 1. 使用VLC for Android VLC Media Player(VLC多媒体播放器),最初命名为VideoLAN客户端,是VideoLAN品牌产品,是VideoLAN计划的多媒体播放器。它支持众多音频与视频解码器及文件格式,并支持DVD影音光盘,VCD影

《x86汇编语言:从实模式到保护模式》视频来了

《x86汇编语言:从实模式到保护模式》视频来了 很多朋友留言,说我的专栏《x86汇编语言:从实模式到保护模式》写得很详细,还有的朋友希望我能写得更细,最好是覆盖全书的所有章节。 毕竟我不是作者,只有作者的解读才是最权威的。 当初我学习这本书的时候,只能靠自己摸索,网上搜不到什么好资源。 如果你正在学这本书或者汇编语言,那你有福气了。 本书作者李忠老师,以此书为蓝本,录制了全套视频。 试

消除安卓SDK更新时的“https://dl-ssl.google.com refused”异常的方法

消除安卓SDK更新时的“https://dl-ssl.google.com refused”异常的方法   消除安卓SDK更新时的“https://dl-ssl.google.com refused”异常的方法 [转载]原地址:http://blog.csdn.net/x605940745/article/details/17911115 消除SDK更新时的“

轻松录制每一刻:探索2024年免费高清录屏应用

你不会还在用一些社交工具来录屏吧?现在的市面上有不少免费录屏的软件了。别看如软件是免费的,它的功能比起社交工具的录屏功能来说全面的多。这次我就分享几款我用过的录屏工具。 1.福晰录屏大师 链接直达:https://www.foxitsoftware.cn/REC/  这个软件的操作方式非常简单,打开软件之后从界面设计就能看出来这个软件操作的便捷性。界面的设计简单明了基本一打眼你就会轻松驾驭啦

SAM2POINT:以zero-shot且快速的方式将任何 3D 视频分割为视频

摘要 我们介绍 SAM2POINT,这是一种采用 Segment Anything Model 2 (SAM 2) 进行零样本和快速 3D 分割的初步探索。 SAM2POINT 将任何 3D 数据解释为一系列多向视频,并利用 SAM 2 进行 3D 空间分割,无需进一步训练或 2D-3D 投影。 我们的框架支持各种提示类型,包括 3D 点、框和掩模,并且可以泛化到不同的场景,例如 3D 对象、室

树莓派5_opencv笔记27:Opencv录制视频(无声音)

今日继续学习树莓派5 8G:(Raspberry Pi,简称RPi或RasPi)  本人所用树莓派5 装载的系统与版本如下:  版本可用命令 (lsb_release -a) 查询: Opencv 与 python 版本如下: 今天就水一篇文章,用树莓派摄像头,Opencv录制一段视频保存在指定目录... 文章提供测试代码讲解,整体代码贴出、测试效果图 目录 阶段一:录制一段

基于树梅派的视频监控机器人Verybot

最近这段时间做了一个基于树梅派 ( raspberry pi ) 的视频监控机器人平台 Verybot ,现在打算把这个机器人的一些图片、视频、设计思路进行公开,并且希望跟大家一起研究相关的各种问题,下面是两张机器人的照片:         图片1:                   图片2                    这个平台的基本组成是: