博客
关于我
录音功能
阅读量: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/

你可能感兴趣的文章
Nginx 的 proxy_pass 使用简介
查看>>
Nginx 的配置文件中的 keepalive 介绍
查看>>
Nginx 结合 consul 实现动态负载均衡
查看>>
Nginx 负载均衡与权重配置解析
查看>>
Nginx 负载均衡详解
查看>>
nginx 配置 单页面应用的解决方案
查看>>
nginx 配置https(一)—— 自签名证书
查看>>
nginx 配置~~~本身就是一个静态资源的服务器
查看>>
Nginx 配置清单(一篇够用)
查看>>
Nginx 配置解析:从基础到高级应用指南
查看>>
nginx+php的搭建
查看>>
nginx+tomcat+memcached
查看>>
nginx+Tomcat性能监控
查看>>
nginx+uwsgi+django
查看>>
Nginx-http-flv-module流媒体服务器搭建+模拟推流+flv.js在前端html和Vue中播放HTTP-FLV视频流
查看>>
nginx-vts + prometheus 监控nginx
查看>>
Nginx下配置codeigniter框架方法
查看>>
Nginx之二:nginx.conf简单配置(参数详解)
查看>>
Nginx代理websocket配置(解决websocket异常断开连接tcp连接不断问题)
查看>>
Nginx代理初探
查看>>