博客
关于我
录音功能
阅读量: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锁(2):表级锁
查看>>
MySQL锁,锁的到底是什么?
查看>>
MySQL错误-this is incompatible with sql_mode=only_full_group_by完美解决方案
查看>>
Mysql错误2003 -Can't connect toMySQL server on 'localhost'(10061)解决办法
查看>>
MySQL错误提示mysql Statement violates GTID consistency
查看>>
mysql错误:This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its de
查看>>
mysql长事务
查看>>
mysql问题记录
查看>>
MySQL集群解决方案(1):MySQL数据库的集群方案
查看>>
MySQL集群解决方案(4):负载均衡
查看>>
MySQL集群解决方案(5):PXC集群
查看>>
MySQL面试宝典
查看>>
WAP短信:融合传统短信和互联网的新型通信方式
查看>>
mysql面试题学校三表查询_mysql三表查询分组后取每组最大值,mysql面试题。
查看>>
Mysql面试题精选
查看>>
MySQL面试题集锦
查看>>
mysql面试题,存储引擎InnoDB和MyISAM
查看>>
mysql面试题:为什么MySQL单表不能超过2000W条数据?
查看>>