关于MIDI键盘的服务对接

本文介绍如何使用Electron框架监听MIDI设备并实现与MIDI键盘的服务连接。通过navigator对象监听getUserMedia权限,利用MIDIInterface自定义类管理MIDI访问权限和服务状态。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

运用electron连接MIDI键盘服务

1.使用addEventListener监听浏览器navigator是否生成getUserMedia()服务

window.addEventListener('load', function () {
navigator.getUserMedia({ video: true, audio: true }, function onSuccess(stream) {
        console.log('已点击允许,开启成功');
    }, function onError(error) {
        console.log("错误:", error);
    });
});

2.然后声明一个函数将midi服务的方法映射到window对象中

	var MIDIInterface = function () {
        this.promise = navigator.requestMIDIAccess();
        this.promise.then(
            function (acc) {
                window.midi.access = acc;
                window.midi.internalFunctionAccessGranted();
                console.log('MIDI服务 Is Ready.');
            }
        );
        //键值绑定
        this.internalFunctionAccessGranted = function () {
            var it = this.access.inputs.entries();
            var cango = true;
            while (cango) {
                var input = it.next();
                if (input.value) {
                    var isstr = true;
                    var i = 0;
                    while (isstr) {
                        if (typeof input.value[i] !== 'string') {
                            isstr = false;
                            this.input = input.value[i];
                            this.internalFunctionInputReady();//键值绑定回调
                        }
                        i++;
                    }
                } else {
                    cango = false;
                }
            }
        };
        //通过键值绑定相关方法
        this.internalFunctionInputReady = function () {
        this.input.onmidimessage = function (msg) {
				//通过msg绑定相关方法...
			};
        };
		//判断当前键值是开始还是结束
        var notevent;
        var notevents = [];
        this.noteEvent = function (evt, noteid) {
            if (noteid) {
                notevents[noteid] = evt;
            } else {
                notevent = evt;
            }
        };
    };

完成~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值