电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

js通過audioContext實現3D音效

瀏覽:86日期:2024-04-01 18:12:33

本文實例為大家分享了js通過audioContext實現3D音效的具體代碼,供大家參考,具體內容如下

前言

AudioContext的setPosition實現3D音效

效果展示

js通過audioContext實現3D音效

代碼展示

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title>3D Audio</title> <style>body, div{ margin: 0px; padding: 0px; text-align: center;}#cav{ border: 1px solid black; border-radius: 4px; margin: 10px auto;} </style></head><body><canvas height='200'></canvas></body><script> let Aud = function (ctx, url) {this.ctx = ctx;this.url = url;// source節點this.src = ctx.createBufferSource();// 多個處理節點組this.pNode = []; }; Aud.prototype = {output(){ for (let i = 0; i < this.pNode.length; i++){let tNode = this.src;for (let j = 0; j < this.pNode[i].length; j++){ tNode.connect(this.pNode[i][j]); tNode = this.pNode[i][j];}tNode.connect(this.ctx.destination); }},play(loop){ this.src.loop = loop || false; this.output(); this.src.start(0);},stop() { this.src.stop();},addNode(node, groupIdx = 0){ this.pNode[groupIdx] = this.pNode[groupIdx] || []; this.pNode[groupIdx].push(node);} }; //設置節點類型 Aud.NODETYPE = {GNODE: 0 // 表示gainNode節點 } //Aud管理對象 AudManager = {urls: [],items: [],ctx: null,init(){ try{this.ctx = new AudioContext(); }catch (e) {console.log(`${e}`); }},load(callback){ for (let i = 0; i < this.urls.length; i++){this.loadSingle(this.urls[i], callback); }},loadSingle(url, callback){ let req = new XMLHttpRequest(); req.open(’GET’, url, true); req.responseType = ’arraybuffer’; let self = this; req.onload = function () {self.ctx.decodeAudioData(this.response) .then(buf => { let aud = new Aud(self.ctx, url); aud.src.buffer = buf; self.items.push(aud); if (self.items.length == self.urls.length){callback(); }},err => { console.log(`decode error:${err}`);} ) }; req.send();},createNode(nodeType, param){ let node = null; switch (nodeType) {case 1: node = this.ctx.createPanner(); break;case 2: node = this.ctx.createScriptProcessor(param[0], param[1], param[2]); break;default: node = this.ctx.createGain(); } return node;} }; let ctx = document.getElementById(’cav’).getContext(’2d’);// 定義移動點坐標 let cX = 190,cY = 100,deg = 0; window.onload = function (){init(); } function renderCir(x, y, r, col){ctx.save();ctx.beginPath();ctx.arc(x, y, r, 0, Math.PI*2);ctx.closePath();ctx.fillStyle = col;ctx.fill();ctx.restore(); } function renderCenter(){renderCir(160, 100, 8, 'red'); } function renderCat() {renderCir(cX, cY, 8, 'blue'); } function init(){AudManager.urls = ['test.mp3'];AudManager.init();AudManager.load(()=>{ let pNod1 = AudManager.createNode(1); let sound1 = AudManager.items[0]; sound1.addNode(pNod1); sound1.play(true); timeHandle();}); } function timeHandle() {window.setInterval(()=>{ ctx.clearRect(0,0,320,200); let rad = Math.PI*deg / 180; let sx = 90*Math.cos(rad),sy = 90*Math.sin(rad); cX = 160 + sx; cY = 100 + sy; AudManager.items[0].pNode[0][0].setPosition(sx*0.1, -sy*0.1, 0); renderCenter(); renderCat(); deg++;}, 30); }</script></html>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 天津货架厂_穿梭车货架_重型仓储货架_阁楼货架定制-天津钢力仓储货架生产厂家_天津钢力智能仓储装备 | 办公室装修_上海办公室设计装修_时尚办公新主张-后街印象 | 青岛空压机,青岛空压机维修/保养,青岛空压机销售/出租公司,青岛空压机厂家电话 | 无压烧结银_有压烧结银_导电银胶_导电油墨_导电胶-善仁(浙江)新材料 | 蜂蜜瓶-玻璃瓶-玻璃瓶厂-玻璃瓶生产厂家-徐州贵邦玻璃制品有限公司 | 胶原检测试剂盒,弹性蛋白检测试剂盒,类克ELISA试剂盒,阿达木单抗ELISA试剂盒-北京群晓科苑生物技术有限公司 | 砂尘试验箱_淋雨试验房_冰水冲击试验箱_IPX9K淋雨试验箱_广州岳信试验设备有限公司 | 吹塑加工_大型吹塑加工_滚塑代加工-莱力奇吹塑加工有限公司 | 警用|治安|保安|不锈钢岗亭-售货亭价格-垃圾分类亭-移动厕所厂家-苏州灿宇建材 | 山东螺杆空压机,烟台空压机,烟台开山空压机-烟台开山机电设备有限公司 | 彭世修脚_修脚加盟_彭世修脚加盟_彭世足疗加盟_足疗加盟连锁_彭世修脚技术培训_彭世足疗 | 雨水收集系统厂家-雨水收集利用-模块雨水收集池-徐州博智环保科技有限公司 | 精密线材测试仪-电线电缆检测仪-苏州欣硕电子科技有限公司 | 奥运星-汽车性能网评-提供个性化汽车资讯 | 硬度计_影像测量仪_维氏硬度计_佛山市精测计量仪器设备有限公司厂家 | 创客匠人-让IP变现不走弯路 | 彩超机-黑白B超机-便携兽用B超机-多普勒彩超机价格「大为彩超」厂家 | 安徽华耐泵阀有限公司-官方网站| 找培训机构_找学习课程_励普教育 | 山东led显示屏,山东led全彩显示屏,山东LED小间距屏,临沂全彩电子屏-山东亚泰视讯传媒有限公司 | 外贮压-柜式-悬挂式-七氟丙烷-灭火器-灭火系统-药剂-价格-厂家-IG541-混合气体-贮压-非贮压-超细干粉-自动-灭火装置-气体灭火设备-探火管灭火厂家-东莞汇建消防科技有限公司 | 撕碎机,撕破机,双轴破碎机-大件垃圾破碎机厂家 | 斗式提升机_链式斗提机_带式斗提机厂家无锡市鸿诚输送机械有限公司 | 污水提升器,污水提升泵,地下室排水,增压泵,雨水泵,智能供排水控制器-上海智流泵业有限公司 | 江苏皓越真空设备有限公司 | 硅胶布|电磁炉垫片|特氟龙胶带-江苏浩天复合材料有限公司 | 自动化展_机器人展_机床展_工业互联网展_广东佛山工博会 | 安平县鑫川金属丝网制品有限公司,声屏障,高速声屏障,百叶孔声屏障,大弧形声屏障,凹凸穿孔声屏障,铁路声屏障,顶部弧形声屏障,玻璃钢吸音板 | 宝宝药浴-产后药浴-药浴加盟-艾裕-专注母婴调养泡浴 | 武汉画册印刷厂家-企业画册印刷-画册设计印刷制作-宣传画册印刷公司 - 武汉泽雅印刷厂 | 慈溪麦田广告公司,提供慈溪广告设计。| DWS物流设备_扫码称重量方一体机_快递包裹分拣机_广东高臻智能装备有限公司 | 不锈钢螺丝 - 六角螺丝厂家 - 不锈钢紧固件 - 万千紧固件--紧固件一站式采购 | 裹包机|裹膜机|缠膜机|绕膜机-上海晏陵智能设备有限公司 | 污水处理设备维修_污水处理工程改造_机械格栅_过滤设备_气浮设备_刮吸泥机_污泥浓缩罐_污水处理设备_污水处理工程-北京龙泉新禹科技有限公司 | 2-羟基泽兰内酯-乙酰蒲公英萜醇-甘草查尔酮A-上海纯优生物科技有限公司 | 泰兴市热钻机械有限公司-热熔钻孔机-数控热熔钻-热熔钻孔攻牙一体机 | 代理记账_免费注册公司_营业执照代办_资质代办-【乐财汇】 | 线材成型机,线材折弯机,线材成型机厂家,贝朗自动化设备有限公司1 | 商标转让-购买商标专业|放心的商标交易网-蜀易标商标网 | 右手官网|右手工业设计|外观设计公司|工业设计公司|产品创新设计|医疗产品结构设计|EMC产品结构设计 |