博客
关于我
录音功能
阅读量:353 次
发布时间:2019-03-04

本文共 1543 字,大约阅读时间需要 5 分钟。

写在前面:

录音功能并不像是音频播放那样原本就有音频源,他是由纯脚本构成

1.页面组成

简单的UI制作界面如下图

在这里插入图片描述

2.录音音频

直接创建一个AudioSource,但是不给他挂在音频文件

3.创建一个c#脚本,脚本内容如下

using UnityEngine;public class TestAudio : MonoBehaviour{    AudioSource aud;///     ///保存录音文件    ///     // Start is called before the first frame update    void Start()    {        foreach(string device in Microphone.devices)        {            Debug.Log("Name:" + device);        }    }    // Update is called once per frame    void Update()    {            }    public void ButtonOnClick(int index)    {        if(index == 0)        {            aud = this.GetComponent
(); //如果传入的录音参数为0 aud.clip = Microphone.Start(Microphone.devices[0], true, 10, 44100);//开始录音 //参数代表的含义分别为1.目标设备的名称,是否循环录制,录制时间长短,录音品质需要注意的是 //无损音质的采样率=44100,即每秒音频用44100个float数据表示,但语音8000就够了(通常的移动电话=8000)。 } else if(index == 1)//如果传入的录音参数为1说明现在已经录音一段 { Microphone.End(Microphone.devices[0]); } else if(index == 2) { aud = this.GetComponent
(); aud.Play(); int min = 40000; int max = 44100; Debug.Log("播放状态" + IsRecording(Microphone.devices[0]));//输出当前的播放状态 Debug.Log("播放位置" + GetPosition(Microphone.devices[0]));//输出当前录音的位置 } } public bool IsRecording(string deviceName) { return IsRecording(deviceName); } public int GetPosition(string deviceName) { return GetPosition(deviceName); }}

将脚本挂在到AudioSource上,为Button绑定上监听事件,发布到手机上,即可使用录音功能。

转载地址:http://zbjr.baihongyu.com/

你可能感兴趣的文章
mysql 查询,正数降序排序,负数升序排序
查看>>
MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
查看>>
mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
查看>>
mysql 死锁(先delete 后insert)日志分析
查看>>
MySQL 死锁了,怎么办?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 添加列,修改列,删除列
查看>>
mysql 添加索引
查看>>
MySQL 添加索引,删除索引及其用法
查看>>
mysql 状态检查,备份,修复
查看>>
MySQL 用 limit 为什么会影响性能?
查看>>
MySQL 用 limit 为什么会影响性能?有什么优化方案?
查看>>
MySQL 用户权限管理:授权、撤销、密码更新和用户删除(图文解析)
查看>>
mysql 用户管理和权限设置
查看>>
MySQL 的 varchar 水真的太深了!
查看>>
mysql 的GROUP_CONCAT函数的使用(group_by 如何显示分组之前的数据)
查看>>
MySQL 的instr函数
查看>>
MySQL 的mysql_secure_installation安全脚本执行过程介绍
查看>>
MySQL 的Rename Table语句
查看>>