当前位置:首页 > 软件开放 > 正文内容

当前时间代码(当前时间的代码)

软件开放1年前 (2024-01-06)463

在 CSS-Tricks 上看到一篇介绍 Web Audio API 的文章,学以致用,为工具箱中的摩斯密码转换器加上了在线播放功能。

从 AudioContext 开始

Web Audio API 主要通过 AudioContext 来处理音频,就好像 RenderingContext 之于 Canvas API。

// Safari 需要 `webkit` 前缀

varAudioContext= window.AudioContext|| window.webkitAudioContext;

varctx = newAudioContext();

通常一个典型的 Web Audio API 操作流程是这样的:

创建音频上下文对象

创建音频源:音频文件、振荡器(生成声波)或音频流(摄像头/麦克风)

连接效果节点

输出音频

通过 Oscillator(振荡器)生成声波

Oscillator 可以发出指定波形和频率的声波。

让我们来听下四种常见的波形:方波 (square)、三角波 (triangle)、正弦波 (sine) 和锯齿波 (sawtooth)

展开全文

当前时间代码(当前时间的代码)

通过 Oscillator,我们无需音频文件,就能生成和电报一样的声音:

varoscillator = ctx.createOscillator();

// 设置波形

oscillator.type = "sine";

// 设置频率

oscillator.frequency.value = 600;

为了把音频输出到扬声器,你需要将各个节点连接起来。接着上面的代码,将 Oscillator 节点连接到 AudioContext.destination(即输出设备),调用 start() 方法开始播放。

varAudioContext= window.AudioContext|| window.webkitAudioContext;

varctx = newAudioContext();

varoscillator = ctx.createOscillator();

oscillator.type = "sine";

oscillator.frequency.value = 600;

oscillator.connect(ctx.destination);

oscillator.start();

要更改音量,你需要连接一个 GainNode(音量控制器)节点。新的节点路由变成了:oscillator - gainNode - destination

vargainNode = ctx.createGain();

oscillator.connect(gainNode);

gainNode.connect(ctx.destination);

// 从第 0 秒开始设置音量为 0.5

gainNode.gain.setValueAtTime(0.5, 0);

gainNode.gain返回的是一个 AudioParam 对象,它有一个 setValueAtTime(value, startTime) 方法来在指定时间设置指定值。

// AudioContext.currentTime 返回的是当前时间

gainNode.gain.setValueAtTime(0.5, ctx.currentTime + 0);

// 1 秒后恢复音量

gainNode.gain.setValueAtTime(1.0, ctx.currentTime + 1);

摩尔斯电码(英语:Morse code)是一种时通时断的信号代码,通过不同的排列顺序来表达不同的英文字母、數字和标点符号。是由美國人艾爾菲德·維爾(Alfred Lewis Vail)與萨缪尔·摩尔斯(Samuel Finley Breese Morse)在1836年发明。 —— 维基百科

摩尔斯电码(英语:Morse code)是一种时通时断的信号代码,通过不同的排列顺序来表达不同的英文字母、數字和标点符号。是由美國人艾爾菲德·維爾(Alfred Lewis Vail)與萨缪尔·摩尔斯(Samuel Finley Breese Morse)在1836年发明。 —— 维基百科

播放摩斯密码所需要的 Web Audio API 上文都已介绍,现在我们只需要根据摩斯密码在不同的时间点设置音量为 1 或 0 就能实现电报效果了。

小结

本文只介绍了 Web Audio API 的冰山一角,更多的特性就等你自己发掘了~

HTML5 音频 API Web Audio

扫描二维码推送至手机访问。

版权声明:本文由飞速云SEO网络优化推广发布,如需转载请注明出处。

本文链接:http://chlfg.com/post/77036.html

分享给朋友:

“当前时间代码(当前时间的代码)” 的相关文章

国外网站新闻软件(国外的新闻软件)

国外网站新闻软件(国外的新闻软件)

今天给各位分享国外网站新闻软件的知识,其中也会对国外的新闻软件进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、查看国际新闻用什么软件更好 2、求问!求问!有什么软件可以关注全球新闻,特别是民生新闻,经济等等之类的。谢谢各位了! 3、有什么可以看国外英...

华为浏览器开了无痕浏览怎么看历史记录(华为浏览器突然没有历史记录了没开无痕)

华为浏览器开了无痕浏览怎么看历史记录(华为浏览器突然没有历史记录了没开无痕)

本篇文章给大家谈谈华为浏览器开了无痕浏览怎么看历史记录,以及华为浏览器突然没有历史记录了没开无痕对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 本文目录一览: 1、华为手机无痕浏览的历史如何还原? 2、无痕浏览器的历史记录在哪? 3、华为p9无痕浏览了如何恢复 华为手机无痕浏览的历...

云摄影照片直播平台(云摄影照片直播平台下载)

云摄影照片直播平台(云摄影照片直播平台下载)

本篇文章给大家谈谈云摄影照片直播平台,以及云摄影照片直播平台下载对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 本文目录一览: 1、享像派云摄影App能连接Sony A7M3进行照片直播吗?用Wifi还是OTG数据线? 2、享像派云摄影照片直播,需要买硬件设备吗? 3、用享像派云摄影...

任务拉新平台源码(拉新脚本平台)

任务拉新平台源码(拉新脚本平台)

本篇文章给大家谈谈任务拉新平台源码,以及拉新脚本平台对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 本文目录一览: 1、快拉新平台靠谱吗 2、地推拉新app推广接单平台 3、正规拉新推广平台有哪些 快拉新平台靠谱吗 是靠谱的。快拉新平台是推做单平台,京东购买一分,美团优化小程序拉新...

体育直播app大全免费下载(中国体育直播app下载)

体育直播app大全免费下载(中国体育直播app下载)

本篇文章给大家谈谈体育直播app大全免费下载,以及中国体育直播app下载对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 本文目录一览: 1、体育直播的软件有哪些?用哪个最好,求推荐 2、请问体育直播的网站有哪些啊 3、有什么手机软件可以看nba直播 体育直播的软件有哪些?用哪个最好...

html静态网页制作代码大全(html静态网页制作代码大全下载)

html静态网页制作代码大全(html静态网页制作代码大全下载)

今天给各位分享html静态网页制作代码大全的知识,其中也会对html静态网页制作代码大全下载进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、寻找最全的HTML语言代码大全 2、html求制作一个简单网页代码,只需要一些文字加张图片 3、用html如何...